• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * mutex6.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  * Test the default (type not set) mutex type.
37  * Should be the same as PTHREAD_MUTEX_NORMAL.
38  * Thread locks mutex twice (recursive lock).
39  * Locking thread should deadlock on second attempt.
40  *
41  * Depends on API functions:
42  *	pthread_mutex_lock()
43  *	pthread_mutex_trylock()
44  *	pthread_mutex_unlock()
45  */
46 
47 #include "test.h"
48 
49 static volatile int lockCount = 0;
50 
51 static pthread_mutex_t mutex;
52 
locker(void * arg)53 void * locker(void * arg)
54 {
55   assert(pthread_mutex_lock(&mutex) == 0);
56   InterlockedIncrement((long *)&lockCount);
57 
58   /* Should wait here (deadlocked) */
59   assert(pthread_mutex_lock(&mutex) == 0);
60   InterlockedIncrement((long *)&lockCount);
61   assert(pthread_mutex_unlock(&mutex) == 0);
62 
63   return 0;
64 }
65 
66 int
main()67 main()
68 {
69   pthread_t t;
70 
71   assert(pthread_mutex_init(&mutex, NULL) == 0);
72 
73   assert(pthread_create(&t, NULL, locker, NULL) == 0);
74 
75   Sleep(1000);
76 
77   printf("lockCount = %d\n", lockCount);
78   assert(lockCount == 1);
79 
80   /*
81    * Should succeed even though we don't own the lock
82    * because FAST mutexes don't check ownership.
83    */
84   assert(pthread_mutex_unlock(&mutex) == 0);
85 
86   Sleep (1000);
87 
88   assert(lockCount == 2);
89 
90   exit(0);
91 
92   /* Never reached */
93   return 0;
94 }
95