mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-02-07 15:03:34 +00:00
Add mlock() and munlock()
This commit is contained in:
parent
7c9ef924bf
commit
fec139f423
8 changed files with 115 additions and 2 deletions
|
@ -23,6 +23,7 @@
|
||||||
#define _POSIX_READER_WRITER_LOCKS _POSIX_VERSION
|
#define _POSIX_READER_WRITER_LOCKS _POSIX_VERSION
|
||||||
#define _POSIX_SEMAPHORES _POSIX_VERSION
|
#define _POSIX_SEMAPHORES _POSIX_VERSION
|
||||||
#define _POSIX_SHARED_MEMORY_OBJECTS _POSIX_VERSION
|
#define _POSIX_SHARED_MEMORY_OBJECTS _POSIX_VERSION
|
||||||
|
#define _POSIX_MEMLOCK_RANGE _POSIX_VERSION
|
||||||
|
|
||||||
#define EOF -1 /* end of file */
|
#define EOF -1 /* end of file */
|
||||||
#define WEOF -1u /* end of file (multibyte) */
|
#define WEOF -1u /* end of file (multibyte) */
|
||||||
|
|
44
libc/calls/mlock.c
Normal file
44
libc/calls/mlock.c
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
/*-*- mode:c;indent-tabs-mode:nil;c-basic-offset:2;tab-width:8;coding:utf-8 -*-│
|
||||||
|
│vi: set net ft=c ts=2 sts=2 sw=2 fenc=utf-8 :vi│
|
||||||
|
╞══════════════════════════════════════════════════════════════════════════════╡
|
||||||
|
│ Copyright 2023 Justine Alexandra Roberts Tunney │
|
||||||
|
│ │
|
||||||
|
│ Permission to use, copy, modify, and/or distribute this software for │
|
||||||
|
│ any purpose with or without fee is hereby granted, provided that the │
|
||||||
|
│ above copyright notice and this permission notice appear in all copies. │
|
||||||
|
│ │
|
||||||
|
│ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL │
|
||||||
|
│ WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED │
|
||||||
|
│ WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE │
|
||||||
|
│ AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL │
|
||||||
|
│ DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR │
|
||||||
|
│ PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER │
|
||||||
|
│ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR │
|
||||||
|
│ PERFORMANCE OF THIS SOFTWARE. │
|
||||||
|
╚─────────────────────────────────────────────────────────────────────────────*/
|
||||||
|
#include "libc/calls/calls.h"
|
||||||
|
#include "libc/calls/syscall_support-nt.internal.h"
|
||||||
|
#include "libc/dce.h"
|
||||||
|
#include "libc/nt/memory.h"
|
||||||
|
#include "libc/runtime/runtime.h"
|
||||||
|
|
||||||
|
static textwindows int sys_mlock_nt(const void *addr, size_t len) {
|
||||||
|
if (VirtualLock(addr, len)) {
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
return __winerr();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Locks virtual memory interval into RAM, preventing it from swapping.
|
||||||
|
*
|
||||||
|
* @return 0 on success, or -1 w/ errno
|
||||||
|
*/
|
||||||
|
int mlock(const void *addr, size_t len) {
|
||||||
|
if (!IsWindows()) {
|
||||||
|
return sys_mlock(addr, len);
|
||||||
|
} else {
|
||||||
|
return sys_mlock_nt(addr, len);
|
||||||
|
}
|
||||||
|
}
|
44
libc/calls/munlock.c
Normal file
44
libc/calls/munlock.c
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
/*-*- mode:c;indent-tabs-mode:nil;c-basic-offset:2;tab-width:8;coding:utf-8 -*-│
|
||||||
|
│vi: set net ft=c ts=2 sts=2 sw=2 fenc=utf-8 :vi│
|
||||||
|
╞══════════════════════════════════════════════════════════════════════════════╡
|
||||||
|
│ Copyright 2023 Justine Alexandra Roberts Tunney │
|
||||||
|
│ │
|
||||||
|
│ Permission to use, copy, modify, and/or distribute this software for │
|
||||||
|
│ any purpose with or without fee is hereby granted, provided that the │
|
||||||
|
│ above copyright notice and this permission notice appear in all copies. │
|
||||||
|
│ │
|
||||||
|
│ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL │
|
||||||
|
│ WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED │
|
||||||
|
│ WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE │
|
||||||
|
│ AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL │
|
||||||
|
│ DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR │
|
||||||
|
│ PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER │
|
||||||
|
│ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR │
|
||||||
|
│ PERFORMANCE OF THIS SOFTWARE. │
|
||||||
|
╚─────────────────────────────────────────────────────────────────────────────*/
|
||||||
|
#include "libc/calls/calls.h"
|
||||||
|
#include "libc/calls/syscall_support-nt.internal.h"
|
||||||
|
#include "libc/dce.h"
|
||||||
|
#include "libc/nt/memory.h"
|
||||||
|
#include "libc/runtime/runtime.h"
|
||||||
|
|
||||||
|
static textwindows int sys_munlock_nt(const void *addr, size_t len) {
|
||||||
|
if (VirtualUnlock(addr, len)) {
|
||||||
|
return 0;
|
||||||
|
} else {
|
||||||
|
return __winerr();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unlocks virtual memory interval from RAM, to permit swapping.
|
||||||
|
*
|
||||||
|
* @return 0 on success, or -1 w/ errno
|
||||||
|
*/
|
||||||
|
int munlock(const void *addr, size_t len) {
|
||||||
|
if (!IsWindows()) {
|
||||||
|
return sys_munlock(addr, len);
|
||||||
|
} else {
|
||||||
|
return sys_munlock_nt(addr, len);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,2 +1,12 @@
|
||||||
.include "o/libc/nt/codegen.inc"
|
.include "o/libc/nt/codegen.inc"
|
||||||
.imp kernel32,__imp_VirtualLock,VirtualLock,0
|
.imp kernel32,__imp_VirtualLock,VirtualLock,0
|
||||||
|
|
||||||
|
.text.windows
|
||||||
|
VirtualLock:
|
||||||
|
push %rbp
|
||||||
|
mov %rsp,%rbp
|
||||||
|
.profilable
|
||||||
|
mov __imp_VirtualLock(%rip),%rax
|
||||||
|
jmp __sysv2nt
|
||||||
|
.endfn VirtualLock,globl
|
||||||
|
.previous
|
||||||
|
|
|
@ -1,2 +1,12 @@
|
||||||
.include "o/libc/nt/codegen.inc"
|
.include "o/libc/nt/codegen.inc"
|
||||||
.imp kernel32,__imp_VirtualUnlock,VirtualUnlock,0
|
.imp kernel32,__imp_VirtualUnlock,VirtualUnlock,0
|
||||||
|
|
||||||
|
.text.windows
|
||||||
|
VirtualUnlock:
|
||||||
|
push %rbp
|
||||||
|
mov %rsp,%rbp
|
||||||
|
.profilable
|
||||||
|
mov __imp_VirtualUnlock(%rip),%rax
|
||||||
|
jmp __sysv2nt
|
||||||
|
.endfn VirtualUnlock,globl
|
||||||
|
.previous
|
||||||
|
|
|
@ -1046,11 +1046,11 @@ imp 'VirtualAllocEx' VirtualAllocEx kernel32 0 5
|
||||||
imp 'VirtualAllocExNuma' VirtualAllocExNuma kernel32 0
|
imp 'VirtualAllocExNuma' VirtualAllocExNuma kernel32 0
|
||||||
imp 'VirtualFree' VirtualFree kernel32 0 3
|
imp 'VirtualFree' VirtualFree kernel32 0 3
|
||||||
imp 'VirtualFreeEx' VirtualFreeEx kernel32 0
|
imp 'VirtualFreeEx' VirtualFreeEx kernel32 0
|
||||||
imp 'VirtualLock' VirtualLock kernel32 0
|
imp 'VirtualLock' VirtualLock kernel32 0 2
|
||||||
|
imp 'VirtualUnlock' VirtualUnlock kernel32 0 2
|
||||||
imp 'VirtualProtectEx' VirtualProtectEx kernel32 0
|
imp 'VirtualProtectEx' VirtualProtectEx kernel32 0
|
||||||
imp 'VirtualQuery' VirtualQuery kernel32 0 3
|
imp 'VirtualQuery' VirtualQuery kernel32 0 3
|
||||||
imp 'VirtualQueryEx' VirtualQueryEx kernel32 0
|
imp 'VirtualQueryEx' VirtualQueryEx kernel32 0
|
||||||
imp 'VirtualUnlock' VirtualUnlock kernel32 0
|
|
||||||
imp 'WTSGetActiveConsoleSessionId' WTSGetActiveConsoleSessionId kernel32 1497
|
imp 'WTSGetActiveConsoleSessionId' WTSGetActiveConsoleSessionId kernel32 1497
|
||||||
imp 'WaitCommEvent' WaitCommEvent kernel32 0
|
imp 'WaitCommEvent' WaitCommEvent kernel32 0
|
||||||
imp 'WaitForDebugEvent' WaitForDebugEvent kernel32 0
|
imp 'WaitForDebugEvent' WaitForDebugEvent kernel32 0
|
||||||
|
|
|
@ -66,6 +66,8 @@ void *VirtualAlloc(void *opt_lpAddress, uint64_t dwSize,
|
||||||
bool32 VirtualFree(void *lpAddress, uint64_t dwSize, uint32_t dwFreeType);
|
bool32 VirtualFree(void *lpAddress, uint64_t dwSize, uint32_t dwFreeType);
|
||||||
bool32 VirtualProtect(void *lpAddress, uint64_t dwSize, uint32_t flNewProtect,
|
bool32 VirtualProtect(void *lpAddress, uint64_t dwSize, uint32_t flNewProtect,
|
||||||
uint32_t *lpflOldProtect) paramsnonnull();
|
uint32_t *lpflOldProtect) paramsnonnull();
|
||||||
|
bool32 VirtualLock(void *lpAddress, size_t dwSize);
|
||||||
|
bool32 VirtualUnlock(void *lpAddress, size_t dwSize);
|
||||||
uint64_t VirtualQuery(const void *lpAddress,
|
uint64_t VirtualQuery(const void *lpAddress,
|
||||||
struct NtMemoryBasicInformation *lpBuffer,
|
struct NtMemoryBasicInformation *lpBuffer,
|
||||||
uint64_t dwLength);
|
uint64_t dwLength);
|
||||||
|
|
|
@ -69,6 +69,8 @@ void *mremap(void *, size_t, size_t, int, ...);
|
||||||
int munmap(void *, uint64_t);
|
int munmap(void *, uint64_t);
|
||||||
int mprotect(void *, uint64_t, int) privileged;
|
int mprotect(void *, uint64_t, int) privileged;
|
||||||
int msync(void *, size_t, int);
|
int msync(void *, size_t, int);
|
||||||
|
int mlock(const void *, size_t);
|
||||||
|
int munlock(const void *, size_t);
|
||||||
void *sbrk(intptr_t);
|
void *sbrk(intptr_t);
|
||||||
int brk(void *);
|
int brk(void *);
|
||||||
long gethostid(void);
|
long gethostid(void);
|
||||||
|
|
Loading…
Reference in a new issue