/** Cause a race inside code protected by a reader lock. */ /* Needed for older glibc's (2.3 and older, at least) who don't otherwise "know" about pthread_rwlock_anything or about PTHREAD_MUTEX_RECURSIVE (amongst things). */ #define _GNU_SOURCE 1 #include #include #include static pthread_rwlock_t s_rwlock; static int s_racy; static void sleep_ms(const int ms) { struct timespec delay = { ms / 1000, (ms % 1000) * 1000 * 1000 }; nanosleep(&delay, 0); } static void* thread_func(void* arg) { pthread_rwlock_rdlock(&s_rwlock); s_racy++; pthread_rwlock_unlock(&s_rwlock); sleep_ms(100); return 0; } int main(int argc, char** argv) { pthread_t thread1; pthread_t thread2; #if 0 VALGRIND_DO_CLIENT_REQUEST_STMT(VG_USERREQ__DRD_TRACE_ADDR, &s_racy, 0, 0, 0, 0); #endif pthread_rwlock_init(&s_rwlock, 0); pthread_create(&thread1, 0, thread_func, 0); pthread_create(&thread2, 0, thread_func, 0); pthread_join(thread1, 0); pthread_join(thread2, 0); pthread_rwlock_destroy(&s_rwlock); fprintf(stderr, "Result: %d\n", s_racy); return 0; }