1 
2 #include <pthread.h>
3 #include <stdio.h>
4 #include <stdlib.h>
5 
6 /* Simple test program, has a race.  Parent and child both modify y
7    with no locking.  This is the program shown in Fig 2 of the
8    original Eraser paper by Savage et al. */
9 
10 int y = 0, v = 0;
11 pthread_mutex_t mu = PTHREAD_MUTEX_INITIALIZER;
12 
13 void* child_fn ( void* arg )
14 {
15    /* "Thread 2" in the paper */
16    pthread_mutex_lock( &mu );
17    v = v + 1;
18    pthread_mutex_unlock( &mu );
19    y = y + 1;
20    return NULL;
21 }
22 
23 int main ( void )
24 {
25    const struct timespec delay = { 0, 100 * 1000 * 1000 };
26    pthread_t child;
27    if (pthread_create(&child, NULL, child_fn, NULL)) {
28       perror("pthread_create");
29       exit(1);
30    }
31    nanosleep(&delay, 0);
32    /* "Thread 1" in the paper */
33    y = y + 1;
34    pthread_mutex_lock( &mu );
35    v = v + 1;
36    pthread_mutex_unlock( &mu );
37 
38    if (pthread_join(child, NULL)) {
39       perror("pthread join");
40       exit(1);
41    }
42 
43    return 0;
44 }
45