From mboxrd@z Thu Jan 1 00:00:00 1970 From: Daniel Borkmann Subject: Re: [PATCH RFC v4 net-next 01/26] net: filter: add "load 64-bit immediate" eBPF instruction Date: Wed, 13 Aug 2014 11:17:37 +0200 Message-ID: <53EB2D31.8090204@redhat.com> References: <1407916658-8731-1-git-send-email-ast@plumgrid.com> <1407916658-8731-2-git-send-email-ast@plumgrid.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: "David S. Miller" , Ingo Molnar , Linus Torvalds , Andy Lutomirski , Steven Rostedt , Chema Gonzalez , Eric Dumazet , Peter Zijlstra , "H. Peter Anvin" , Andrew Morton , Kees Cook , linux-api-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, netdev-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: Alexei Starovoitov Return-path: In-Reply-To: <1407916658-8731-2-git-send-email-ast-uqk4Ao+rVK5Wk0Htik3J/w@public.gmane.org> Sender: linux-api-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org List-Id: netdev.vger.kernel.org On 08/13/2014 09:57 AM, Alexei Starovoitov wrote: > add BPF_LD_IMM64 instruction to load 64-bit immediate value into register. > All previous instructions were 8-byte. This is first 16-byte instruction. > Two consecutive 'struct bpf_insn' blocks are interpreted as single instruction: > insn[0/1].code = BPF_LD | BPF_DW | BPF_IMM > insn[0/1].dst_reg = destination register > insn[0].imm = lower 32-bit > insn[1].imm = upper 32-bit > > Classic BPF has similar instruction: BPF_LD | BPF_W | BPF_IMM > which loads 32-bit immediate value into a register. > > x64 JITs it as single 'movabsq %rax, imm64' > arm64 may JIT as sequence of four 'movk x0, #imm16, lsl #shift' insn > > Note that old eBPF programs are binary compatible with new interpreter. > > Signed-off-by: Alexei Starovoitov For follow-ups on this series, can you put the actual motivation for this change from the cover letter into this commit log as it otherwise doesn't say anything clearly why it is needed. Code and test case looks good to me.