[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20210929214703.GG22689@gate.crashing.org>
Date: Wed, 29 Sep 2021 16:47:03 -0500
From: Segher Boessenkool <segher@...nel.crashing.org>
To: Mathieu Desnoyers <mathieu.desnoyers@...icios.com>
Cc: will@...nel.org, paulmck@...nel.org,
Peter Zijlstra <peterz@...radead.org>,
linux-kernel@...r.kernel.org,
Linus Torvalds <torvalds@...ux-foundation.org>,
stern@...land.harvard.edu, parri.andrea@...il.com,
boqun.feng@...il.com, npiggin@...il.com, dhowells@...hat.com,
j.alglave@....ac.uk, luc.maranget@...ia.fr, akiyks@...il.com,
linux-toolchains@...r.kernel.org, linux-arch@...r.kernel.org
Subject: Re: [RFC PATCH] LKMM: Add ctrl_dep() macro for control dependency
Hi!
On Tue, Sep 28, 2021 at 05:15:07PM -0400, Mathieu Desnoyers wrote:
> C99 describes that accessing volatile objects are side-effects, and that
> "at certain specified points in the execution sequence called sequence
> points, all side effects of previous evaluations shall be complete
> and no side effects of subsequent evaluations shall have taken
> place". [2]
But note that the kernel explicitly uses C89 (with GNU extensions).
Side effects are largely equal there though.
Also note that there may no place in the generated machine code that
corresponds exactly to some sequence point. Sequence points are a
concept that applies to the source program and how that executes on the
abstract machine.
> +Because ctrl_dep emits distinct asm volatile within each leg of the if
> +statement, the compiler cannot transform the two writes to 'b' into a
> +conditional-move (cmov) instruction, thus ensuring the presence of a
> +conditional branch. Also because the ctrl_dep emits asm volatile within
> +each leg of the if statement, the compiler cannot move the write to 'c'
> +before the conditional branch.
I think your reasoning here misses some things. So many that I don't
know where to start to list them, every "because" and "thus" here does
not follow, and even the statements of fact are not a given.
Why do you want a conditional branch insn at all, anyway? You really
want something else as far as I can see.
It is essential here that there is a READ_ONCE and the WRITE_ONCE.
Those things might make it work the way you want, but as Linus says this
is all way too subtle. Can you include the *_ONCE into the primitive
itself somehow?
Segher
Powered by blists - more mailing lists