1360301a6SAlexei Starovoitov // SPDX-License-Identifier: GPL-2.0-only
2360301a6SAlexei Starovoitov /* Copyright (c) 2020 Facebook */
3360301a6SAlexei Starovoitov #include <stddef.h>
4360301a6SAlexei Starovoitov #include <linux/bpf.h>
53e689141SToke Høiland-Jørgensen #include <bpf/bpf_helpers.h>
695ebb376SAndrii Nakryiko #include "bpf_misc.h"
7360301a6SAlexei Starovoitov 
8360301a6SAlexei Starovoitov #define MAX_STACK (512 - 3 * 32 + 8)
9360301a6SAlexei Starovoitov 
10360301a6SAlexei Starovoitov static __attribute__ ((noinline))
f0(int var,struct __sk_buff * skb)11360301a6SAlexei Starovoitov int f0(int var, struct __sk_buff *skb)
12360301a6SAlexei Starovoitov {
13*f1f5553dSYonghong Song 	asm volatile ("");
14*f1f5553dSYonghong Song 
15360301a6SAlexei Starovoitov 	return skb->len;
16360301a6SAlexei Starovoitov }
17360301a6SAlexei Starovoitov 
18360301a6SAlexei Starovoitov __attribute__ ((noinline))
f1(struct __sk_buff * skb)19360301a6SAlexei Starovoitov int f1(struct __sk_buff *skb)
20360301a6SAlexei Starovoitov {
21360301a6SAlexei Starovoitov 	volatile char buf[MAX_STACK] = {};
22360301a6SAlexei Starovoitov 
23c8ed6685SAndrii Nakryiko 	__sink(buf[MAX_STACK - 1]);
24c8ed6685SAndrii Nakryiko 
25360301a6SAlexei Starovoitov 	return f0(0, skb) + skb->len;
26360301a6SAlexei Starovoitov }
27360301a6SAlexei Starovoitov 
28360301a6SAlexei Starovoitov int f3(int, struct __sk_buff *skb, int);
29360301a6SAlexei Starovoitov 
30360301a6SAlexei Starovoitov __attribute__ ((noinline))
f2(int val,struct __sk_buff * skb)31360301a6SAlexei Starovoitov int f2(int val, struct __sk_buff *skb)
32360301a6SAlexei Starovoitov {
33360301a6SAlexei Starovoitov 	return f1(skb) + f3(val, skb, 1);
34360301a6SAlexei Starovoitov }
35360301a6SAlexei Starovoitov 
36360301a6SAlexei Starovoitov __attribute__ ((noinline))
f3(int val,struct __sk_buff * skb,int var)37360301a6SAlexei Starovoitov int f3(int val, struct __sk_buff *skb, int var)
38360301a6SAlexei Starovoitov {
39360301a6SAlexei Starovoitov 	volatile char buf[MAX_STACK] = {};
40360301a6SAlexei Starovoitov 
41c8ed6685SAndrii Nakryiko 	__sink(buf[MAX_STACK - 1]);
42c8ed6685SAndrii Nakryiko 
43360301a6SAlexei Starovoitov 	return skb->ifindex * val * var;
44360301a6SAlexei Starovoitov }
45360301a6SAlexei Starovoitov 
46c22bdd28SAndrii Nakryiko SEC("tc")
4795ebb376SAndrii Nakryiko __failure __msg("combined stack size of 4 calls is 544")
global_func1(struct __sk_buff * skb)4895ebb376SAndrii Nakryiko int global_func1(struct __sk_buff *skb)
49360301a6SAlexei Starovoitov {
50360301a6SAlexei Starovoitov 	return f0(1, skb) + f1(skb) + f2(2, skb) + f3(3, skb, 4);
51360301a6SAlexei Starovoitov }
52