1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */ 205462310SMichael Holzheu /* 305462310SMichael Holzheu * BPF Jit compiler defines 405462310SMichael Holzheu * 505462310SMichael Holzheu * Copyright IBM Corp. 2012,2015 605462310SMichael Holzheu * 705462310SMichael Holzheu * Author(s): Martin Schwidefsky <schwidefsky@de.ibm.com> 805462310SMichael Holzheu * Michael Holzheu <holzheu@linux.vnet.ibm.com> 905462310SMichael Holzheu */ 1005462310SMichael Holzheu 1105462310SMichael Holzheu #ifndef __ARCH_S390_NET_BPF_JIT_H 1205462310SMichael Holzheu #define __ARCH_S390_NET_BPF_JIT_H 1305462310SMichael Holzheu 1405462310SMichael Holzheu #ifndef __ASSEMBLY__ 1505462310SMichael Holzheu 1605462310SMichael Holzheu #include <linux/filter.h> 1705462310SMichael Holzheu #include <linux/types.h> 1805462310SMichael Holzheu 1905462310SMichael Holzheu extern u8 sk_load_word_pos[], sk_load_half_pos[], sk_load_byte_pos[]; 2005462310SMichael Holzheu extern u8 sk_load_word[], sk_load_half[], sk_load_byte[]; 2105462310SMichael Holzheu 2205462310SMichael Holzheu #endif /* __ASSEMBLY__ */ 2305462310SMichael Holzheu 2405462310SMichael Holzheu /* 2505462310SMichael Holzheu * Stackframe layout (packed stack): 2605462310SMichael Holzheu * 2705462310SMichael Holzheu * ^ high 2805462310SMichael Holzheu * +---------------+ | 2905462310SMichael Holzheu * | old backchain | | 3005462310SMichael Holzheu * +---------------+ | 3105462310SMichael Holzheu * | r15 - r6 | | 326651ee07SMichael Holzheu * +---------------+ | 336651ee07SMichael Holzheu * | 4 byte align | | 346651ee07SMichael Holzheu * | tail_call_cnt | | 3505462310SMichael Holzheu * BFP -> +===============+ | 3605462310SMichael Holzheu * | | | 3705462310SMichael Holzheu * | BPF stack | | 3805462310SMichael Holzheu * | | | 3905462310SMichael Holzheu * +---------------+ | 409db7f2b8SMichael Holzheu * | 8 byte skbp | | 416edf0aa4SMichael Holzheu * R15+176 -> +---------------+ | 4205462310SMichael Holzheu * | 8 byte hlen | | 4305462310SMichael Holzheu * R15+168 -> +---------------+ | 4405462310SMichael Holzheu * | 4 byte align | | 4505462310SMichael Holzheu * +---------------+ | 4605462310SMichael Holzheu * | 4 byte temp | | 4705462310SMichael Holzheu * | for bpf_jit.S | | 4805462310SMichael Holzheu * R15+160 -> +---------------+ | 4905462310SMichael Holzheu * | new backchain | | 5005462310SMichael Holzheu * R15+152 -> +---------------+ | 5105462310SMichael Holzheu * | + 152 byte SA | | 5205462310SMichael Holzheu * R15 -> +---------------+ + low 5305462310SMichael Holzheu * 5405462310SMichael Holzheu * We get 160 bytes stack space from calling function, but only use 556651ee07SMichael Holzheu * 12 * 8 byte for old backchain, r15..r6, and tail_call_cnt. 5605462310SMichael Holzheu */ 579db7f2b8SMichael Holzheu #define STK_SPACE (MAX_BPF_STACK + 8 + 8 + 4 + 4 + 160) 586651ee07SMichael Holzheu #define STK_160_UNUSED (160 - 12 * 8) 59bbac1c94SMichael Holzheu #define STK_OFF (STK_SPACE - STK_160_UNUSED) 6005462310SMichael Holzheu #define STK_OFF_TMP 160 /* Offset of tmp buffer on stack */ 6105462310SMichael Holzheu #define STK_OFF_HLEN 168 /* Offset of SKB header length on stack */ 626edf0aa4SMichael Holzheu #define STK_OFF_SKBP 176 /* Offset of SKB pointer on stack */ 6305462310SMichael Holzheu 646651ee07SMichael Holzheu #define STK_OFF_R6 (160 - 11 * 8) /* Offset of r6 on stack */ 656651ee07SMichael Holzheu #define STK_OFF_TCCNT (160 - 12 * 8) /* Offset of tail_call_cnt on stack */ 666651ee07SMichael Holzheu 6705462310SMichael Holzheu /* Offset to skip condition code check */ 6805462310SMichael Holzheu #define OFF_OK 4 6905462310SMichael Holzheu 7005462310SMichael Holzheu #endif /* __ARCH_S390_NET_BPF_JIT_H */ 71