Re: [RFC] LKMM: Add volatile_if()
From: Segher Boessenkool
Date: Mon Jun 07 2021 - 13:46:35 EST
On Sun, Jun 06, 2021 at 03:38:06PM -0700, Linus Torvalds wrote:
> In the case of "volatile_if()", we actually would like to have not a
> memory clobber, but a "memory read". IOW, it would be a barrier for
> any writes taking place, but reads can move around it.
>
> I don't know of any way to express that to the compiler. We've used
> hacks for it before (in gcc, BLKmode reads turn into that kind of
> barrier in practice, so you can do something like make the memory
> input to the asm be a big array). But that turned out to be fairly
> unreliable, so now we use memory clobbers even if we just mean "reads
> random memory".
>
> Example: variable_test_bit(), which generates a "bt" instruction, does
>
> : "m" (*(unsigned long *)addr), "Ir" (nr) : "memory");
>
> and the memory clobber is obviously wrong: 'bt' only *reads* memory,
> but since the whole reason we use it is that it's not just that word
> at address 'addr', in order to make sure that any previous writes are
> actually stable in memory, we use that "memory" clobber.
You can split the "I" version from the "r" version, it does not need
the memory clobber. If you know the actual maximum bit offset used you
don't need the clobber for "r" either. Or you could even write
"m"(((unsigned long *)addr)[nr/32])
That should work for all cases.
> Anybody have ideas or suggestions for something like that?
Is it useful in general for the kernel to have separate "read" and
"write" clobbers in asm expressions? And for other applications?
Segher