From: Jonathan Gray Date: Thu, 1 Nov 2018 02:16:13 +0000 (+1100) Subject: util/anon_file: add OpenBSD shm_mkstemp() path X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=6e9c0661f8538cdabe7d7de73af11b4165f51f93;p=mesa.git util/anon_file: add OpenBSD shm_mkstemp() path memfd_create() is a linux syscall replace the use of it with shm_mkstemp() on OpenBSD. unconditionally include stdlib.h for mkstemp()/mkostemp() Fixes: c0376a12341 ("util: add anon_file.h for all memfd/temp file usage") Signed-off-by: Jonathan Gray Reviewed-by: Eric Engestrom Part-of: --- diff --git a/src/util/anon_file.c b/src/util/anon_file.c index bd415adb647..6c8885707f4 100644 --- a/src/util/anon_file.c +++ b/src/util/anon_file.c @@ -33,16 +33,15 @@ #include #include #include +#include -#ifdef __FreeBSD__ +#if defined(__FreeBSD__) || defined(__OpenBSD__) #include #elif defined(HAVE_MEMFD_CREATE) || defined(ANDROID) #include #include -#include #else #include -#include #endif #if !(defined(__FreeBSD__) || defined(HAVE_MEMFD_CREATE) || defined(HAVE_MKOSTEMP) || defined(ANDROID)) @@ -119,6 +118,11 @@ os_create_anonymous_file(off_t size, const char *debug_name) #ifdef __FreeBSD__ (void*)debug_name; fd = shm_open(SHM_ANON, O_CREAT | O_RDWR | O_CLOEXEC, 0600); +#elif defined(__OpenBSD__) + char template[] = "/tmp/mesa-XXXXXXXXXX"; + fd = shm_mkstemp(template); + if (fd != -1) + shm_unlink(template); #elif defined(HAVE_MEMFD_CREATE) || defined(ANDROID) if (!debug_name) debug_name = "mesa-shared";