Commit 694731e8 authored by Andrii Nakryiko's avatar Andrii Nakryiko Committed by Daniel Borkmann

selftests/bpf: Adjust CO-RE reloc tests for new bpf_core_read() macro

To allow adding a variadic BPF_CORE_READ macro with slightly different
syntax and semantics, define CORE_READ in CO-RE reloc tests, which is
a thin wrapper around low-level bpf_core_read() macro, which in turn is
just a wrapper around bpf_probe_read().
Signed-off-by: default avatarAndrii Nakryiko <andriin@fb.com>
Signed-off-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
Acked-by: default avatarJohn Fastabend <john.fastabend@gmail.com>
Acked-by: default avatarSong Liu <songliubraving@fb.com>
Link: https://lore.kernel.org/bpf/20191008175942.1769476-4-andriin@fb.com
parent 36b5d471
...@@ -223,7 +223,7 @@ struct pt_regs; ...@@ -223,7 +223,7 @@ struct pt_regs;
#endif #endif
/* /*
* BPF_CORE_READ abstracts away bpf_probe_read() call and captures offset * bpf_core_read() abstracts away bpf_probe_read() call and captures offset
* relocation for source address using __builtin_preserve_access_index() * relocation for source address using __builtin_preserve_access_index()
* built-in, provided by Clang. * built-in, provided by Clang.
* *
...@@ -238,8 +238,8 @@ struct pt_regs; ...@@ -238,8 +238,8 @@ struct pt_regs;
* actual field offset, based on target kernel BTF type that matches original * actual field offset, based on target kernel BTF type that matches original
* (local) BTF, used to record relocation. * (local) BTF, used to record relocation.
*/ */
#define BPF_CORE_READ(dst, src) \ #define bpf_core_read(dst, sz, src) \
bpf_probe_read((dst), sizeof(*(src)), \ bpf_probe_read(dst, sz, \
__builtin_preserve_access_index(src)) (const void *)__builtin_preserve_access_index(src))
#endif #endif
...@@ -31,6 +31,8 @@ struct core_reloc_arrays { ...@@ -31,6 +31,8 @@ struct core_reloc_arrays {
struct core_reloc_arrays_substruct d[1][2]; struct core_reloc_arrays_substruct d[1][2];
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_arrays(void *ctx) int test_core_arrays(void *ctx)
{ {
...@@ -38,16 +40,16 @@ int test_core_arrays(void *ctx) ...@@ -38,16 +40,16 @@ int test_core_arrays(void *ctx)
struct core_reloc_arrays_output *out = (void *)&data.out; struct core_reloc_arrays_output *out = (void *)&data.out;
/* in->a[2] */ /* in->a[2] */
if (BPF_CORE_READ(&out->a2, &in->a[2])) if (CORE_READ(&out->a2, &in->a[2]))
return 1; return 1;
/* in->b[1][2][3] */ /* in->b[1][2][3] */
if (BPF_CORE_READ(&out->b123, &in->b[1][2][3])) if (CORE_READ(&out->b123, &in->b[1][2][3]))
return 1; return 1;
/* in->c[1].c */ /* in->c[1].c */
if (BPF_CORE_READ(&out->c1c, &in->c[1].c)) if (CORE_READ(&out->c1c, &in->c[1].c))
return 1; return 1;
/* in->d[0][0].d */ /* in->d[0][0].d */
if (BPF_CORE_READ(&out->d00d, &in->d[0][0].d)) if (CORE_READ(&out->d00d, &in->d[0][0].d))
return 1; return 1;
return 0; return 0;
......
...@@ -39,6 +39,8 @@ struct core_reloc_flavors___weird { ...@@ -39,6 +39,8 @@ struct core_reloc_flavors___weird {
}; };
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_flavors(void *ctx) int test_core_flavors(void *ctx)
{ {
...@@ -48,13 +50,13 @@ int test_core_flavors(void *ctx) ...@@ -48,13 +50,13 @@ int test_core_flavors(void *ctx)
struct core_reloc_flavors *out = (void *)&data.out; struct core_reloc_flavors *out = (void *)&data.out;
/* read a using weird layout */ /* read a using weird layout */
if (BPF_CORE_READ(&out->a, &in_weird->a)) if (CORE_READ(&out->a, &in_weird->a))
return 1; return 1;
/* read b using reversed layout */ /* read b using reversed layout */
if (BPF_CORE_READ(&out->b, &in_rev->b)) if (CORE_READ(&out->b, &in_rev->b))
return 1; return 1;
/* read c using original layout */ /* read c using original layout */
if (BPF_CORE_READ(&out->c, &in_orig->c)) if (CORE_READ(&out->c, &in_orig->c))
return 1; return 1;
return 0; return 0;
......
...@@ -23,20 +23,22 @@ struct core_reloc_ints { ...@@ -23,20 +23,22 @@ struct core_reloc_ints {
int64_t s64_field; int64_t s64_field;
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_ints(void *ctx) int test_core_ints(void *ctx)
{ {
struct core_reloc_ints *in = (void *)&data.in; struct core_reloc_ints *in = (void *)&data.in;
struct core_reloc_ints *out = (void *)&data.out; struct core_reloc_ints *out = (void *)&data.out;
if (BPF_CORE_READ(&out->u8_field, &in->u8_field) || if (CORE_READ(&out->u8_field, &in->u8_field) ||
BPF_CORE_READ(&out->s8_field, &in->s8_field) || CORE_READ(&out->s8_field, &in->s8_field) ||
BPF_CORE_READ(&out->u16_field, &in->u16_field) || CORE_READ(&out->u16_field, &in->u16_field) ||
BPF_CORE_READ(&out->s16_field, &in->s16_field) || CORE_READ(&out->s16_field, &in->s16_field) ||
BPF_CORE_READ(&out->u32_field, &in->u32_field) || CORE_READ(&out->u32_field, &in->u32_field) ||
BPF_CORE_READ(&out->s32_field, &in->s32_field) || CORE_READ(&out->s32_field, &in->s32_field) ||
BPF_CORE_READ(&out->u64_field, &in->u64_field) || CORE_READ(&out->u64_field, &in->u64_field) ||
BPF_CORE_READ(&out->s64_field, &in->s64_field)) CORE_READ(&out->s64_field, &in->s64_field))
return 1; return 1;
return 0; return 0;
......
...@@ -17,6 +17,8 @@ struct task_struct { ...@@ -17,6 +17,8 @@ struct task_struct {
int tgid; int tgid;
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_kernel(void *ctx) int test_core_kernel(void *ctx)
{ {
...@@ -24,8 +26,8 @@ int test_core_kernel(void *ctx) ...@@ -24,8 +26,8 @@ int test_core_kernel(void *ctx)
uint64_t pid_tgid = bpf_get_current_pid_tgid(); uint64_t pid_tgid = bpf_get_current_pid_tgid();
int pid, tgid; int pid, tgid;
if (BPF_CORE_READ(&pid, &task->pid) || if (CORE_READ(&pid, &task->pid) ||
BPF_CORE_READ(&tgid, &task->tgid)) CORE_READ(&tgid, &task->tgid))
return 1; return 1;
/* validate pid + tgid matches */ /* validate pid + tgid matches */
......
...@@ -32,6 +32,8 @@ struct core_reloc_misc_extensible { ...@@ -32,6 +32,8 @@ struct core_reloc_misc_extensible {
int b; int b;
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_misc(void *ctx) int test_core_misc(void *ctx)
{ {
...@@ -41,15 +43,15 @@ int test_core_misc(void *ctx) ...@@ -41,15 +43,15 @@ int test_core_misc(void *ctx)
struct core_reloc_misc_output *out = (void *)&data.out; struct core_reloc_misc_output *out = (void *)&data.out;
/* record two different relocations with the same accessor string */ /* record two different relocations with the same accessor string */
if (BPF_CORE_READ(&out->a, &in_a->a1) || /* accessor: 0:0 */ if (CORE_READ(&out->a, &in_a->a1) || /* accessor: 0:0 */
BPF_CORE_READ(&out->b, &in_b->b1)) /* accessor: 0:0 */ CORE_READ(&out->b, &in_b->b1)) /* accessor: 0:0 */
return 1; return 1;
/* Validate relocations capture array-only accesses for structs with /* Validate relocations capture array-only accesses for structs with
* fixed header, but with potentially extendable tail. This will read * fixed header, but with potentially extendable tail. This will read
* first 4 bytes of 2nd element of in_ext array of potentially * first 4 bytes of 2nd element of in_ext array of potentially
* variably sized struct core_reloc_misc_extensible. */ * variably sized struct core_reloc_misc_extensible. */
if (BPF_CORE_READ(&out->c, &in_ext[2])) /* accessor: 2 */ if (CORE_READ(&out->c, &in_ext[2])) /* accessor: 2 */
return 1; return 1;
return 0; return 0;
......
...@@ -41,20 +41,22 @@ struct core_reloc_mods { ...@@ -41,20 +41,22 @@ struct core_reloc_mods {
core_reloc_mods_substruct_t h; core_reloc_mods_substruct_t h;
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_mods(void *ctx) int test_core_mods(void *ctx)
{ {
struct core_reloc_mods *in = (void *)&data.in; struct core_reloc_mods *in = (void *)&data.in;
struct core_reloc_mods_output *out = (void *)&data.out; struct core_reloc_mods_output *out = (void *)&data.out;
if (BPF_CORE_READ(&out->a, &in->a) || if (CORE_READ(&out->a, &in->a) ||
BPF_CORE_READ(&out->b, &in->b) || CORE_READ(&out->b, &in->b) ||
BPF_CORE_READ(&out->c, &in->c) || CORE_READ(&out->c, &in->c) ||
BPF_CORE_READ(&out->d, &in->d) || CORE_READ(&out->d, &in->d) ||
BPF_CORE_READ(&out->e, &in->e[2]) || CORE_READ(&out->e, &in->e[2]) ||
BPF_CORE_READ(&out->f, &in->f[1]) || CORE_READ(&out->f, &in->f[1]) ||
BPF_CORE_READ(&out->g, &in->g.x) || CORE_READ(&out->g, &in->g.x) ||
BPF_CORE_READ(&out->h, &in->h.y)) CORE_READ(&out->h, &in->h.y))
return 1; return 1;
return 0; return 0;
......
...@@ -30,15 +30,17 @@ struct core_reloc_nesting { ...@@ -30,15 +30,17 @@ struct core_reloc_nesting {
} b; } b;
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_nesting(void *ctx) int test_core_nesting(void *ctx)
{ {
struct core_reloc_nesting *in = (void *)&data.in; struct core_reloc_nesting *in = (void *)&data.in;
struct core_reloc_nesting *out = (void *)&data.out; struct core_reloc_nesting *out = (void *)&data.out;
if (BPF_CORE_READ(&out->a.a.a, &in->a.a.a)) if (CORE_READ(&out->a.a.a, &in->a.a.a))
return 1; return 1;
if (BPF_CORE_READ(&out->b.b.b, &in->b.b.b)) if (CORE_READ(&out->b.b.b, &in->b.b.b))
return 1; return 1;
return 0; return 0;
......
...@@ -25,17 +25,19 @@ struct core_reloc_primitives { ...@@ -25,17 +25,19 @@ struct core_reloc_primitives {
int (*f)(const char *); int (*f)(const char *);
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_primitives(void *ctx) int test_core_primitives(void *ctx)
{ {
struct core_reloc_primitives *in = (void *)&data.in; struct core_reloc_primitives *in = (void *)&data.in;
struct core_reloc_primitives *out = (void *)&data.out; struct core_reloc_primitives *out = (void *)&data.out;
if (BPF_CORE_READ(&out->a, &in->a) || if (CORE_READ(&out->a, &in->a) ||
BPF_CORE_READ(&out->b, &in->b) || CORE_READ(&out->b, &in->b) ||
BPF_CORE_READ(&out->c, &in->c) || CORE_READ(&out->c, &in->c) ||
BPF_CORE_READ(&out->d, &in->d) || CORE_READ(&out->d, &in->d) ||
BPF_CORE_READ(&out->f, &in->f)) CORE_READ(&out->f, &in->f))
return 1; return 1;
return 0; return 0;
......
...@@ -16,13 +16,15 @@ struct core_reloc_ptr_as_arr { ...@@ -16,13 +16,15 @@ struct core_reloc_ptr_as_arr {
int a; int a;
}; };
#define CORE_READ(dst, src) bpf_core_read(dst, sizeof(*(dst)), src)
SEC("raw_tracepoint/sys_enter") SEC("raw_tracepoint/sys_enter")
int test_core_ptr_as_arr(void *ctx) int test_core_ptr_as_arr(void *ctx)
{ {
struct core_reloc_ptr_as_arr *in = (void *)&data.in; struct core_reloc_ptr_as_arr *in = (void *)&data.in;
struct core_reloc_ptr_as_arr *out = (void *)&data.out; struct core_reloc_ptr_as_arr *out = (void *)&data.out;
if (BPF_CORE_READ(&out->a, &in[2].a)) if (CORE_READ(&out->a, &in[2].a))
return 1; return 1;
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment