X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=os%2Fos-openbsd.h;h=43a649d447bcaeaa3d72f6cdd4dcd58194bd4393;hb=c7cc1c75b801c5fce5dcf165c9b42e5f101be735;hp=7def4326786d9b8e9d24f5f69b3d6fa0dd556462;hpb=22de5d7741f963e57dd5e3bb70d822e992dd2515;p=fio.git diff --git a/os/os-openbsd.h b/os/os-openbsd.h index 7def4326..43a649d4 100644 --- a/os/os-openbsd.h +++ b/os/os-openbsd.h @@ -9,23 +9,22 @@ #include #include #include -/* XXX hack to avoid conflicts between rbtree.h and */ +#include +#include #include + +/* XXX hack to avoid conflicts between rbtree.h and */ #undef RB_BLACK #undef RB_RED #undef RB_ROOT #include "../file.h" -#undef FIO_HAVE_ODIRECT -#define FIO_USE_GENERIC_RAND #define FIO_USE_GENERIC_INIT_RANDOM_STATE #define FIO_HAVE_FS_STAT #define FIO_HAVE_GETTID #define FIO_HAVE_SHM_ATTACH_REMOVED -#undef FIO_HAVE_CPU_AFFINITY /* XXX notyet */ - #define OS_MAP_ANON MAP_ANON #ifndef PTHREAD_STACK_MIN @@ -66,10 +65,12 @@ static inline unsigned long long os_phys_mem(void) return mem; } +#ifndef CONFIG_HAVE_GETTID static inline int gettid(void) { - return (int) pthread_self(); + return (int)(intptr_t) pthread_self(); } +#endif static inline unsigned long long get_fs_free_size(const char *path) { @@ -90,9 +91,31 @@ static inline unsigned long long get_fs_free_size(const char *path) static inline int shm_attach_to_open_removed(void) { + struct utsname uts; + int major, minor; + + if (uname(&uts) == -1) + return 0; + /* - * XXX: Return 1 if >= OpenBSD 5.1 according to 97900ebf. + * Return 1 if >= OpenBSD 5.1 according to 97900ebf, + * assuming both major/minor versions are < 10. */ + if (uts.release[0] > '9' || uts.release[0] < '0') + return 0; + if (uts.release[1] != '.') + return 0; + if (uts.release[2] > '9' || uts.release[2] < '0') + return 0; + + major = uts.release[0] - '0'; + minor = uts.release[2] - '0'; + + if (major > 5) + return 1; + if (major == 5 && minor >= 1) + return 1; + return 0; }