diff --git a/libc/include/sys/syscall.h b/libc/include/sys/syscall.h index a253b214..3cb1af42 100644 --- a/libc/include/sys/syscall.h +++ b/libc/include/sys/syscall.h @@ -20,6 +20,7 @@ __BEGIN_DECLS #define SYS_FORK 13 #define SYS_SLEEP 14 #define SYS_EXEC 15 +#define SYS_REALLOC 16 __END_DECLS diff --git a/libc/stdlib.cpp b/libc/stdlib.cpp index 8209b12d..6de113a3 100644 --- a/libc/stdlib.cpp +++ b/libc/stdlib.cpp @@ -76,6 +76,16 @@ void* calloc(size_t nmemb, size_t size) return ptr; } +void* realloc(void* ptr, size_t size) +{ + if (ptr == nullptr) + return malloc(size); + long ret = syscall(SYS_REALLOC, ptr, size); + if (ret == -1) + return nullptr; + return (void*)ret; +} + void free(void* ptr) { if (ptr == nullptr) diff --git a/libc/unistd.cpp b/libc/unistd.cpp index 970a1fc0..4818b6d3 100644 --- a/libc/unistd.cpp +++ b/libc/unistd.cpp @@ -130,6 +130,13 @@ long syscall(long syscall, ...) ret = Kernel::syscall(SYS_EXEC, (uintptr_t)pathname, (uintptr_t)argv, (uintptr_t)envp); break; } + case SYS_REALLOC: + { + void* ptr = va_arg(args, void*); + size_t size = va_arg(args, size_t); + ret = Kernel::syscall(SYS_REALLOC, (uintptr_t)ptr, size); + break; + } default: puts("LibC: Unhandeled syscall"); ret = -ENOSYS;