Re: [GIT PULL] x86/asm updates for v5.10
From: Linus Torvalds
Date: Mon Oct 12 2020 - 15:07:28 EST
On Mon, Oct 12, 2020 at 11:56 AM Linus Torvalds
<torvalds@xxxxxxxxxxxxxxxxxxxx> wrote:
>
> I also find that clang generates code that uses the high byte
> registers, although again, that's not from any knowledge of clang
> internals, and just by looking at my kernel image disassembly.
>
> So yes, it _may_ all be just peepholes, but it's not obvious that this
> is all safe.
The clang use I find seems to be _purely_ for variations of "mov", and
only ever with the high register as a source.
So yes, that one looks very much like a peephole optimization where
clang just recognizes patterns line
X = (y >> 8) & 0xff;
and uses a "movzbl %*h,xyz" for it.
Gcc actually seems to use high registers more, but the extended use
seems to be bit test (and set) operations that also may be simply
peepholes.
So yes, from code generation patterns it does look likely that neither
compiler actually considers the high registers to be truely
independent entities, and thus quite likely that you'd never find
concurrent mixed use.
But that really seems to be an implementation issue rather than
something we should necessarily rely on, unless we have a stronger
statement from both compiler camps..
Linus