cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

bpf_jit_32.h (1741B)


      1/* SPDX-License-Identifier: GPL-2.0 */
      2#ifndef _BPF_JIT_H
      3#define _BPF_JIT_H
      4
      5/* Conventions:
      6 *  %g1 : temporary
      7 *  %g2 : Secondary temporary used by SKB data helper stubs.
      8 *  %g3 : packet offset passed into SKB data helper stubs.
      9 *  %o0 : pointer to skb (first argument given to JIT function)
     10 *  %o1 : BPF A accumulator
     11 *  %o2 : BPF X accumulator
     12 *  %o3 : Holds saved %o7 so we can call helper functions without needing
     13 *        to allocate a register window.
     14 *  %o4 : skb->len - skb->data_len
     15 *  %o5 : skb->data
     16 */
     17
     18#ifndef __ASSEMBLER__
     19#define G0		0x00
     20#define G1		0x01
     21#define G3		0x03
     22#define G6		0x06
     23#define O0		0x08
     24#define O1		0x09
     25#define O2		0x0a
     26#define O3		0x0b
     27#define O4		0x0c
     28#define O5		0x0d
     29#define SP		0x0e
     30#define O7		0x0f
     31#define FP		0x1e
     32
     33#define r_SKB		O0
     34#define r_A		O1
     35#define r_X		O2
     36#define r_saved_O7	O3
     37#define r_HEADLEN	O4
     38#define r_SKB_DATA	O5
     39#define r_TMP		G1
     40#define r_TMP2		G2
     41#define r_OFF		G3
     42
     43/* assembly code in arch/sparc/net/bpf_jit_asm_32.S */
     44extern u32 bpf_jit_load_word[];
     45extern u32 bpf_jit_load_half[];
     46extern u32 bpf_jit_load_byte[];
     47extern u32 bpf_jit_load_byte_msh[];
     48extern u32 bpf_jit_load_word_positive_offset[];
     49extern u32 bpf_jit_load_half_positive_offset[];
     50extern u32 bpf_jit_load_byte_positive_offset[];
     51extern u32 bpf_jit_load_byte_msh_positive_offset[];
     52extern u32 bpf_jit_load_word_negative_offset[];
     53extern u32 bpf_jit_load_half_negative_offset[];
     54extern u32 bpf_jit_load_byte_negative_offset[];
     55extern u32 bpf_jit_load_byte_msh_negative_offset[];
     56
     57#else
     58#define r_SKB		%o0
     59#define r_A		%o1
     60#define r_X		%o2
     61#define r_saved_O7	%o3
     62#define r_HEADLEN	%o4
     63#define r_SKB_DATA	%o5
     64#define r_TMP		%g1
     65#define r_TMP2		%g2
     66#define r_OFF		%g3
     67#endif
     68
     69#endif /* _BPF_JIT_H */