1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
|
// check if write locks are fair
#include <stdio.h>
#include <assert.h>
#include <unistd.h>
#include <pthread.h>
pthread_rwlock_t rwlock;
volatile int killed = 0;
static void *t1_func(void *arg) {
int i;
for (i = 0; !killed; i++) {
int r;
r = pthread_rwlock_wrlock(&rwlock);
assert(r == 0);
usleep(10000);
r = pthread_rwlock_unlock(&rwlock);
assert(r == 0);
}
printf("%lu %d\n", (unsigned long) pthread_self(), i);
return arg;
}
int main(void) {
int r;
#if 0
rwlock = PTHREAD_RWLOCK_INITIALIZER;
#endif
#if 0
pthread_rwlockattr_t attr;
pthread_rwlockattr_init(&attr);
pthread_rwlockattr_setkind_np(&attr, PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP);
r = pthread_rwlock_init(&rwlock, &attr);
#endif
#if 0
pthread_rwlockattr_t attr;
pthread_rwlockattr_init(&attr);
r = pthread_rwlock_init(&rwlock, &attr);
#endif
#if 1
r = pthread_rwlock_init(&rwlock, NULL);
assert(r == 0);
#endif
const int nthreads = 2;
pthread_t tids[nthreads];
for (int i = 0; i < nthreads; i++) {
r = pthread_create(&tids[i], NULL, t1_func, NULL);
assert(r == 0);
}
sleep(10);
killed = 1;
for (int i = 0; i < nthreads; i++) {
void *ret;
r = pthread_join(tids[i], &ret);
assert(r == 0);
}
return 0;
}
|