File: pth_barrier_race.c

package info (click to toggle)
valgrind 1%3A3.12.0~svn20160714-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 120,428 kB
  • ctags: 70,855
  • sloc: ansic: 674,645; exp: 26,134; xml: 21,574; asm: 7,570; cpp: 7,567; makefile: 7,380; sh: 6,188; perl: 5,855; haskell: 195
file content (48 lines) | stat: -rw-r--r-- 1,241 bytes parent folder | download | duplicates (11)
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
/*
 * Test program that triggers a race between pthread_barrier_wait() and
 * pthread_barrier_destroy(): proper synchronization is missing between
 * the pthread_barrier_wait() and the pthread_barrier_destroy() calls. This
 * test program is based on the example that was posted on February 5, 2009 by
 * Christoph Bartoschek on the valgrind-users mailing list. Redistribution of
 * the source code below is permitted under the GPLv2 license.
 *
 * See also http://article.gmane.org/gmane.comp.debugging.valgrind/8945/match=pthread_barrier_wait
 */


#define _GNU_SOURCE

#include <pthread.h>
#include <stdlib.h>
#include <unistd.h>

static pthread_barrier_t* barrier;


static void* thread(void* arg)
{
  pthread_barrier_wait(barrier);
  return NULL;
}

int main()
{
  pthread_t tid;

  barrier = (pthread_barrier_t *) malloc(sizeof(*barrier));
  pthread_barrier_init(barrier, NULL, 2);

  pthread_create(&tid, NULL, thread, NULL);

  pthread_barrier_wait(barrier);
  /*
   * The sleep() call below ensures that the pthread_barrier_destroy() call
   * happens after the created thread has returned from pthread_barrier_wait().
   */
  sleep(1);
  pthread_barrier_destroy(barrier);
  free(barrier);

  pthread_join(tid, NULL);
  return 0;
}