Hello! David Goldblatt (CCed) came up with an interesting pair of C++ litmus tests involving POSIX signals that have Linux-kernel counterparts involving interrupts. These litmus tests can (in paranoid theory, anyway) produce counter-intuitive results on architectures that use explicit fences to enforce ordering as part of a larger primitive, which in the specific case of smp_store_release() includes all architectures other than arm64, ia64, s390, SPARC, x86, and of course any UP-only architecture. David's first litmus test made use of the C11 sequentially consistent store, which in the Linux kernel would require two separate statements anyway (a WRITE_ONCE() either preceded or followed by smp_mb()), so the outcome that is counter-intuitive in C11 should be expected in the Linux kernel. (Yes, there are similar but more complicated examples that would have more interesting outcomes in the Linux kernel, but let's keep it simple for the moment.) The second (informal) litmus test has a more interesting Linux-kernel counterpart: void t1_interrupt(void) { r0 = READ_ONCE(y); smp_store_release(&x, 1); } void t1(void) { smp_store_release(&y, 1); } void t2(void) { r1 = smp_load_acquire(&x); r2 = smp_load_acquire(&y); } On store-reordering architectures that implement smp_store_release() as a memory-barrier instruction followed by a store, the interrupt could arrive betweentimes in t1(), so that there would be no ordering between t1_interrupt()'s store to x and t1()'s store to y. This could (again, in paranoid theory) result in the outcome r0==0 && r1==0 && r2==1. In practice, we analyzed exception paths in the sys_membarrier() review, and ended up with this function: static void ipi_mb(void *info) { smp_mb(); /* IPIs should be serializing but paranoid. */ } So how paranoid should we be with respect to interrupt handlers for smp_store_release(), smp_load_acquire(), and the various RMW atomic operations that are sometimes implemented with separate memory-barrier instructions? ;-) Thanx, Paul