Re: [PATCH] x86/asm/entry/32: simplify pushes of zeroed pt_regs->REGs

From: Ingo Molnar
Date: Sat Mar 12 2016 - 10:45:22 EST



* Denys Vlasenko <dvlasenk@xxxxxxxxxx> wrote:

> Use of a temporary R8 register here seems to be unnecessary.
>
> "push %r8" is a two-byte insn (it needs REX prefix to specify R8),
> "push $0" is two-byte too. It seems just using the latter would be
> no worse.
>
> Thus, code had an unnecessary "xorq %r8,%r8" insn.
> It probably costs nothing in execution time here since we are probably
> limited by store bandwidth at this point, but still.

Note that the 3 fewer instruction in the image also shrink the code by 16 bytes:

arch/x86/entry/entry_64_compat.o:

text data bss dec hex filename
380 0 0 380 17c entry_64_compat.o.before
364 0 0 364 16c entry_64_compat.o.after

because (at least in this defconfig build) one of these functions shrunk below a
16-byte boundary. So cache footprint got denser.

Thanks,

Ingo