File: myth_key_getspecific.c

package info (click to toggle)
massivethreads 1.02-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 13,924 kB
  • sloc: ansic: 27,814; sh: 4,559; cpp: 3,334; javascript: 1,799; makefile: 1,745; python: 523; asm: 373; perl: 118; lisp: 9
file content (64 lines) | stat: -rw-r--r-- 1,312 bytes parent folder | download
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
61
62
63
64
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <myth/myth.h>

#define n_keys 100

myth_key_t keys[n_keys];

void * f(void * x) {
  long a = (long)x;
  unsigned short rg[3] = {
    (unsigned short)(     a  & 0xffff),
    (unsigned short)((a + 1) & 0xffff),
    (unsigned short)((a + 2) & 0xffff)
  };
  void * vals[n_keys];
  int i, t;
  for (i = 0; i < n_keys; i++) {
    void * v = (void *)jrand48(rg);
    vals[i] = v;
    int r = myth_setspecific(keys[i], v);
    assert(r == 0);
  }
  for (t = 0; t < 10; t++) {
    for (i = 0; i < n_keys; i++) {
      void * v = myth_getspecific(keys[i]);
      assert(v == vals[i]);
      v = (void *)jrand48(rg);
      vals[i] = v;
      myth_setspecific(keys[i], v);
      myth_yield_ex(myth_yield_option_steal_first);
    }
  }
  return 0;
}

int create_and_delete_keys() {
  long i;
  myth_thread_t th[n_keys];
  for (i = 0; i < n_keys; i++) {
    myth_key_create(&keys[i], 0);
  }
  for (i = 0; i < n_keys; i++) {
    th[i] = myth_create(f, (void *)i);
  }
  for (i = 0; i < n_keys; i++) {
    myth_join(th[i], 0);
  }
  for (i = 0; i < n_keys; i++) {
    int r = myth_key_delete(keys[i]);
    assert(r == 0);
  }
  return 0;
}

int main() {
  int i;
  for (i = 0; i < 10; i++) {
    create_and_delete_keys();
  }
  printf("OK\n");
  return 0;
}