From 933f70cf5d16cc3b6c4ea248ff5f91e03d66b418 Mon Sep 17 00:00:00 2001
From: Mark Spencer <markster@digium.com>
Date: Wed, 13 Aug 2003 22:12:54 +0000
Subject: [PATCH] Add crash option

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@1317 65c4cc65-6c06-0410-ace0-fbb531ad65f3
---
 include/asterisk/lock.h | 13 +++++++++++--
 1 file changed, 11 insertions(+), 2 deletions(-)

diff --git a/include/asterisk/lock.h b/include/asterisk/lock.h
index 092672cae8..9459042fcd 100755
--- a/include/asterisk/lock.h
+++ b/include/asterisk/lock.h
@@ -17,8 +17,10 @@
 #include <pthread.h>
 
 #ifdef DEBUG_THREADS
+#ifdef THREAD_CRASH
+#define DO_THREAD_CRASH do { *((int *)(0)) = 1; } while(0)
+#endif
 
-#define TRIES 50
 
 #include <errno.h>
 #include <string.h>
@@ -93,6 +95,9 @@ static inline int __ast_pthread_mutex_lock(char *filename, int lineno, char *fun
 	} else {
 		fprintf(stderr, "%s line %d (%s): Error obtaining mutex: %s\n",
 			filename, lineno, func, strerror(errno));
+#ifdef THREAD_CRASH
+		DO_THREAD_CRASH;
+#endif
 	}
 	return res;
 }
@@ -121,9 +126,13 @@ static inline int __ast_pthread_mutex_unlock(char *filename, int lineno, char *f
 	t->func = NULL;
 	t->thread = 0;
 	res = pthread_mutex_unlock(&t->mutex);
-	if (res) 
+	if (res) {
 		fprintf(stderr, "%s line %d (%s): Error releasing mutex: %s\n", 
 				filename, lineno, func, strerror(res));
+#ifdef THREAD_CRASH
+		DO_THREAD_CRASH;
+#endif
+	}
 	return res;
 }
 
-- 
GitLab