summaryrefslogtreecommitdiff
path: root/arch/powerpc/net/bpf_timed_may_goto.S
blob: 6fd8b1c9f4ac870fb6de1df9f9635af6c5e61215 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright (c) 2025 IBM Corporation, Saket Kumar Bhaskar <skb99@linux.ibm.com> */

#include <linux/linkage.h>
#include <asm/ppc_asm.h>

/*
 * arch_bpf_timed_may_goto() trampoline for powerpc64
 *
 * Custom BPF convention (verifier/JIT):
 *	- input:  stack offset in BPF_REG_AX (r12)
 *	- output: updated count in BPF_REG_AX (r12)
 *
 * Call bpf_check_timed_may_goto(ptr) with normal powerpc64 ABI:
 * 	- r3 = ptr, return in r3
 *
 * Preserve BPF regs R0-R5 (mapping: r8, r3-r7).
 */

SYM_FUNC_START(arch_bpf_timed_may_goto)
	/* Prologue: save LR, allocate frame */
	mflr    r0
	std     r0, 16(r1)
	stdu    r1, -112(r1)

	/* Save BPF registers R0 - R5 (r8, r3-r7) */
	std     r3, 32(r1)
	std     r4, 40(r1)
	std     r5, 48(r1)
	std     r6, 56(r1)
	std     r7, 64(r1)
	std     r8, 72(r1)

	/*
	 * r3 = BPF_REG_FP + BPF_REG_AX
	 * BPF_REG_FP is r31; BPF_REG_AX is r12 (stack offset in bytes).
	 */
	add     r3, r31, r12
	bl      bpf_check_timed_may_goto

	/* Put return value back into AX */
	mr      r12, r3

	/* Restore BPF registers R0 - R5 (r8, r3-r7) */
	ld      r3, 32(r1)
	ld      r4, 40(r1)
	ld      r5, 48(r1)
	ld      r6, 56(r1)
	ld      r7, 64(r1)
	ld      r8, 72(r1)

	/* Epilogue: pop frame, restore LR, return */
	addi    r1, r1, 112
	ld      r0, 16(r1)
	mtlr    r0
	blr
SYM_FUNC_END(arch_bpf_timed_may_goto)