Linux Audio

Check our new training course

Loading...
v6.13.7
 1/* SPDX-License-Identifier: GPL-2.0 */
 2/* Copyright (c) 2018 Facebook */
 3#include <linux/bpf.h>
 4#include <bpf/bpf_helpers.h>
 5#include "bpf_legacy.h"
 
 6
 7struct ipv_counts {
 8	unsigned int v4;
 9	unsigned int v6;
10};
11
 
 
 
 
 
 
 
 
 
 
12struct {
13	__uint(type, BPF_MAP_TYPE_ARRAY);
14	__uint(max_entries, 4);
15	__type(key, int);
16	__type(value, struct ipv_counts);
17} btf_map SEC(".maps");
18
 
 
 
 
 
19__attribute__((noinline))
20int test_long_fname_2(void)
21{
22	struct ipv_counts *counts;
23	int key = 0;
24
 
 
 
25	counts = bpf_map_lookup_elem(&btf_map, &key);
26	if (!counts)
27		return 0;
28
29	counts->v6++;
30
 
 
 
 
 
31	return 0;
32}
33
34__attribute__((noinline))
35int test_long_fname_1(void)
36{
37	return test_long_fname_2();
38}
39
40SEC("dummy_tracepoint")
41int _dummy_tracepoint(void *arg)
42{
43	return test_long_fname_1();
44}
45
46char _license[] SEC("license") = "GPL";
v5.4
 1/* SPDX-License-Identifier: GPL-2.0 */
 2/* Copyright (c) 2018 Facebook */
 3#include <linux/bpf.h>
 4#include "bpf_helpers.h"
 5
 6int _version SEC("version") = 1;
 7
 8struct ipv_counts {
 9	unsigned int v4;
10	unsigned int v6;
11};
12
13/* just to validate we can handle maps in multiple sections */
14struct bpf_map_def SEC("maps") btf_map_legacy = {
15	.type = BPF_MAP_TYPE_ARRAY,
16	.key_size = sizeof(int),
17	.value_size = sizeof(long long),
18	.max_entries = 4,
19};
20
21BPF_ANNOTATE_KV_PAIR(btf_map_legacy, int, struct ipv_counts);
22
23struct {
24	__uint(type, BPF_MAP_TYPE_ARRAY);
25	__uint(max_entries, 4);
26	__type(key, int);
27	__type(value, struct ipv_counts);
28} btf_map SEC(".maps");
29
30struct dummy_tracepoint_args {
31	unsigned long long pad;
32	struct sock *sock;
33};
34
35__attribute__((noinline))
36static int test_long_fname_2(struct dummy_tracepoint_args *arg)
37{
38	struct ipv_counts *counts;
39	int key = 0;
40
41	if (!arg->sock)
42		return 0;
43
44	counts = bpf_map_lookup_elem(&btf_map, &key);
45	if (!counts)
46		return 0;
47
48	counts->v6++;
49
50	/* just verify we can reference both maps */
51	counts = bpf_map_lookup_elem(&btf_map_legacy, &key);
52	if (!counts)
53		return 0;
54
55	return 0;
56}
57
58__attribute__((noinline))
59static int test_long_fname_1(struct dummy_tracepoint_args *arg)
60{
61	return test_long_fname_2(arg);
62}
63
64SEC("dummy_tracepoint")
65int _dummy_tracepoint(struct dummy_tracepoint_args *arg)
66{
67	return test_long_fname_1(arg);
68}
69
70char _license[] SEC("license") = "GPL";