~ubuntu-branches/ubuntu/raring/clamav/raring-updates

« back to all changes in this revision

Viewing changes to win32/3rdparty/pthreads/tests/once3.c

  • Committer: Bazaar Package Importer
  • Author(s): Scott Kitterman
  • Date: 2011-06-18 11:56:34 UTC
  • mfrom: (0.35.21 sid)
  • Revision ID: james.westby@ubuntu.com-20110618115634-u2lovivet0qx34d0
Tags: 0.97.1+dfsg-1ubuntu1
* Merge from debian unstable.  Remaining changes:
  - Drop build-dep on electric-fence (in Universe)
  - Add apparmor profiles for clamd and freshclam along with maintainer
    script changes

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 * once3.c
3
 
 *
4
 
 *
5
 
 * --------------------------------------------------------------------------
6
 
 *
7
 
 *      Pthreads-win32 - POSIX Threads Library for Win32
8
 
 *      Copyright(C) 1998 John E. Bossom
9
 
 *      Copyright(C) 1999,2005 Pthreads-win32 contributors
10
 
 * 
11
 
 *      Contact Email: rpj@callisto.canberra.edu.au
12
 
 * 
13
 
 *      The current list of contributors is contained
14
 
 *      in the file CONTRIBUTORS included with the source
15
 
 *      code distribution. The list can also be seen at the
16
 
 *      following World Wide Web location:
17
 
 *      http://sources.redhat.com/pthreads-win32/contributors.html
18
 
 * 
19
 
 *      This library is free software; you can redistribute it and/or
20
 
 *      modify it under the terms of the GNU Lesser General Public
21
 
 *      License as published by the Free Software Foundation; either
22
 
 *      version 2 of the License, or (at your option) any later version.
23
 
 * 
24
 
 *      This library is distributed in the hope that it will be useful,
25
 
 *      but WITHOUT ANY WARRANTY; without even the implied warranty of
26
 
 *      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
27
 
 *      Lesser General Public License for more details.
28
 
 * 
29
 
 *      You should have received a copy of the GNU Lesser General Public
30
 
 *      License along with this library in the file COPYING.LIB;
31
 
 *      if not, write to the Free Software Foundation, Inc.,
32
 
 *      59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
33
 
 *
34
 
 * --------------------------------------------------------------------------
35
 
 *
36
 
 * Create several pthread_once objects and channel several threads
37
 
 * through each. Make the init_routine cancelable and cancel them
38
 
 * waiters waiting.
39
 
 *
40
 
 * Depends on API functions:
41
 
 *      pthread_once()
42
 
 *      pthread_create()
43
 
 *      pthread_testcancel()
44
 
 *      pthread_cancel()
45
 
 *      pthread_once()
46
 
 */
47
 
 
48
 
#include "test.h"
49
 
 
50
 
#define NUM_THREADS 100 /* Targeting each once control */
51
 
#define NUM_ONCE    10
52
 
 
53
 
pthread_once_t o = PTHREAD_ONCE_INIT;
54
 
pthread_once_t once[NUM_ONCE];
55
 
 
56
 
typedef struct {
57
 
  int i;
58
 
  CRITICAL_SECTION cs;
59
 
} sharedInt_t;
60
 
 
61
 
static sharedInt_t numOnce = {0, {0}};
62
 
static sharedInt_t numThreads = {0, {0}};
63
 
 
64
 
void
65
 
myfunc(void)
66
 
{
67
 
  EnterCriticalSection(&numOnce.cs);
68
 
  numOnce.i++;
69
 
  LeaveCriticalSection(&numOnce.cs);
70
 
  /* Simulate slow once routine so that following threads pile up behind it */
71
 
  Sleep(10);
72
 
  /* test for cancelation late so we're sure to have waiters. */
73
 
  pthread_testcancel();
74
 
}
75
 
 
76
 
void *
77
 
mythread(void * arg)
78
 
{
79
 
  /*
80
 
   * Cancel every thread. These threads are deferred cancelable only, so
81
 
   * only the thread performing the init_routine will see it (there are
82
 
   * no other cancelation points here). The result will be that every thread
83
 
   * eventually cancels only when it becomes the new initter.
84
 
   */
85
 
  pthread_cancel(pthread_self());
86
 
  assert(pthread_once(&once[(int) arg], myfunc) == 0);
87
 
  EnterCriticalSection(&numThreads.cs);
88
 
  numThreads.i++;
89
 
  LeaveCriticalSection(&numThreads.cs);
90
 
  return 0;
91
 
}
92
 
 
93
 
int
94
 
main()
95
 
{
96
 
  pthread_t t[NUM_THREADS][NUM_ONCE];
97
 
  int i, j;
98
 
  
99
 
  InitializeCriticalSection(&numThreads.cs);
100
 
  InitializeCriticalSection(&numOnce.cs);
101
 
 
102
 
  for (j = 0; j < NUM_ONCE; j++)
103
 
    {
104
 
      once[j] = o;
105
 
 
106
 
      for (i = 0; i < NUM_THREADS; i++)
107
 
        {
108
 
          assert(pthread_create(&t[i][j], NULL, mythread, (void *) j) == 0);
109
 
        }
110
 
    }
111
 
 
112
 
  for (j = 0; j < NUM_ONCE; j++)
113
 
    for (i = 0; i < NUM_THREADS; i++)
114
 
      if (pthread_join(t[i][j], NULL) != 0)
115
 
        printf("Join failed for [thread,once] = [%d,%d]\n", i, j);
116
 
 
117
 
  /*
118
 
   * All threads will cancel, none will return normally from
119
 
   * pthread_once and so numThreads should never be incremented. However,
120
 
   * numOnce should be incremented by every thread (NUM_THREADS*NUM_ONCE).
121
 
   */
122
 
  assert(numOnce.i == NUM_ONCE * NUM_THREADS);
123
 
  assert(numThreads.i == 0);
124
 
 
125
 
  DeleteCriticalSection(&numOnce.cs);
126
 
  DeleteCriticalSection(&numThreads.cs);
127
 
 
128
 
  return 0;
129
 
}