Fix all selftests to include libbpf header files with the bpf/ prefix, to
be consistent with external users of the library. Also ensure that all
includes of exported libbpf header files (those that are exported on 'make
install' of the library) use bracketed includes instead of quoted.
To not break the build, keep the old include path until everything has been
changed to the new one; a subsequent patch will remove that.
Fixes: 6910d7d386 ("selftests/bpf: Ensure bpf_helper_defs.h are taken from selftests dir")
Signed-off-by: Toke Høiland-Jørgensen <toke@redhat.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Acked-by: Andrii Nakryiko <andriin@fb.com>
Link: https://lore.kernel.org/bpf/157952560568.1683545.9649335788846513446.stgit@toke.dk
		
	
			
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Copyright (c) 2017 Facebook
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of version 2 of the GNU General Public
 | |
|  * License as published by the Free Software Foundation.
 | |
|  */
 | |
| 
 | |
| #include <linux/bpf.h>
 | |
| #include <linux/version.h>
 | |
| #include <bpf/bpf_helpers.h>
 | |
| 
 | |
| SEC("cgroup/dev")
 | |
| int bpf_prog1(struct bpf_cgroup_dev_ctx *ctx)
 | |
| {
 | |
| 	short type = ctx->access_type & 0xFFFF;
 | |
| #ifdef DEBUG
 | |
| 	short access = ctx->access_type >> 16;
 | |
| 	char fmt[] = "  %d:%d    \n";
 | |
| 
 | |
| 	switch (type) {
 | |
| 	case BPF_DEVCG_DEV_BLOCK:
 | |
| 		fmt[0] = 'b';
 | |
| 		break;
 | |
| 	case BPF_DEVCG_DEV_CHAR:
 | |
| 		fmt[0] = 'c';
 | |
| 		break;
 | |
| 	default:
 | |
| 		fmt[0] = '?';
 | |
| 		break;
 | |
| 	}
 | |
| 
 | |
| 	if (access & BPF_DEVCG_ACC_READ)
 | |
| 		fmt[8] = 'r';
 | |
| 
 | |
| 	if (access & BPF_DEVCG_ACC_WRITE)
 | |
| 		fmt[9] = 'w';
 | |
| 
 | |
| 	if (access & BPF_DEVCG_ACC_MKNOD)
 | |
| 		fmt[10] = 'm';
 | |
| 
 | |
| 	bpf_trace_printk(fmt, sizeof(fmt), ctx->major, ctx->minor);
 | |
| #endif
 | |
| 
 | |
| 	/* Allow access to /dev/zero and /dev/random.
 | |
| 	 * Forbid everything else.
 | |
| 	 */
 | |
| 	if (ctx->major != 1 || type != BPF_DEVCG_DEV_CHAR)
 | |
| 		return 0;
 | |
| 
 | |
| 	switch (ctx->minor) {
 | |
| 	case 5: /* 1:5 /dev/zero */
 | |
| 	case 9: /* 1:9 /dev/urandom */
 | |
| 		return 1;
 | |
| 	}
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| char _license[] SEC("license") = "GPL";
 | |
| __u32 _version SEC("version") = LINUX_VERSION_CODE;
 |