mdbx: refine POSIX-options detection.

This commit is contained in:
Leonid Yuriev 2019-11-08 16:57:54 +03:00
parent 51440b5542
commit 6a7499c8fc
2 changed files with 10 additions and 12 deletions

View File

@ -207,20 +207,17 @@
#define MDBX_USE_MUTEXES -1 /* Windows don't support POSIX */ #define MDBX_USE_MUTEXES -1 /* Windows don't support POSIX */
#else #else
#ifndef MDBX_USE_MUTEXES #ifndef MDBX_USE_MUTEXES
#if defined(__linux__) || defined(__gnu_linux__) || defined(__FreeBSD__) || \ #if defined(_POSIX_THREAD_PROCESS_SHARED) && \
defined(__APPLE__) || \ _POSIX_THREAD_PROCESS_SHARED >= 200112L && !defined(__FreeBSD__)
(defined(_POSIX_THREAD_PROCESS_SHARED) && \
_POSIX_THREAD_PROCESS_SHARED > 0)
/* Some platforms define the EOWNERDEAD error code even though they /* Some platforms define the EOWNERDEAD error code even though they
* don't support Robust Mutexes. If doubt compile with -MDBX_USE_MUTEXES=1. */ * don't support Robust Mutexes. If doubt compile with -MDBX_USE_MUTEXES=1. */
#if defined(EOWNERDEAD) && _POSIX_C_SOURCE >= 200809L && \ #if defined(EOWNERDEAD) && _POSIX_THREAD_PROCESS_SHARED >= 200809L && \
(!defined(__GLIBC__) || /* LY: glibc before 2.10 has a troubles with \ (defined(_POSIX_THREAD_ROBUST_PRIO_INHERIT) || \
Robust mutexes. */ \ defined(_POSIX_THREAD_ROBUST_PRIO_PROTECT) || \
__GLIBC_PREREQ(2, 10)) && \ defined(PTHREAD_MUTEX_ROBUST) || defined(PTHREAD_MUTEX_ROBUST_NP)) && \
(defined(PTHREAD_MUTEX_ROBUST) || defined(PTHREAD_MUTEX_ROBUST_NP) || \ (!defined(__GLIBC__) || \
defined(PTHREAD_MUTEX_STALLED_NP) || defined(__GLIBC__) || \ __GLIBC_PREREQ(2, 10) /* troubles with Robust mutexes before 2.10 */)
(!defined(__ANDROID__) && !defined(__APPLE__)))
#define MDBX_USE_MUTEXES 2 /* use robust shared pthread mutexes */ #define MDBX_USE_MUTEXES 2 /* use robust shared pthread mutexes */
#else #else
#define MDBX_USE_MUTEXES 1 /* use shared pthread mutexes */ #define MDBX_USE_MUTEXES 1 /* use shared pthread mutexes */

View File

@ -388,7 +388,8 @@ void osal_udelay(unsigned us) {
static unsigned threshold_us; static unsigned threshold_us;
if (threshold_us == 0) { if (threshold_us == 0) {
#ifdef CLOCK_PROCESS_CPUTIME_ID #if defined(_POSIX_CPUTIME) && _POSIX_CPUTIME > -1 && \
defined(CLOCK_PROCESS_CPUTIME_ID)
if (clock_getres(CLOCK_PROCESS_CPUTIME_ID, &ts)) { if (clock_getres(CLOCK_PROCESS_CPUTIME_ID, &ts)) {
int rc = errno; int rc = errno;
log_warning("clock_getres(CLOCK_PROCESS_CPUTIME_ID), failed errno %d", log_warning("clock_getres(CLOCK_PROCESS_CPUTIME_ID), failed errno %d",