Skip to content

Commit

Permalink
Extract thread-alive-counter-outer example from nnn
Browse files Browse the repository at this point in the history
  • Loading branch information
sim642 committed Sep 20, 2023
1 parent d25f41d commit b0bc3ad
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 1 deletion.
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
// Thread pool joining via threads alive counter.
// Thread pool joining via threads alive counter incremented inside of thread.
// Extracted from concrat/C-Thread-Pool.
#include <stdbool.h>
#include <pthread.h>
Expand Down
49 changes: 49 additions & 0 deletions tests/regression/03-practical/34-thread-alive-counter-outer.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
// Thread pool joining via threads alive counter incremented outside of thread.
// Extracted from concrat/nnn.
#include <pthread.h>
#include <goblint.h>
extern int __VERIFIER_nondet_int();

int threads_alive = 0;
pthread_mutex_t threads_alive_mutex = PTHREAD_MUTEX_INITIALIZER;

int data = 0;
pthread_mutex_t data_mutex = PTHREAD_MUTEX_INITIALIZER;

void *thread(void *arg) {
pthread_mutex_lock(&data_mutex);
data = __VERIFIER_nondet_int(); // NORACE
pthread_mutex_unlock(&data_mutex);

pthread_mutex_lock(&threads_alive_mutex);
threads_alive--; // NORACE
pthread_mutex_unlock(&threads_alive_mutex);
return NULL;
}

int main() {
int threads_total = __VERIFIER_nondet_int();
__goblint_assume(threads_total >= 0);

// create threads
for (int i = 0; i < threads_total; i++) {
pthread_mutex_lock(&threads_alive_mutex);
threads_alive++; // NORACE
pthread_mutex_unlock(&threads_alive_mutex);

pthread_t tid;
pthread_create(&tid, NULL, &thread, NULL); // may fail but doesn't matter
pthread_detach(tid);
}

// wait for all threads to stop
pthread_mutex_lock(&threads_alive_mutex);
while (threads_alive) { // NORACE
pthread_mutex_unlock(&threads_alive_mutex);
// busy loop for simplicity
pthread_mutex_lock(&threads_alive_mutex);
}
pthread_mutex_unlock(&threads_alive_mutex);

return data; // NORACE (all threads stopped)
}

0 comments on commit b0bc3ad

Please sign in to comment.