| #ifndef _BPF_JIT_H |
| #define _BPF_JIT_H |
| |
| /* Conventions: |
| * %g1 : temporary |
| * %g2 : Secondary temporary used by SKB data helper stubs. |
| * %g3 : packet offset passed into SKB data helper stubs. |
| * %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. |
| * %o4 : skb->len - skb->data_len |
| * %o5 : skb->data |
| */ |
| |
| #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 |
| |
| /* assembly code in arch/sparc/net/bpf_jit_asm.S */ |
| 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[]; |
| |
| #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 */ |