Michael Holzheu | 0546231 | 2015-04-01 16:08:32 +0200 | [diff] [blame] | 1 | /* |
| 2 | * BPF Jit compiler defines |
| 3 | * |
| 4 | * Copyright IBM Corp. 2012,2015 |
| 5 | * |
| 6 | * Author(s): Martin Schwidefsky <schwidefsky@de.ibm.com> |
| 7 | * Michael Holzheu <holzheu@linux.vnet.ibm.com> |
| 8 | */ |
| 9 | |
| 10 | #ifndef __ARCH_S390_NET_BPF_JIT_H |
| 11 | #define __ARCH_S390_NET_BPF_JIT_H |
| 12 | |
| 13 | #ifndef __ASSEMBLY__ |
| 14 | |
| 15 | #include <linux/filter.h> |
| 16 | #include <linux/types.h> |
| 17 | |
| 18 | extern u8 sk_load_word_pos[], sk_load_half_pos[], sk_load_byte_pos[]; |
| 19 | extern u8 sk_load_word[], sk_load_half[], sk_load_byte[]; |
| 20 | |
| 21 | #endif /* __ASSEMBLY__ */ |
| 22 | |
| 23 | /* |
| 24 | * Stackframe layout (packed stack): |
| 25 | * |
| 26 | * ^ high |
| 27 | * +---------------+ | |
| 28 | * | old backchain | | |
| 29 | * +---------------+ | |
| 30 | * | r15 - r6 | | |
Michael Holzheu | 6651ee0 | 2015-06-08 21:51:06 -0700 | [diff] [blame^] | 31 | * +---------------+ | |
| 32 | * | 4 byte align | | |
| 33 | * | tail_call_cnt | | |
Michael Holzheu | 0546231 | 2015-04-01 16:08:32 +0200 | [diff] [blame] | 34 | * BFP -> +===============+ | |
| 35 | * | | | |
| 36 | * | BPF stack | | |
| 37 | * | | | |
| 38 | * +---------------+ | |
| 39 | * | 8 byte hlen | | |
| 40 | * R15+168 -> +---------------+ | |
| 41 | * | 4 byte align | | |
| 42 | * +---------------+ | |
| 43 | * | 4 byte temp | | |
| 44 | * | for bpf_jit.S | | |
| 45 | * R15+160 -> +---------------+ | |
| 46 | * | new backchain | | |
| 47 | * R15+152 -> +---------------+ | |
| 48 | * | + 152 byte SA | | |
| 49 | * R15 -> +---------------+ + low |
| 50 | * |
| 51 | * We get 160 bytes stack space from calling function, but only use |
Michael Holzheu | 6651ee0 | 2015-06-08 21:51:06 -0700 | [diff] [blame^] | 52 | * 12 * 8 byte for old backchain, r15..r6, and tail_call_cnt. |
Michael Holzheu | 0546231 | 2015-04-01 16:08:32 +0200 | [diff] [blame] | 53 | */ |
Michael Holzheu | bbac1c9 | 2015-06-01 22:48:34 -0700 | [diff] [blame] | 54 | #define STK_SPACE (MAX_BPF_STACK + 8 + 4 + 4 + 160) |
Michael Holzheu | 6651ee0 | 2015-06-08 21:51:06 -0700 | [diff] [blame^] | 55 | #define STK_160_UNUSED (160 - 12 * 8) |
Michael Holzheu | bbac1c9 | 2015-06-01 22:48:34 -0700 | [diff] [blame] | 56 | #define STK_OFF (STK_SPACE - STK_160_UNUSED) |
Michael Holzheu | 0546231 | 2015-04-01 16:08:32 +0200 | [diff] [blame] | 57 | #define STK_OFF_TMP 160 /* Offset of tmp buffer on stack */ |
| 58 | #define STK_OFF_HLEN 168 /* Offset of SKB header length on stack */ |
| 59 | |
Michael Holzheu | 6651ee0 | 2015-06-08 21:51:06 -0700 | [diff] [blame^] | 60 | #define STK_OFF_R6 (160 - 11 * 8) /* Offset of r6 on stack */ |
| 61 | #define STK_OFF_TCCNT (160 - 12 * 8) /* Offset of tail_call_cnt on stack */ |
| 62 | |
Michael Holzheu | 0546231 | 2015-04-01 16:08:32 +0200 | [diff] [blame] | 63 | /* Offset to skip condition code check */ |
| 64 | #define OFF_OK 4 |
| 65 | |
| 66 | #endif /* __ARCH_S390_NET_BPF_JIT_H */ |