2012-04-15 20:06:27 -07:00
# ifndef _BPF_JIT_H
# define _BPF_JIT_H
/* Conventions:
* % g1 : temporary
* % g2 : Secondary temporary used by SKB data helper stubs .
2012-04-17 16:08:29 -04:00
* % g3 : packet offset passed into SKB data helper stubs .
2012-04-15 20:06:27 -07:00
* % o0 : pointer to skb ( first argument given to JIT function )
* % o1 : BPF A accumulator
* % o2 : BPF X accumulator
* % o3 : Holds saved % o7 so we can call helper functions without needing
* to allocate a register window .
2012-04-17 16:08:29 -04:00
* % o4 : skb - > len - skb - > data_len
* % o5 : skb - > data
2012-04-15 20:06:27 -07:00
*/
# ifndef __ASSEMBLER__
# define G0 0x00
# define G1 0x01
# define G3 0x03
# define G6 0x06
# define O0 0x08
# define O1 0x09
# define O2 0x0a
# define O3 0x0b
# define O4 0x0c
# define O5 0x0d
# define SP 0x0e
# define O7 0x0f
# define FP 0x1e
# define r_SKB O0
# define r_A O1
# define r_X O2
# define r_saved_O7 O3
# define r_HEADLEN O4
# define r_SKB_DATA O5
# define r_TMP G1
# define r_TMP2 G2
# define r_OFF G3
2012-04-17 16:38:16 -04:00
2017-04-17 18:44:36 -07:00
/* assembly code in arch/sparc/net/bpf_jit_asm_32.S */
2012-04-17 16:38:16 -04:00
extern u32 bpf_jit_load_word [ ] ;
extern u32 bpf_jit_load_half [ ] ;
extern u32 bpf_jit_load_byte [ ] ;
extern u32 bpf_jit_load_byte_msh [ ] ;
extern u32 bpf_jit_load_word_positive_offset [ ] ;
extern u32 bpf_jit_load_half_positive_offset [ ] ;
extern u32 bpf_jit_load_byte_positive_offset [ ] ;
extern u32 bpf_jit_load_byte_msh_positive_offset [ ] ;
extern u32 bpf_jit_load_word_negative_offset [ ] ;
extern u32 bpf_jit_load_half_negative_offset [ ] ;
extern u32 bpf_jit_load_byte_negative_offset [ ] ;
extern u32 bpf_jit_load_byte_msh_negative_offset [ ] ;
2012-04-15 20:06:27 -07:00
# else
# define r_SKB %o0
# define r_A %o1
# define r_X %o2
# define r_saved_O7 %o3
# define r_HEADLEN %o4
# define r_SKB_DATA %o5
# define r_TMP %g1
# define r_TMP2 %g2
# define r_OFF %g3
# endif
# endif /* _BPF_JIT_H */