#include #include #include #include #include #define RUNS (4096 * 256) #define THREADS 4 static int leader[RUNS] = { 0 }; static atomic_int nb_leaders[RUNS] = { 0 }; // used to check correctness void* elect(void* _tid) { intptr_t tid = (intptr_t) _tid; // For each run (or round) we try to impose ourselves as the run's leader. for (int r = 0; r < RUNS; r++) { if (leader[r] == 0) { leader[r] = tid; atomic_fetch_add(&nb_leaders[r], 1); // used to check correctness } // **Incorrect**, super wrong, plz synchronize. } } int main() { pthread_t handlers[THREADS]; for (intptr_t i = 0; i < THREADS; i++) { int res = pthread_create(&handlers[i], NULL, elect, (void*)(i + 1)); assert(!res); } for (int i = 0; i < THREADS; i++) { int res = pthread_join(handlers[i], NULL); assert(!res); } int r = 0; for (; r < RUNS; r++) { if (nb_leaders[r] != 1) { printf("Leader election for round %d failed.\n", r); break; } } if (r == RUNS) { printf("Looks correct to me! :)\n"); } }