mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 e68a144547
			
		
	
	
		e68a144547
		
	
	
	
	
		
			
			Modify few tests to sanity test sleepable bpf functionality. Running 'bench trig-fentry-sleep' vs 'bench trig-fentry' and 'perf report': sleepable with SRCU: 3.86% bench [k] __srcu_read_unlock 3.22% bench [k] __srcu_read_lock 0.92% bench [k] bpf_prog_740d4210cdcd99a3_bench_trigger_fentry_sleep 0.50% bench [k] bpf_trampoline_10297 0.26% bench [k] __bpf_prog_exit_sleepable 0.21% bench [k] __bpf_prog_enter_sleepable sleepable with RCU_TRACE: 0.79% bench [k] bpf_prog_740d4210cdcd99a3_bench_trigger_fentry_sleep 0.72% bench [k] bpf_trampoline_10381 0.31% bench [k] __bpf_prog_exit_sleepable 0.29% bench [k] __bpf_prog_enter_sleepable non-sleepable with RCU: 0.88% bench [k] bpf_prog_740d4210cdcd99a3_bench_trigger_fentry 0.84% bench [k] bpf_trampoline_10297 0.13% bench [k] __bpf_prog_enter 0.12% bench [k] __bpf_prog_exit Signed-off-by: Alexei Starovoitov <ast@kernel.org> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Acked-by: KP Singh <kpsingh@google.com> Link: https://lore.kernel.org/bpf/20200827220114.69225-6-alexei.starovoitov@gmail.com
		
			
				
	
	
		
			55 lines
		
	
	
		
			994 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			994 B
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| // Copyright (c) 2020 Facebook
 | |
| 
 | |
| #include <linux/bpf.h>
 | |
| #include <asm/unistd.h>
 | |
| #include <bpf/bpf_helpers.h>
 | |
| #include <bpf/bpf_tracing.h>
 | |
| 
 | |
| char _license[] SEC("license") = "GPL";
 | |
| 
 | |
| long hits = 0;
 | |
| 
 | |
| SEC("tp/syscalls/sys_enter_getpgid")
 | |
| int bench_trigger_tp(void *ctx)
 | |
| {
 | |
| 	__sync_add_and_fetch(&hits, 1);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| SEC("raw_tp/sys_enter")
 | |
| int BPF_PROG(bench_trigger_raw_tp, struct pt_regs *regs, long id)
 | |
| {
 | |
| 	if (id == __NR_getpgid)
 | |
| 		__sync_add_and_fetch(&hits, 1);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| SEC("kprobe/__x64_sys_getpgid")
 | |
| int bench_trigger_kprobe(void *ctx)
 | |
| {
 | |
| 	__sync_add_and_fetch(&hits, 1);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| SEC("fentry/__x64_sys_getpgid")
 | |
| int bench_trigger_fentry(void *ctx)
 | |
| {
 | |
| 	__sync_add_and_fetch(&hits, 1);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| SEC("fentry.s/__x64_sys_getpgid")
 | |
| int bench_trigger_fentry_sleep(void *ctx)
 | |
| {
 | |
| 	__sync_add_and_fetch(&hits, 1);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| SEC("fmod_ret/__x64_sys_getpgid")
 | |
| int bench_trigger_fmodret(void *ctx)
 | |
| {
 | |
| 	__sync_add_and_fetch(&hits, 1);
 | |
| 	return -22;
 | |
| }
 |