On Mon, Mar 4, 2019 at 2:24 AM Michael Ellerman <mpe@xxxxxxxxxxxxxx> wrote: > > Without wading into the rest of the discussion, this does raise an > interesting point, ie. what about eg. rwlock's? > > They're basically equivalent to spinlocks, and so could reasonably be > expected to have the same behaviour. > > But we don't check the io_sync flag in arch_read/write_unlock() etc. and > both of those use lwsync. I think technically rwlocks should do the same thing, at least when they are used for exclusion. Because of the exclusion argument, we can presubably limit it to just write_unlock(), although at least in theory I guess you could have some "one reader does IO, then a writer comes in" situation.. Perhaps more importantly, what about sleeping locks? When they actually *block*, they get the barrier thanks to the scheduler, but you can have a nice non-contended sequence that never does that. I guess the fact that these cases have never even shown up as an issue means that we could just continue to ignore it. We could even give that approach some fancy name, and claim it as a revolutionary new programming paradigm ("ostrich programming" to go with "agile" and "pair programming"). Linus