/* 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)