mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 a8fdaad5cf
			
		
	
	
		a8fdaad5cf
		
	
	
	
	
		
			
			Add exra level of verboseness, activated by -vvv argument. When -vv is specified, verbose libbpf and verifier log (level 1) is output, even for successful tests. With -vvv, verifier log goes to level 2. This is extremely useful to debug verifier failures, as well as just see the state and flow of verification. Before this, you'd have to go and modify load_program()'s source code inside libbpf to specify extra log_level flags, which is suboptimal to say the least. Currently -vv and -vvv triggering verifier output is integrated into test_stub's bpf_prog_load as well as bpf_verif_scale.c tests. Signed-off-by: Andrii Nakryiko <andriin@fb.com> Signed-off-by: Alexei Starovoitov <ast@kernel.org> Link: https://lore.kernel.org/bpf/20191120003548.4159797-1-andriin@fb.com
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
 | |
| /* Copyright (C) 2019 Netronome Systems, Inc. */
 | |
| 
 | |
| #include <bpf/bpf.h>
 | |
| #include <bpf/libbpf.h>
 | |
| #include <string.h>
 | |
| 
 | |
| int extra_prog_load_log_flags = 0;
 | |
| 
 | |
| int bpf_prog_test_load(const char *file, enum bpf_prog_type type,
 | |
| 		       struct bpf_object **pobj, int *prog_fd)
 | |
| {
 | |
| 	struct bpf_prog_load_attr attr;
 | |
| 
 | |
| 	memset(&attr, 0, sizeof(struct bpf_prog_load_attr));
 | |
| 	attr.file = file;
 | |
| 	attr.prog_type = type;
 | |
| 	attr.expected_attach_type = 0;
 | |
| 	attr.prog_flags = BPF_F_TEST_RND_HI32;
 | |
| 	attr.log_level = extra_prog_load_log_flags;
 | |
| 
 | |
| 	return bpf_prog_load_xattr(&attr, pobj, prog_fd);
 | |
| }
 | |
| 
 | |
| int bpf_test_load_program(enum bpf_prog_type type, const struct bpf_insn *insns,
 | |
| 			  size_t insns_cnt, const char *license,
 | |
| 			  __u32 kern_version, char *log_buf,
 | |
| 		     size_t log_buf_sz)
 | |
| {
 | |
| 	struct bpf_load_program_attr load_attr;
 | |
| 
 | |
| 	memset(&load_attr, 0, sizeof(struct bpf_load_program_attr));
 | |
| 	load_attr.prog_type = type;
 | |
| 	load_attr.expected_attach_type = 0;
 | |
| 	load_attr.name = NULL;
 | |
| 	load_attr.insns = insns;
 | |
| 	load_attr.insns_cnt = insns_cnt;
 | |
| 	load_attr.license = license;
 | |
| 	load_attr.kern_version = kern_version;
 | |
| 	load_attr.prog_flags = BPF_F_TEST_RND_HI32;
 | |
| 	load_attr.log_level = extra_prog_load_log_flags;
 | |
| 
 | |
| 	return bpf_load_program_xattr(&load_attr, log_buf, log_buf_sz);
 | |
| }
 |