/* Remap a virtual memory address. Linux specific syscall. Copyright (C) 2021-2022 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. The GNU C Library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with the GNU C Library; if not, see . */ #include #include #include #include #include void * __mremap (void *addr, size_t old_len, size_t new_len, int flags, ...) { va_list va; void *new_addr = NULL; if (flags & MREMAP_FIXED) { va_start (va, flags); new_addr = va_arg (va, void *); va_end (va); } void *ret; ret = (void *) INLINE_SYSCALL_CALL (mremap, addr, old_len, new_len, flags, new_addr); #ifdef __CHERI_PURE_CAPABILITY__ if (ret != MAP_FAILED) { size_t ps = GLRO(dl_pagesize); ret = __builtin_cheri_bounds_set (ret, (new_len + ps - 1) & -ps); } #endif return ret; } libc_hidden_def (__mremap) weak_alias (__mremap, mremap)