summaryrefslogtreecommitdiff
path: root/kernel/libc/string
diff options
context:
space:
mode:
authorAnton Kling <anton@kling.gg>2024-12-10 12:24:07 +0100
committerAnton Kling <anton@kling.gg>2024-12-10 12:24:07 +0100
commit916aa42260290e9e864304bc7d9395b6aa693c27 (patch)
tree784cdcbe26e828e18413bf9d31d6a84ed74dd1ba /kernel/libc/string
parentbcca3d183930eeaf3d024476f39d1d8fccf2ebab (diff)
kernel: Add string view and string builder
This makes write/read calls that use strings to communicate much simpler and less error prone.
Diffstat (limited to 'kernel/libc/string')
-rw-r--r--kernel/libc/string/memmove.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/kernel/libc/string/memmove.c b/kernel/libc/string/memmove.c
new file mode 100644
index 0000000..5fc49f7
--- /dev/null
+++ b/kernel/libc/string/memmove.c
@@ -0,0 +1,14 @@
+#include <string.h>
+
+// copy bytes in memory with overlapping areas
+// https://pubs.opengroup.org/onlinepubs/9699919799/functions/memmove.html
+void *memmove(void *s1, const void *s2, size_t n) {
+ // Copying takes place as if the n bytes from the object pointed to by s2 are
+ // first copied into a temporary array of n bytes that does not overlap the
+ // objects pointed to by s1 and s2, and then the n bytes from the temporary
+ // array are copied into the object pointed to by s1.
+ unsigned char tmp[n];
+ memcpy(tmp, s2, n);
+ memcpy(s1, tmp, n);
+ return s1;
+}