X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fmman%2Fmremap.c;h=cc6991a635e1d2e2eb82f8f24fc39534901d6502;hb=da845d52c5a8bee206fae899654e393d725a287f;hp=78491ef472e4751cca015835cb020dece7abebde;hpb=0b44a0315b47dd8eced9f3b7f31580cf14bbfc01;p=musl diff --git a/src/mman/mremap.c b/src/mman/mremap.c index 78491ef4..cc6991a6 100644 --- a/src/mman/mremap.c +++ b/src/mman/mremap.c @@ -1,19 +1,32 @@ +#define _GNU_SOURCE #include #include +#include +#include #include #include "syscall.h" -#include "libc.h" + +static void dummy(void) { } +weak_alias(dummy, __vm_wait); void *__mremap(void *old_addr, size_t old_len, size_t new_len, int flags, ...) { va_list ap; - void *new_addr; - - va_start(ap, flags); - new_addr = va_arg(ap, void *); - va_end(ap); + void *new_addr = 0; + + if (new_len >= PTRDIFF_MAX) { + errno = ENOMEM; + return MAP_FAILED; + } + + if (flags & MREMAP_FIXED) { + __vm_wait(); + va_start(ap, flags); + new_addr = va_arg(ap, void *); + va_end(ap); + } - return (void *)syscall5(__NR_mremap, (long)old_addr, old_len, new_len, flags, (long)new_addr); + return (void *)syscall(SYS_mremap, old_addr, old_len, new_len, flags, new_addr); } weak_alias(__mremap, mremap);