psss / rpms / ksh

Forked from rpms/ksh 6 years ago
Clone
ebf9b31
diff -up ksh-20120801/src/cmd/ksh93/include/jobs.h.locking ksh-20120801/src/cmd/ksh93/include/jobs.h
ebf9b31
--- ksh-20120801/src/cmd/ksh93/include/jobs.h.locking	2014-06-27 15:51:07.144923719 +0200
ebf9b31
+++ ksh-20120801/src/cmd/ksh93/include/jobs.h	2014-06-27 15:52:56.463272276 +0200
ebf9b31
@@ -149,15 +149,18 @@ extern struct jobs job;
ebf9b31
 #define vmbusy()	0
ebf9b31
 #endif
ebf9b31
 
ebf9b31
-#define job_lock()	(job.in_critical++)
ebf9b31
+#define asoincint(p)  __sync_fetch_and_add(p,1)
ebf9b31
+#define asodecint(p)  __sync_fetch_and_sub(p,1)
ebf9b31
+
ebf9b31
+#define job_lock()	asoincint(&job.in_critical)
ebf9b31
 #define job_unlock()	\
ebf9b31
 	do { \
ebf9b31
 		int	sig; \
ebf9b31
-		if (!--job.in_critical && (sig = job.savesig)) \
ebf9b31
+		if (asodecint(&job.in_critical)==1 && (sig = job.savesig)) \
ebf9b31
 		{ \
ebf9b31
-			if (!job.in_critical++ && !vmbusy()) \
ebf9b31
+			if (!asoincint(&job.in_critical) && !vmbusy()) \
ebf9b31
 				job_reap(sig); \
ebf9b31
-			job.in_critical--; \
ebf9b31
+			asodecint(&job.in_critical); \
ebf9b31
 		} \
ebf9b31
 	} while(0)
ebf9b31