Add memory copy and move functions. Required by gcc, and we'll also use
them soon
This commit is contained in:
parent
c19bc51bdc
commit
954696728c
@ -21,3 +21,12 @@
|
|||||||
|
|
||||||
#define PAGE_SIZE 0x1000
|
#define PAGE_SIZE 0x1000
|
||||||
#define ENTRIES_PER_PT 512
|
#define ENTRIES_PER_PT 512
|
||||||
|
|
||||||
|
#ifndef __ASSEMBLER__
|
||||||
|
#include <stddef.h>
|
||||||
|
void *memcpy(void *dst, const void *src, size_t n);
|
||||||
|
void *memset(void *s, int c, size_t n);
|
||||||
|
void *memmove(void *dest, const void *src, size_t n);
|
||||||
|
int memcmp(const void *s1, const void *s2, size_t n);
|
||||||
|
size_t strlen(const char *s);
|
||||||
|
#endif
|
||||||
|
43
src/kernel/memory/string.c
Normal file
43
src/kernel/memory/string.c
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
#include <memory.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stddef.h>
|
||||||
|
|
||||||
|
void *memcpy(void *dst, const void *src, size_t n)
|
||||||
|
{
|
||||||
|
char *dp = dst;
|
||||||
|
const char *sp = src;
|
||||||
|
while(n--) *dp++ = *sp++;
|
||||||
|
return dst;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *memset(void *s, int c, size_t n)
|
||||||
|
{
|
||||||
|
unsigned char *p = s;
|
||||||
|
while(n--) *p++ = (unsigned char)c;
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *memmove(void *dest, const void *src, size_t n)
|
||||||
|
{
|
||||||
|
// Since our memcpy implementation copies one char* at a time, this is safe
|
||||||
|
memcpy(dest, src, n);
|
||||||
|
return dest;
|
||||||
|
}
|
||||||
|
|
||||||
|
int memcmp(const void *s1, const void *s2, size_t n)
|
||||||
|
{
|
||||||
|
const unsigned char *p1 = s1, *p2 = s2;
|
||||||
|
for(; n--; p1++, p2++)
|
||||||
|
{
|
||||||
|
if(*p1 != *p2)
|
||||||
|
return *p1 - *p2;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t strlen(const char *s)
|
||||||
|
{
|
||||||
|
size_t len = 0;
|
||||||
|
while(*s++) len++;
|
||||||
|
return len;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user