Browse Source

condition variable signal/bcast need not wake unless there are waiters

Rich Felker 13 years ago
parent
commit
1407785824
2 changed files with 4 additions and 4 deletions
  1. 2 2
      src/thread/pthread_cond_broadcast.c
  2. 2 2
      src/thread/pthread_cond_signal.c

+ 2 - 2
src/thread/pthread_cond_broadcast.c

@@ -2,7 +2,7 @@
 
 int pthread_cond_broadcast(pthread_cond_t *c)
 {
-	c->_c_block = 0;
-	__wake(&c->_c_block, -1, 0);
+	if (a_swap(&c->_c_block, 0))
+		__wake(&c->_c_block, -1, 0);
 	return 0;
 }

+ 2 - 2
src/thread/pthread_cond_signal.c

@@ -2,7 +2,7 @@
 
 int pthread_cond_signal(pthread_cond_t *c)
 {
-	c->_c_block = 0;
-	__wake(&c->_c_block, 1, 0);
+	if (a_swap(&c->_c_block, 0));
+		__wake(&c->_c_block, 1, 0);
 	return 0;
 }