diff options
author | Daniel Borkmann <daniel@iogearbox.net> | 2018-02-24 01:07:59 +0100 |
---|---|---|
committer | Alexei Starovoitov <ast@kernel.org> | 2018-02-24 07:50:00 +0100 |
commit | 6fe8b9c1f41dfe3209dabc5bd0726e003a065288 (patch) | |
tree | d252cdd2b889a6b785b499456edda2b0f2759fde /arch/x86/ras | |
parent | bpf, x64: save one byte per shl/shr/sar when imm is 1 (diff) | |
download | linux-6fe8b9c1f41dfe3209dabc5bd0726e003a065288.tar.xz linux-6fe8b9c1f41dfe3209dabc5bd0726e003a065288.zip |
bpf, x64: save several bytes by using mov over movabsq when possible
While analyzing some of the more complex BPF programs from Cilium,
I found that LLVM generally prefers to emit LD_IMM64 instead of MOV32
BPF instructions for loading unsigned 32-bit immediates into a
register. Given we cannot change the current/stable LLVM versions
that are already out there, lets optimize this case such that the
JIT prefers to emit 'mov %eax, imm32' over 'movabsq %rax, imm64'
whenever suitable in order to reduce the image size by 4-5 bytes per
such load in the typical case, reducing image size on some of the
bigger programs by up to 4%. emit_mov_imm32() and emit_mov_imm64()
have been added as helpers.
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Diffstat (limited to 'arch/x86/ras')
0 files changed, 0 insertions, 0 deletions