summaryrefslogtreecommitdiff
path: root/tests/mutex6n.c
diff options
context:
space:
mode:
authorrpj <rpj>2001-05-31 02:05:25 +0000
committerrpj <rpj>2001-05-31 02:05:25 +0000
commita8744086b476e4007c1d8fc0fae84ecfcade99ba (patch)
tree69bd3bd925233e00d960f3de5a5f3953db235da7 /tests/mutex6n.c
parente121b938c9f012958196a3141f04a3fd4f58bdb9 (diff)
New test.
Diffstat (limited to 'tests/mutex6n.c')
-rw-r--r--tests/mutex6n.c61
1 files changed, 61 insertions, 0 deletions
diff --git a/tests/mutex6n.c b/tests/mutex6n.c
new file mode 100644
index 0000000..19e917c
--- /dev/null
+++ b/tests/mutex6n.c
@@ -0,0 +1,61 @@
+/*
+ * mutex6n.c
+ *
+ * Tests PTHREAD_MUTEX_NORMAL mutex type.
+ * Thread locks mutex twice (recursive lock).
+ * The thread should deadlock.
+ *
+ * Depends on API functions:
+ * pthread_create()
+ * pthread_mutexattr_init()
+ * pthread_mutexattr_settype()
+ * pthread_mutexattr_gettype()
+ * pthread_mutex_init()
+ * pthread_mutex_lock()
+ * pthread_mutex_unlock()
+ */
+
+#include "test.h"
+
+static int lockCount = 0;
+
+static pthread_mutex_t mutex;
+static pthread_mutexattr_t mxAttr;
+
+void * locker(void * arg)
+{
+ assert(pthread_mutex_lock(&mutex) == 0);
+ lockCount++;
+ assert(pthread_mutex_lock(&mutex) != 0);
+ lockCount++;
+ assert(pthread_mutex_unlock(&mutex) == 0);
+ assert(pthread_mutex_unlock(&mutex) == 0);
+
+ return (void *) 555;
+}
+
+int
+main()
+{
+ pthread_t t;
+ int mxType = -1;
+
+ assert(pthread_mutexattr_init(&mxAttr) == 0);
+ assert(pthread_mutexattr_settype(&mxAttr, PTHREAD_MUTEX_NORMAL) == 0);
+ assert(pthread_mutexattr_gettype(&mxAttr, &mxType) == 0);
+ assert(mxType == PTHREAD_MUTEX_NORMAL);
+
+ assert(pthread_mutex_init(&mutex, &mxAttr) == 0);
+
+ assert(pthread_create(&t, NULL, locker, NULL) == 0);
+
+ Sleep(1000);
+
+ assert(lockCount == 1);
+
+ exit(0);
+
+ /* Never reached */
+ return 0;
+}
+