mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-10-31 08:28:13 +00:00
9e9b451593
Adjust static_linked selftests to test a mix of global and static variables and their handling of bpftool's skeleton generation code. Signed-off-by: Andrii Nakryiko <andrii@kernel.org> Signed-off-by: Alexei Starovoitov <ast@kernel.org> Link: https://lore.kernel.org/bpf/20210513233643.194711-1-andrii@kernel.org
82 lines
1.8 KiB
C
82 lines
1.8 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/* Copyright (c) 2021 Facebook */
|
|
|
|
#include "vmlinux.h"
|
|
#include <bpf/bpf_helpers.h>
|
|
#include <bpf/bpf_tracing.h>
|
|
|
|
struct my_key { long x; };
|
|
struct my_value { long x; };
|
|
|
|
struct {
|
|
__uint(type, BPF_MAP_TYPE_HASH);
|
|
__type(key, struct my_key);
|
|
__type(value, struct my_value);
|
|
__uint(max_entries, 16);
|
|
} map1 SEC(".maps");
|
|
|
|
/* Matches map2 definition in linked_maps2.c. Order of the attributes doesn't
|
|
* matter.
|
|
*/
|
|
typedef struct {
|
|
__uint(max_entries, 8);
|
|
__type(key, int);
|
|
__type(value, int);
|
|
__uint(type, BPF_MAP_TYPE_ARRAY);
|
|
} map2_t;
|
|
|
|
extern map2_t map2 SEC(".maps");
|
|
|
|
/* This should be the winning map definition, but we have no way of verifying,
|
|
* so we just make sure that it links and works without errors
|
|
*/
|
|
struct {
|
|
__uint(type, BPF_MAP_TYPE_ARRAY);
|
|
__type(key, int);
|
|
__type(value, int);
|
|
__uint(max_entries, 16);
|
|
} map_weak __weak SEC(".maps");
|
|
|
|
int output_first1;
|
|
int output_second1;
|
|
int output_weak1;
|
|
|
|
SEC("raw_tp/sys_enter")
|
|
int BPF_PROG(handler_enter1)
|
|
{
|
|
/* update values with key = 1 */
|
|
int key = 1, val = 1;
|
|
struct my_key key_struct = { .x = 1 };
|
|
struct my_value val_struct = { .x = 1000 };
|
|
|
|
bpf_map_update_elem(&map1, &key_struct, &val_struct, 0);
|
|
bpf_map_update_elem(&map2, &key, &val, 0);
|
|
bpf_map_update_elem(&map_weak, &key, &val, 0);
|
|
|
|
return 0;
|
|
}
|
|
|
|
SEC("raw_tp/sys_exit")
|
|
int BPF_PROG(handler_exit1)
|
|
{
|
|
/* lookup values with key = 2, set in another file */
|
|
int key = 2, *val;
|
|
struct my_key key_struct = { .x = 2 };
|
|
struct my_value *value_struct;
|
|
|
|
value_struct = bpf_map_lookup_elem(&map1, &key_struct);
|
|
if (value_struct)
|
|
output_first1 = value_struct->x;
|
|
|
|
val = bpf_map_lookup_elem(&map2, &key);
|
|
if (val)
|
|
output_second1 = *val;
|
|
|
|
val = bpf_map_lookup_elem(&map_weak, &key);
|
|
if (val)
|
|
output_weak1 = *val;
|
|
|
|
return 0;
|
|
}
|
|
|
|
char LICENSE[] SEC("license") = "GPL";
|