2020-01-18 09:38:21 +01:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-01-18 09:38:21 +01:00
|
|
|
*/
|
|
|
|
|
|
2021-07-29 22:22:50 +01:00
|
|
|
#include <AK/Format.h>
|
2018-11-08 11:37:01 +01:00
|
|
|
#include <errno.h>
|
|
|
|
|
#include <stdio.h>
|
2020-01-06 11:56:59 +01:00
|
|
|
#include <string.h>
|
2021-05-14 17:38:33 +02:00
|
|
|
#include <sys/mman.h>
|
2021-02-05 12:16:30 +01:00
|
|
|
#include <syscall.h>
|
2018-10-24 09:48:24 +02:00
|
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
|
|
2020-02-16 12:55:56 +01:00
|
|
|
void* serenity_mmap(void* addr, size_t size, int prot, int flags, int fd, off_t offset, size_t alignment, const char* name)
|
2018-10-24 09:48:24 +02:00
|
|
|
{
|
2020-10-12 14:49:31 +02:00
|
|
|
Syscall::SC_mmap_params params { (uintptr_t)addr, size, alignment, prot, flags, fd, offset, { name, name ? strlen(name) : 0 } };
|
2021-02-25 16:08:02 +01:00
|
|
|
ptrdiff_t rc = syscall(SC_mmap, ¶ms);
|
2019-02-16 15:34:31 +01:00
|
|
|
if (rc < 0 && -rc < EMAXERRNO) {
|
|
|
|
|
errno = -rc;
|
2020-01-06 12:04:55 +01:00
|
|
|
return MAP_FAILED;
|
2019-02-16 15:34:31 +01:00
|
|
|
}
|
|
|
|
|
return (void*)rc;
|
2018-10-24 09:48:24 +02:00
|
|
|
}
|
|
|
|
|
|
2020-02-16 12:55:56 +01:00
|
|
|
void* mmap(void* addr, size_t size, int prot, int flags, int fd, off_t offset)
|
|
|
|
|
{
|
|
|
|
|
return serenity_mmap(addr, size, prot, flags, fd, offset, PAGE_SIZE, nullptr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void* mmap_with_name(void* addr, size_t size, int prot, int flags, int fd, off_t offset, const char* name)
|
|
|
|
|
{
|
|
|
|
|
return serenity_mmap(addr, size, prot, flags, fd, offset, PAGE_SIZE, name);
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-29 02:11:47 +01:00
|
|
|
void* mremap(void* old_address, size_t old_size, size_t new_size, int flags)
|
|
|
|
|
{
|
|
|
|
|
Syscall::SC_mremap_params params { (uintptr_t)old_address, old_size, new_size, flags };
|
2021-02-25 16:08:02 +01:00
|
|
|
ptrdiff_t rc = syscall(SC_mremap, ¶ms);
|
2020-12-29 02:11:47 +01:00
|
|
|
if (rc < 0 && -rc < EMAXERRNO) {
|
|
|
|
|
errno = -rc;
|
|
|
|
|
return MAP_FAILED;
|
|
|
|
|
}
|
|
|
|
|
return (void*)rc;
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-24 09:48:24 +02:00
|
|
|
int munmap(void* addr, size_t size)
|
|
|
|
|
{
|
2018-12-21 03:02:06 +01:00
|
|
|
int rc = syscall(SC_munmap, addr, size);
|
2018-10-25 12:06:00 +02:00
|
|
|
__RETURN_WITH_ERRNO(rc, rc, -1);
|
2018-10-24 09:48:24 +02:00
|
|
|
}
|
|
|
|
|
|
2019-08-12 19:33:24 +02:00
|
|
|
int mprotect(void* addr, size_t size, int prot)
|
|
|
|
|
{
|
|
|
|
|
int rc = syscall(SC_mprotect, addr, size, prot);
|
|
|
|
|
__RETURN_WITH_ERRNO(rc, rc, -1);
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-28 09:57:22 +01:00
|
|
|
int set_mmap_name(void* addr, size_t size, const char* name)
|
|
|
|
|
{
|
2020-01-06 11:56:59 +01:00
|
|
|
if (!name) {
|
|
|
|
|
errno = EFAULT;
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
2020-01-11 12:47:47 +01:00
|
|
|
Syscall::SC_set_mmap_name_params params { addr, size, { name, strlen(name) } };
|
2020-01-06 11:56:59 +01:00
|
|
|
int rc = syscall(SC_set_mmap_name, ¶ms);
|
2018-10-28 09:57:22 +01:00
|
|
|
__RETURN_WITH_ERRNO(rc, rc, -1);
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-09 19:12:38 +01:00
|
|
|
int madvise(void* address, size_t size, int advice)
|
|
|
|
|
{
|
|
|
|
|
int rc = syscall(SC_madvise, address, size, advice);
|
|
|
|
|
__RETURN_WITH_ERRNO(rc, rc, -1);
|
|
|
|
|
}
|
2020-04-12 20:22:26 +02:00
|
|
|
|
2021-04-24 11:30:20 +03:00
|
|
|
void* allocate_tls(const char* initial_data, size_t size)
|
2020-10-10 12:17:07 +03:00
|
|
|
{
|
2021-04-24 11:30:20 +03:00
|
|
|
ptrdiff_t rc = syscall(SC_allocate_tls, initial_data, size);
|
2020-10-10 12:17:07 +03:00
|
|
|
if (rc < 0 && -rc < EMAXERRNO) {
|
|
|
|
|
errno = -rc;
|
|
|
|
|
return MAP_FAILED;
|
|
|
|
|
}
|
|
|
|
|
return (void*)rc;
|
|
|
|
|
}
|
2021-07-29 22:22:50 +01:00
|
|
|
|
|
|
|
|
int mlock(const void*, size_t)
|
|
|
|
|
{
|
|
|
|
|
dbgln("FIXME: Implement mlock()");
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
2018-10-24 09:48:24 +02:00
|
|
|
}
|