memfd_create(2)
- NetBSD Manual Pages
MEMFD_CREATE(2) NetBSD System Calls Manual MEMFD_CREATE(2)
NAME
memfd_create -- create anonymous files
LIBRARY
Standard C Library (libc, -lc)
SYNOPSIS
#include <sys/mman.h>
int
memfd_create(const char *name, unsigned int flags);
DESCRIPTION
The memfd_create() system call returns a file descriptor to a file named
name backed only by RAM. Initially, the size of the file is zero.
The length of name must not exceed NAME_MAX-6 characters in length, to
allow for the prefix ``memfd:'' to be added. But since the file descrip-
tor does not live on disk, name does not have to be unique. name is only
intended to be used for debugging purposes and commands like fstat(1).
Additionally, any of the following may be specified as the flags:
MFD_CLOEXEC Set the close(2) on exec(3) flag.
MFD_ALLOW_SEALING Allow adding seals to the file descriptor using the
fcntl(2) F_ADD_SEALS command.
Otherwise, the returned file descriptor behaves the same as a regular
file, including the ability to be mapped by mmap(2).
RETURN VALUES
If successful, the memfd_create() system call returns a non-negative
integer. On failure -1 is returned and errno is set to indicate the
error.
ERRORS
memfd_create() will fail if:
[EFAULT] The argument name is NULL or points to invalid memory.
[EINVAL] The argument flags has any bits set other than
MFD_CLOEXEC or MFD_ALLOW_SEALING.
[ENAMETOOLONG] The length of name appended with the prefix ``memfd:''
would exceed NAME_MAX.
[ENFILE] The system file table is full.
SEE ALSO
fcntl(2), mmap(2), shmget(2), shm_open(3)
HISTORY
memfd_create() is compatible with the Linux system call of the same name
that first appeared in Linux 3.17.
NetBSD 10.99 July 5, 2023 NetBSD 10.99
Powered by man-cgi (2021-06-01).
Maintained for NetBSD
by Kimmo Suominen.
Based on man-cgi by Panagiotis Christias.