From: Rich Felker Date: Thu, 3 Mar 2011 05:30:31 +0000 (-0500) Subject: implement POSIX shared memory X-Git-Url: http://nsz.repo.hu/git/?a=commitdiff_plain;h=ebd7af6940bebb3b083a4d9239da27a66d1c32ec;hp=71df8b2760348c55b1c0d04aeebcae372d9760d3;p=musl implement POSIX shared memory --- diff --git a/src/mman/shm_open.c b/src/mman/shm_open.c new file mode 100644 index 00000000..d368622d --- /dev/null +++ b/src/mman/shm_open.c @@ -0,0 +1,21 @@ +#include +#include +#include +#include +#include + +int shm_open(const char *name, int flag, mode_t mode) +{ + int fd, dir; + + while (*name == '/') name++; + if (strchr(name, '/')) { + errno = EINVAL; + return -1; + } + + if ((dir = open("/dev/shm", O_DIRECTORY|O_RDONLY)) < 0) return -1; + fd = openat(dir, name, flag|O_NOFOLLOW|O_CLOEXEC|O_NONBLOCK, mode); + close(dir); + return fd; +} diff --git a/src/mman/shm_unlink.c b/src/mman/shm_unlink.c new file mode 100644 index 00000000..46e60b3b --- /dev/null +++ b/src/mman/shm_unlink.c @@ -0,0 +1,21 @@ +#include +#include +#include +#include +#include + +int shm_unlink(const char *name) +{ + int dir, ret; + + while (*name == '/') name++; + if (strchr(name, '/')) { + errno = EINVAL; + return -1; + } + + if ((dir = open("/dev/shm", O_DIRECTORY|O_RDONLY)) < 0) return -1; + ret = unlinkat(dir, name, 0); + close(dir); + return ret; +}