162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci 362306a36Sopenharmony_ci#include <stdio.h> 462306a36Sopenharmony_ci#include <stdlib.h> 562306a36Sopenharmony_ci#include <signal.h> 662306a36Sopenharmony_ci#include <unistd.h> 762306a36Sopenharmony_ci#include <stdbool.h> 862306a36Sopenharmony_ci#include <string.h> 962306a36Sopenharmony_ci#include <stdint.h> 1062306a36Sopenharmony_ci#include <fcntl.h> 1162306a36Sopenharmony_ci#include <linux/bpf.h> 1262306a36Sopenharmony_ci#include <sys/ioctl.h> 1362306a36Sopenharmony_ci#include <sys/types.h> 1462306a36Sopenharmony_ci#include <sys/stat.h> 1562306a36Sopenharmony_ci#include <linux/perf_event.h> 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci#include <bpf/bpf.h> 1862306a36Sopenharmony_ci#include <bpf/libbpf.h> 1962306a36Sopenharmony_ci#include "bpf_util.h" 2062306a36Sopenharmony_ci#include "perf-sys.h" 2162306a36Sopenharmony_ci#include "trace_helpers.h" 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_cistatic struct bpf_program *progs[2]; 2462306a36Sopenharmony_cistatic struct bpf_link *links[2]; 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci#define CHECK_PERROR_RET(condition) ({ \ 2762306a36Sopenharmony_ci int __ret = !!(condition); \ 2862306a36Sopenharmony_ci if (__ret) { \ 2962306a36Sopenharmony_ci printf("FAIL: %s:\n", __func__); \ 3062306a36Sopenharmony_ci perror(" "); \ 3162306a36Sopenharmony_ci return -1; \ 3262306a36Sopenharmony_ci } \ 3362306a36Sopenharmony_ci}) 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci#define CHECK_AND_RET(condition) ({ \ 3662306a36Sopenharmony_ci int __ret = !!(condition); \ 3762306a36Sopenharmony_ci if (__ret) \ 3862306a36Sopenharmony_ci return -1; \ 3962306a36Sopenharmony_ci}) 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_cistatic __u64 ptr_to_u64(void *ptr) 4262306a36Sopenharmony_ci{ 4362306a36Sopenharmony_ci return (__u64) (unsigned long) ptr; 4462306a36Sopenharmony_ci} 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci#define PMU_TYPE_FILE "/sys/bus/event_source/devices/%s/type" 4762306a36Sopenharmony_cistatic int bpf_find_probe_type(const char *event_type) 4862306a36Sopenharmony_ci{ 4962306a36Sopenharmony_ci char buf[256]; 5062306a36Sopenharmony_ci int fd, ret; 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci ret = snprintf(buf, sizeof(buf), PMU_TYPE_FILE, event_type); 5362306a36Sopenharmony_ci CHECK_PERROR_RET(ret < 0 || ret >= sizeof(buf)); 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci fd = open(buf, O_RDONLY); 5662306a36Sopenharmony_ci CHECK_PERROR_RET(fd < 0); 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_ci ret = read(fd, buf, sizeof(buf)); 5962306a36Sopenharmony_ci close(fd); 6062306a36Sopenharmony_ci CHECK_PERROR_RET(ret < 0 || ret >= sizeof(buf)); 6162306a36Sopenharmony_ci 6262306a36Sopenharmony_ci errno = 0; 6362306a36Sopenharmony_ci ret = (int)strtol(buf, NULL, 10); 6462306a36Sopenharmony_ci CHECK_PERROR_RET(errno); 6562306a36Sopenharmony_ci return ret; 6662306a36Sopenharmony_ci} 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ci#define PMU_RETPROBE_FILE "/sys/bus/event_source/devices/%s/format/retprobe" 6962306a36Sopenharmony_cistatic int bpf_get_retprobe_bit(const char *event_type) 7062306a36Sopenharmony_ci{ 7162306a36Sopenharmony_ci char buf[256]; 7262306a36Sopenharmony_ci int fd, ret; 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci ret = snprintf(buf, sizeof(buf), PMU_RETPROBE_FILE, event_type); 7562306a36Sopenharmony_ci CHECK_PERROR_RET(ret < 0 || ret >= sizeof(buf)); 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci fd = open(buf, O_RDONLY); 7862306a36Sopenharmony_ci CHECK_PERROR_RET(fd < 0); 7962306a36Sopenharmony_ci 8062306a36Sopenharmony_ci ret = read(fd, buf, sizeof(buf)); 8162306a36Sopenharmony_ci close(fd); 8262306a36Sopenharmony_ci CHECK_PERROR_RET(ret < 0 || ret >= sizeof(buf)); 8362306a36Sopenharmony_ci CHECK_PERROR_RET(strlen(buf) < strlen("config:")); 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ci errno = 0; 8662306a36Sopenharmony_ci ret = (int)strtol(buf + strlen("config:"), NULL, 10); 8762306a36Sopenharmony_ci CHECK_PERROR_RET(errno); 8862306a36Sopenharmony_ci return ret; 8962306a36Sopenharmony_ci} 9062306a36Sopenharmony_ci 9162306a36Sopenharmony_cistatic int test_debug_fs_kprobe(int link_idx, const char *fn_name, 9262306a36Sopenharmony_ci __u32 expected_fd_type) 9362306a36Sopenharmony_ci{ 9462306a36Sopenharmony_ci __u64 probe_offset, probe_addr; 9562306a36Sopenharmony_ci __u32 len, prog_id, fd_type; 9662306a36Sopenharmony_ci int err, event_fd; 9762306a36Sopenharmony_ci char buf[256]; 9862306a36Sopenharmony_ci 9962306a36Sopenharmony_ci len = sizeof(buf); 10062306a36Sopenharmony_ci event_fd = bpf_link__fd(links[link_idx]); 10162306a36Sopenharmony_ci err = bpf_task_fd_query(getpid(), event_fd, 0, buf, &len, 10262306a36Sopenharmony_ci &prog_id, &fd_type, &probe_offset, 10362306a36Sopenharmony_ci &probe_addr); 10462306a36Sopenharmony_ci if (err < 0) { 10562306a36Sopenharmony_ci printf("FAIL: %s, for event_fd idx %d, fn_name %s\n", 10662306a36Sopenharmony_ci __func__, link_idx, fn_name); 10762306a36Sopenharmony_ci perror(" :"); 10862306a36Sopenharmony_ci return -1; 10962306a36Sopenharmony_ci } 11062306a36Sopenharmony_ci if (strcmp(buf, fn_name) != 0 || 11162306a36Sopenharmony_ci fd_type != expected_fd_type || 11262306a36Sopenharmony_ci probe_offset != 0x0 || probe_addr != 0x0) { 11362306a36Sopenharmony_ci printf("FAIL: bpf_trace_event_query(event_fd[%d]):\n", 11462306a36Sopenharmony_ci link_idx); 11562306a36Sopenharmony_ci printf("buf: %s, fd_type: %u, probe_offset: 0x%llx," 11662306a36Sopenharmony_ci " probe_addr: 0x%llx\n", 11762306a36Sopenharmony_ci buf, fd_type, probe_offset, probe_addr); 11862306a36Sopenharmony_ci return -1; 11962306a36Sopenharmony_ci } 12062306a36Sopenharmony_ci return 0; 12162306a36Sopenharmony_ci} 12262306a36Sopenharmony_ci 12362306a36Sopenharmony_cistatic int test_nondebug_fs_kuprobe_common(const char *event_type, 12462306a36Sopenharmony_ci const char *name, __u64 offset, __u64 addr, bool is_return, 12562306a36Sopenharmony_ci char *buf, __u32 *buf_len, __u32 *prog_id, __u32 *fd_type, 12662306a36Sopenharmony_ci __u64 *probe_offset, __u64 *probe_addr) 12762306a36Sopenharmony_ci{ 12862306a36Sopenharmony_ci int is_return_bit = bpf_get_retprobe_bit(event_type); 12962306a36Sopenharmony_ci int type = bpf_find_probe_type(event_type); 13062306a36Sopenharmony_ci struct perf_event_attr attr = {}; 13162306a36Sopenharmony_ci struct bpf_link *link; 13262306a36Sopenharmony_ci int fd, err = -1; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci if (type < 0 || is_return_bit < 0) { 13562306a36Sopenharmony_ci printf("FAIL: %s incorrect type (%d) or is_return_bit (%d)\n", 13662306a36Sopenharmony_ci __func__, type, is_return_bit); 13762306a36Sopenharmony_ci return err; 13862306a36Sopenharmony_ci } 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_ci attr.sample_period = 1; 14162306a36Sopenharmony_ci attr.wakeup_events = 1; 14262306a36Sopenharmony_ci if (is_return) 14362306a36Sopenharmony_ci attr.config |= 1 << is_return_bit; 14462306a36Sopenharmony_ci 14562306a36Sopenharmony_ci if (name) { 14662306a36Sopenharmony_ci attr.config1 = ptr_to_u64((void *)name); 14762306a36Sopenharmony_ci attr.config2 = offset; 14862306a36Sopenharmony_ci } else { 14962306a36Sopenharmony_ci attr.config1 = 0; 15062306a36Sopenharmony_ci attr.config2 = addr; 15162306a36Sopenharmony_ci } 15262306a36Sopenharmony_ci attr.size = sizeof(attr); 15362306a36Sopenharmony_ci attr.type = type; 15462306a36Sopenharmony_ci 15562306a36Sopenharmony_ci fd = sys_perf_event_open(&attr, -1, 0, -1, 0); 15662306a36Sopenharmony_ci link = bpf_program__attach_perf_event(progs[0], fd); 15762306a36Sopenharmony_ci if (libbpf_get_error(link)) { 15862306a36Sopenharmony_ci printf("ERROR: bpf_program__attach_perf_event failed\n"); 15962306a36Sopenharmony_ci link = NULL; 16062306a36Sopenharmony_ci close(fd); 16162306a36Sopenharmony_ci goto cleanup; 16262306a36Sopenharmony_ci } 16362306a36Sopenharmony_ci 16462306a36Sopenharmony_ci CHECK_PERROR_RET(bpf_task_fd_query(getpid(), fd, 0, buf, buf_len, 16562306a36Sopenharmony_ci prog_id, fd_type, probe_offset, probe_addr) < 0); 16662306a36Sopenharmony_ci err = 0; 16762306a36Sopenharmony_ci 16862306a36Sopenharmony_cicleanup: 16962306a36Sopenharmony_ci bpf_link__destroy(link); 17062306a36Sopenharmony_ci return err; 17162306a36Sopenharmony_ci} 17262306a36Sopenharmony_ci 17362306a36Sopenharmony_cistatic int test_nondebug_fs_probe(const char *event_type, const char *name, 17462306a36Sopenharmony_ci __u64 offset, __u64 addr, bool is_return, 17562306a36Sopenharmony_ci __u32 expected_fd_type, 17662306a36Sopenharmony_ci __u32 expected_ret_fd_type, 17762306a36Sopenharmony_ci char *buf, __u32 buf_len) 17862306a36Sopenharmony_ci{ 17962306a36Sopenharmony_ci __u64 probe_offset, probe_addr; 18062306a36Sopenharmony_ci __u32 prog_id, fd_type; 18162306a36Sopenharmony_ci int err; 18262306a36Sopenharmony_ci 18362306a36Sopenharmony_ci err = test_nondebug_fs_kuprobe_common(event_type, name, 18462306a36Sopenharmony_ci offset, addr, is_return, 18562306a36Sopenharmony_ci buf, &buf_len, &prog_id, 18662306a36Sopenharmony_ci &fd_type, &probe_offset, 18762306a36Sopenharmony_ci &probe_addr); 18862306a36Sopenharmony_ci if (err < 0) { 18962306a36Sopenharmony_ci printf("FAIL: %s, " 19062306a36Sopenharmony_ci "for name %s, offset 0x%llx, addr 0x%llx, is_return %d\n", 19162306a36Sopenharmony_ci __func__, name ? name : "", offset, addr, is_return); 19262306a36Sopenharmony_ci perror(" :"); 19362306a36Sopenharmony_ci return -1; 19462306a36Sopenharmony_ci } 19562306a36Sopenharmony_ci if ((is_return && fd_type != expected_ret_fd_type) || 19662306a36Sopenharmony_ci (!is_return && fd_type != expected_fd_type)) { 19762306a36Sopenharmony_ci printf("FAIL: %s, incorrect fd_type %u\n", 19862306a36Sopenharmony_ci __func__, fd_type); 19962306a36Sopenharmony_ci return -1; 20062306a36Sopenharmony_ci } 20162306a36Sopenharmony_ci if (name) { 20262306a36Sopenharmony_ci if (strcmp(name, buf) != 0) { 20362306a36Sopenharmony_ci printf("FAIL: %s, incorrect buf %s\n", __func__, buf); 20462306a36Sopenharmony_ci return -1; 20562306a36Sopenharmony_ci } 20662306a36Sopenharmony_ci if (probe_offset != offset) { 20762306a36Sopenharmony_ci printf("FAIL: %s, incorrect probe_offset 0x%llx\n", 20862306a36Sopenharmony_ci __func__, probe_offset); 20962306a36Sopenharmony_ci return -1; 21062306a36Sopenharmony_ci } 21162306a36Sopenharmony_ci } else { 21262306a36Sopenharmony_ci if (buf_len != 0) { 21362306a36Sopenharmony_ci printf("FAIL: %s, incorrect buf %p\n", 21462306a36Sopenharmony_ci __func__, buf); 21562306a36Sopenharmony_ci return -1; 21662306a36Sopenharmony_ci } 21762306a36Sopenharmony_ci 21862306a36Sopenharmony_ci if (probe_addr != addr) { 21962306a36Sopenharmony_ci printf("FAIL: %s, incorrect probe_addr 0x%llx\n", 22062306a36Sopenharmony_ci __func__, probe_addr); 22162306a36Sopenharmony_ci return -1; 22262306a36Sopenharmony_ci } 22362306a36Sopenharmony_ci } 22462306a36Sopenharmony_ci return 0; 22562306a36Sopenharmony_ci} 22662306a36Sopenharmony_ci 22762306a36Sopenharmony_cistatic int test_debug_fs_uprobe(char *binary_path, long offset, bool is_return) 22862306a36Sopenharmony_ci{ 22962306a36Sopenharmony_ci char buf[256], event_alias[sizeof("test_1234567890")]; 23062306a36Sopenharmony_ci const char *event_type = "uprobe"; 23162306a36Sopenharmony_ci struct perf_event_attr attr = {}; 23262306a36Sopenharmony_ci __u64 probe_offset, probe_addr; 23362306a36Sopenharmony_ci __u32 len, prog_id, fd_type; 23462306a36Sopenharmony_ci int err = -1, res, kfd, efd; 23562306a36Sopenharmony_ci struct bpf_link *link; 23662306a36Sopenharmony_ci ssize_t bytes; 23762306a36Sopenharmony_ci 23862306a36Sopenharmony_ci snprintf(buf, sizeof(buf), "/sys/kernel/tracing/%s_events", 23962306a36Sopenharmony_ci event_type); 24062306a36Sopenharmony_ci kfd = open(buf, O_WRONLY | O_TRUNC, 0); 24162306a36Sopenharmony_ci CHECK_PERROR_RET(kfd < 0); 24262306a36Sopenharmony_ci 24362306a36Sopenharmony_ci res = snprintf(event_alias, sizeof(event_alias), "test_%d", getpid()); 24462306a36Sopenharmony_ci CHECK_PERROR_RET(res < 0 || res >= sizeof(event_alias)); 24562306a36Sopenharmony_ci 24662306a36Sopenharmony_ci res = snprintf(buf, sizeof(buf), "%c:%ss/%s %s:0x%lx", 24762306a36Sopenharmony_ci is_return ? 'r' : 'p', event_type, event_alias, 24862306a36Sopenharmony_ci binary_path, offset); 24962306a36Sopenharmony_ci CHECK_PERROR_RET(res < 0 || res >= sizeof(buf)); 25062306a36Sopenharmony_ci CHECK_PERROR_RET(write(kfd, buf, strlen(buf)) < 0); 25162306a36Sopenharmony_ci 25262306a36Sopenharmony_ci close(kfd); 25362306a36Sopenharmony_ci kfd = -1; 25462306a36Sopenharmony_ci 25562306a36Sopenharmony_ci snprintf(buf, sizeof(buf), "/sys/kernel/tracing/events/%ss/%s/id", 25662306a36Sopenharmony_ci event_type, event_alias); 25762306a36Sopenharmony_ci efd = open(buf, O_RDONLY, 0); 25862306a36Sopenharmony_ci CHECK_PERROR_RET(efd < 0); 25962306a36Sopenharmony_ci 26062306a36Sopenharmony_ci bytes = read(efd, buf, sizeof(buf)); 26162306a36Sopenharmony_ci CHECK_PERROR_RET(bytes <= 0 || bytes >= sizeof(buf)); 26262306a36Sopenharmony_ci close(efd); 26362306a36Sopenharmony_ci buf[bytes] = '\0'; 26462306a36Sopenharmony_ci 26562306a36Sopenharmony_ci attr.config = strtol(buf, NULL, 0); 26662306a36Sopenharmony_ci attr.type = PERF_TYPE_TRACEPOINT; 26762306a36Sopenharmony_ci attr.sample_period = 1; 26862306a36Sopenharmony_ci attr.wakeup_events = 1; 26962306a36Sopenharmony_ci 27062306a36Sopenharmony_ci kfd = sys_perf_event_open(&attr, -1, 0, -1, PERF_FLAG_FD_CLOEXEC); 27162306a36Sopenharmony_ci link = bpf_program__attach_perf_event(progs[0], kfd); 27262306a36Sopenharmony_ci if (libbpf_get_error(link)) { 27362306a36Sopenharmony_ci printf("ERROR: bpf_program__attach_perf_event failed\n"); 27462306a36Sopenharmony_ci link = NULL; 27562306a36Sopenharmony_ci close(kfd); 27662306a36Sopenharmony_ci goto cleanup; 27762306a36Sopenharmony_ci } 27862306a36Sopenharmony_ci 27962306a36Sopenharmony_ci len = sizeof(buf); 28062306a36Sopenharmony_ci err = bpf_task_fd_query(getpid(), kfd, 0, buf, &len, 28162306a36Sopenharmony_ci &prog_id, &fd_type, &probe_offset, 28262306a36Sopenharmony_ci &probe_addr); 28362306a36Sopenharmony_ci if (err < 0) { 28462306a36Sopenharmony_ci printf("FAIL: %s, binary_path %s\n", __func__, binary_path); 28562306a36Sopenharmony_ci perror(" :"); 28662306a36Sopenharmony_ci return -1; 28762306a36Sopenharmony_ci } 28862306a36Sopenharmony_ci if ((is_return && fd_type != BPF_FD_TYPE_URETPROBE) || 28962306a36Sopenharmony_ci (!is_return && fd_type != BPF_FD_TYPE_UPROBE)) { 29062306a36Sopenharmony_ci printf("FAIL: %s, incorrect fd_type %u\n", __func__, 29162306a36Sopenharmony_ci fd_type); 29262306a36Sopenharmony_ci return -1; 29362306a36Sopenharmony_ci } 29462306a36Sopenharmony_ci if (strcmp(binary_path, buf) != 0) { 29562306a36Sopenharmony_ci printf("FAIL: %s, incorrect buf %s\n", __func__, buf); 29662306a36Sopenharmony_ci return -1; 29762306a36Sopenharmony_ci } 29862306a36Sopenharmony_ci if (probe_offset != offset) { 29962306a36Sopenharmony_ci printf("FAIL: %s, incorrect probe_offset 0x%llx\n", __func__, 30062306a36Sopenharmony_ci probe_offset); 30162306a36Sopenharmony_ci return -1; 30262306a36Sopenharmony_ci } 30362306a36Sopenharmony_ci err = 0; 30462306a36Sopenharmony_ci 30562306a36Sopenharmony_cicleanup: 30662306a36Sopenharmony_ci bpf_link__destroy(link); 30762306a36Sopenharmony_ci return err; 30862306a36Sopenharmony_ci} 30962306a36Sopenharmony_ci 31062306a36Sopenharmony_ciint main(int argc, char **argv) 31162306a36Sopenharmony_ci{ 31262306a36Sopenharmony_ci extern char __executable_start; 31362306a36Sopenharmony_ci char filename[256], buf[256]; 31462306a36Sopenharmony_ci __u64 uprobe_file_offset; 31562306a36Sopenharmony_ci struct bpf_program *prog; 31662306a36Sopenharmony_ci struct bpf_object *obj; 31762306a36Sopenharmony_ci int i = 0, err = -1; 31862306a36Sopenharmony_ci 31962306a36Sopenharmony_ci if (load_kallsyms()) { 32062306a36Sopenharmony_ci printf("failed to process /proc/kallsyms\n"); 32162306a36Sopenharmony_ci return err; 32262306a36Sopenharmony_ci } 32362306a36Sopenharmony_ci 32462306a36Sopenharmony_ci snprintf(filename, sizeof(filename), "%s_kern.o", argv[0]); 32562306a36Sopenharmony_ci obj = bpf_object__open_file(filename, NULL); 32662306a36Sopenharmony_ci if (libbpf_get_error(obj)) { 32762306a36Sopenharmony_ci fprintf(stderr, "ERROR: opening BPF object file failed\n"); 32862306a36Sopenharmony_ci return err; 32962306a36Sopenharmony_ci } 33062306a36Sopenharmony_ci 33162306a36Sopenharmony_ci /* load BPF program */ 33262306a36Sopenharmony_ci if (bpf_object__load(obj)) { 33362306a36Sopenharmony_ci fprintf(stderr, "ERROR: loading BPF object file failed\n"); 33462306a36Sopenharmony_ci goto cleanup; 33562306a36Sopenharmony_ci } 33662306a36Sopenharmony_ci 33762306a36Sopenharmony_ci bpf_object__for_each_program(prog, obj) { 33862306a36Sopenharmony_ci progs[i] = prog; 33962306a36Sopenharmony_ci links[i] = bpf_program__attach(progs[i]); 34062306a36Sopenharmony_ci if (libbpf_get_error(links[i])) { 34162306a36Sopenharmony_ci fprintf(stderr, "ERROR: bpf_program__attach failed\n"); 34262306a36Sopenharmony_ci links[i] = NULL; 34362306a36Sopenharmony_ci goto cleanup; 34462306a36Sopenharmony_ci } 34562306a36Sopenharmony_ci i++; 34662306a36Sopenharmony_ci } 34762306a36Sopenharmony_ci 34862306a36Sopenharmony_ci /* test two functions in the corresponding *_kern.c file */ 34962306a36Sopenharmony_ci CHECK_AND_RET(test_debug_fs_kprobe(0, "blk_mq_start_request", 35062306a36Sopenharmony_ci BPF_FD_TYPE_KPROBE)); 35162306a36Sopenharmony_ci CHECK_AND_RET(test_debug_fs_kprobe(1, "__blk_account_io_done", 35262306a36Sopenharmony_ci BPF_FD_TYPE_KRETPROBE)); 35362306a36Sopenharmony_ci 35462306a36Sopenharmony_ci /* test nondebug fs kprobe */ 35562306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("kprobe", "bpf_check", 0x0, 0x0, 35662306a36Sopenharmony_ci false, BPF_FD_TYPE_KPROBE, 35762306a36Sopenharmony_ci BPF_FD_TYPE_KRETPROBE, 35862306a36Sopenharmony_ci buf, sizeof(buf))); 35962306a36Sopenharmony_ci#ifdef __x86_64__ 36062306a36Sopenharmony_ci /* set a kprobe on "bpf_check + 0x5", which is x64 specific */ 36162306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("kprobe", "bpf_check", 0x5, 0x0, 36262306a36Sopenharmony_ci false, BPF_FD_TYPE_KPROBE, 36362306a36Sopenharmony_ci BPF_FD_TYPE_KRETPROBE, 36462306a36Sopenharmony_ci buf, sizeof(buf))); 36562306a36Sopenharmony_ci#endif 36662306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("kprobe", "bpf_check", 0x0, 0x0, 36762306a36Sopenharmony_ci true, BPF_FD_TYPE_KPROBE, 36862306a36Sopenharmony_ci BPF_FD_TYPE_KRETPROBE, 36962306a36Sopenharmony_ci buf, sizeof(buf))); 37062306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("kprobe", NULL, 0x0, 37162306a36Sopenharmony_ci ksym_get_addr("bpf_check"), false, 37262306a36Sopenharmony_ci BPF_FD_TYPE_KPROBE, 37362306a36Sopenharmony_ci BPF_FD_TYPE_KRETPROBE, 37462306a36Sopenharmony_ci buf, sizeof(buf))); 37562306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("kprobe", NULL, 0x0, 37662306a36Sopenharmony_ci ksym_get_addr("bpf_check"), false, 37762306a36Sopenharmony_ci BPF_FD_TYPE_KPROBE, 37862306a36Sopenharmony_ci BPF_FD_TYPE_KRETPROBE, 37962306a36Sopenharmony_ci NULL, 0)); 38062306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("kprobe", NULL, 0x0, 38162306a36Sopenharmony_ci ksym_get_addr("bpf_check"), true, 38262306a36Sopenharmony_ci BPF_FD_TYPE_KPROBE, 38362306a36Sopenharmony_ci BPF_FD_TYPE_KRETPROBE, 38462306a36Sopenharmony_ci buf, sizeof(buf))); 38562306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("kprobe", NULL, 0x0, 38662306a36Sopenharmony_ci ksym_get_addr("bpf_check"), true, 38762306a36Sopenharmony_ci BPF_FD_TYPE_KPROBE, 38862306a36Sopenharmony_ci BPF_FD_TYPE_KRETPROBE, 38962306a36Sopenharmony_ci 0, 0)); 39062306a36Sopenharmony_ci 39162306a36Sopenharmony_ci /* test nondebug fs uprobe */ 39262306a36Sopenharmony_ci /* the calculation of uprobe file offset is based on gcc 7.3.1 on x64 39362306a36Sopenharmony_ci * and the default linker script, which defines __executable_start as 39462306a36Sopenharmony_ci * the start of the .text section. The calculation could be different 39562306a36Sopenharmony_ci * on different systems with different compilers. The right way is 39662306a36Sopenharmony_ci * to parse the ELF file. We took a shortcut here. 39762306a36Sopenharmony_ci */ 39862306a36Sopenharmony_ci uprobe_file_offset = (unsigned long)main - (unsigned long)&__executable_start; 39962306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("uprobe", (char *)argv[0], 40062306a36Sopenharmony_ci uprobe_file_offset, 0x0, false, 40162306a36Sopenharmony_ci BPF_FD_TYPE_UPROBE, 40262306a36Sopenharmony_ci BPF_FD_TYPE_URETPROBE, 40362306a36Sopenharmony_ci buf, sizeof(buf))); 40462306a36Sopenharmony_ci CHECK_AND_RET(test_nondebug_fs_probe("uprobe", (char *)argv[0], 40562306a36Sopenharmony_ci uprobe_file_offset, 0x0, true, 40662306a36Sopenharmony_ci BPF_FD_TYPE_UPROBE, 40762306a36Sopenharmony_ci BPF_FD_TYPE_URETPROBE, 40862306a36Sopenharmony_ci buf, sizeof(buf))); 40962306a36Sopenharmony_ci 41062306a36Sopenharmony_ci /* test debug fs uprobe */ 41162306a36Sopenharmony_ci CHECK_AND_RET(test_debug_fs_uprobe((char *)argv[0], uprobe_file_offset, 41262306a36Sopenharmony_ci false)); 41362306a36Sopenharmony_ci CHECK_AND_RET(test_debug_fs_uprobe((char *)argv[0], uprobe_file_offset, 41462306a36Sopenharmony_ci true)); 41562306a36Sopenharmony_ci err = 0; 41662306a36Sopenharmony_ci 41762306a36Sopenharmony_cicleanup: 41862306a36Sopenharmony_ci for (i--; i >= 0; i--) 41962306a36Sopenharmony_ci bpf_link__destroy(links[i]); 42062306a36Sopenharmony_ci 42162306a36Sopenharmony_ci bpf_object__close(obj); 42262306a36Sopenharmony_ci return err; 42362306a36Sopenharmony_ci} 424