diff options
author | Rich Felker <dalias@aerifal.cx> | 2014-08-17 00:46:26 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2014-08-17 00:46:26 -0400 |
commit | de7e99c58508ca70f0b1b8ef259a823a3766c434 (patch) | |
tree | 68fbc616cb85a0a5a2992f64080d19b25855088f /src/internal | |
parent | d338b506e39b1e2c68366b12be90704c635602ce (diff) | |
download | musl-de7e99c58508ca70f0b1b8ef259a823a3766c434.tar.gz musl-de7e99c58508ca70f0b1b8ef259a823a3766c434.tar.bz2 musl-de7e99c58508ca70f0b1b8ef259a823a3766c434.tar.xz musl-de7e99c58508ca70f0b1b8ef259a823a3766c434.zip |
make pointers used in robust list volatile
when manipulating the robust list, the order of stores matters,
because the code may be asynchronously interrupted by a fatal signal
and the kernel will then access the robust list in what is essentially
an async-signal context.
previously, aliasing considerations made it seem unlikely that a
compiler could reorder the stores, but proving that they could not be
reordered incorrectly would have been extremely difficult. instead
I've opted to make all the pointers used as part of the robust list,
including those in the robust list head and in the individual mutexes,
volatile.
in addition, the format of the robust list has been changed to point
back to the head at the end, rather than ending with a null pointer.
this is to match the documented kernel robust list ABI. the null
pointer, which was previously used, only worked because faults during
access terminate the robust list processing.
Diffstat (limited to 'src/internal')
-rw-r--r-- | src/internal/pthread_impl.h | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/internal/pthread_impl.h b/src/internal/pthread_impl.h index 826191c2..848ff668 100644 --- a/src/internal/pthread_impl.h +++ b/src/internal/pthread_impl.h @@ -33,9 +33,9 @@ struct pthread { pthread_attr_t attr; volatile int dead; struct { - void **head; + volatile void *volatile head; long off; - void *pending; + volatile void *volatile pending; } robust_list; int unblock_cancel; int timer_id; |