X-Git-Url: https://git.liburcu.org/?a=blobdiff_plain;f=urcu.c;h=a26d38fbaca8286ffe1f6fe3bd522e5a2740a34f;hb=52c67a3d6139a6bf56b97ed350c7f3beaef3ce67;hp=d4c5bf2d4b11861e8e682dc535003ea9dee6cced;hpb=3c29ca5d56988c3a10ba289a1129eadb4bf6b3ee;p=urcu.git diff --git a/urcu.c b/urcu.c index d4c5bf2..a26d38f 100644 --- a/urcu.c +++ b/urcu.c @@ -26,6 +26,7 @@ #define _BSD_SOURCE #define _GNU_SOURCE #define _LGPL_SOURCE +#define _DEFAULT_SOURCE #include #include #include @@ -235,9 +236,22 @@ static void wait_gp(void) { /* Read reader_gp before read futex */ smp_mb_master(RCU_MB_GROUP); - if (uatomic_read(&rcu_gp.futex) == -1) - futex_async(&rcu_gp.futex, FUTEX_WAIT, -1, - NULL, NULL, 0); + if (uatomic_read(&rcu_gp.futex) != -1) + return; + while (futex_async(&rcu_gp.futex, FUTEX_WAIT, -1, + NULL, NULL, 0)) { + switch (errno) { + case EWOULDBLOCK: + /* Value already changed. */ + return; + case EINTR: + /* Retry if interrupted by signal. */ + break; /* Get out of switch. */ + default: + /* Unexpected error. */ + urcu_die(errno); + } + } } /*