]> granicus.if.org Git - musl/commit
retry on cas failures in sem_trywait
authorRich Felker <dalias@aerifal.cx>
Tue, 24 Jul 2012 04:51:36 +0000 (00:51 -0400)
committerRich Felker <dalias@aerifal.cx>
Tue, 24 Jul 2012 04:51:36 +0000 (00:51 -0400)
commit07e62953c768f9f09485388c22ffaed98d11d676
tree5590ab7130d72e33cd5ef3be1659ea18367121e8
parent5d26d5d15bf6c2fc8c0e58b76fb418b51e207af7
retry on cas failures in sem_trywait

this seems counter-intuitive since sem_trywait is supposed to just try
once, not wait for the semaphore. however, the retry loop is not a
wait. instead, it's to handle the case where the value changes due to
a simultaneous post or wait from another thread while the semaphore
value remains positive. in such a case, it's absolutely wrong for
sem_trywait to fail with EAGAIN because the semaphore is not busy.
src/thread/sem_trywait.c