linux-zen-desktop/tools/testing/selftests/bpf/progs/test_global_func1.c

52 lines
984 B
C
Raw Normal View History

2023-08-30 16:31:07 +01:00
// SPDX-License-Identifier: GPL-2.0-only
/* Copyright (c) 2020 Facebook */
#include <stddef.h>
#include <linux/bpf.h>
#include <bpf/bpf_helpers.h>
#include "bpf_misc.h"
#define MAX_STACK (512 - 3 * 32 + 8)
static __attribute__ ((noinline))
int f0(int var, struct __sk_buff *skb)
{
2023-10-24 11:59:35 +01:00
asm volatile ("");
2023-08-30 16:31:07 +01:00
return skb->len;
}
__attribute__ ((noinline))
int f1(struct __sk_buff *skb)
{
volatile char buf[MAX_STACK] = {};
2023-10-24 11:59:35 +01:00
__sink(buf[MAX_STACK - 1]);
2023-08-30 16:31:07 +01:00
return f0(0, skb) + skb->len;
}
int f3(int, struct __sk_buff *skb, int);
__attribute__ ((noinline))
int f2(int val, struct __sk_buff *skb)
{
return f1(skb) + f3(val, skb, 1);
}
__attribute__ ((noinline))
int f3(int val, struct __sk_buff *skb, int var)
{
volatile char buf[MAX_STACK] = {};
2023-10-24 11:59:35 +01:00
__sink(buf[MAX_STACK - 1]);
2023-08-30 16:31:07 +01:00
return skb->ifindex * val * var;
}
SEC("tc")
__failure __msg("combined stack size of 4 calls is 544")
int global_func1(struct __sk_buff *skb)
{
return f0(1, skb) + f1(skb) + f2(2, skb) + f3(3, skb, 4);
}