43 lines
870 B
C
43 lines
870 B
C
|
// SPDX-License-Identifier: GPL-2.0
|
||
|
/* Copyright (c) 2024 Meta Platforms, Inc. and affiliates. */
|
||
|
|
||
|
#include <vmlinux.h>
|
||
|
#include <bpf/bpf_helpers.h>
|
||
|
#include "uptr_test_common.h"
|
||
|
|
||
|
struct {
|
||
|
__uint(type, BPF_MAP_TYPE_TASK_STORAGE);
|
||
|
__uint(map_flags, BPF_F_NO_PREALLOC);
|
||
|
__type(key, int);
|
||
|
__type(value, struct value_lock_type);
|
||
|
} datamap SEC(".maps");
|
||
|
|
||
|
/* load test only. not used */
|
||
|
SEC("syscall")
|
||
|
int not_used(void *ctx)
|
||
|
{
|
||
|
struct value_lock_type *ptr;
|
||
|
struct task_struct *task;
|
||
|
struct user_data *udata;
|
||
|
|
||
|
task = bpf_get_current_task_btf();
|
||
|
ptr = bpf_task_storage_get(&datamap, task, 0, 0);
|
||
|
if (!ptr)
|
||
|
return 0;
|
||
|
|
||
|
bpf_spin_lock(&ptr->lock);
|
||
|
|
||
|
udata = ptr->udata;
|
||
|
if (!udata) {
|
||
|
bpf_spin_unlock(&ptr->lock);
|
||
|
return 0;
|
||
|
}
|
||
|
udata->result = MAGIC_VALUE + udata->a + udata->b;
|
||
|
|
||
|
bpf_spin_unlock(&ptr->lock);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
char _license[] SEC("license") = "GPL";
|