selftests/bpf: Correct various core_reloc 64-bit assumptions

Ensure that types are memory layout- and field alignment-compatible regardless
of 32/64-bitness mix of libbpf and BPF architecture.

Signed-off-by: Andrii Nakryiko <andriin@fb.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Link: https://lore.kernel.org/bpf/20200813204945.1020225-8-andriin@fb.com
This commit is contained in:
Andrii Nakryiko 2020-08-13 13:49:43 -07:00 committed by Alexei Starovoitov
parent 4c01925f58
commit 5705d70583
2 changed files with 47 additions and 42 deletions

View File

@ -237,8 +237,8 @@
.union_sz = sizeof(((type *)0)->union_field), \ .union_sz = sizeof(((type *)0)->union_field), \
.arr_sz = sizeof(((type *)0)->arr_field), \ .arr_sz = sizeof(((type *)0)->arr_field), \
.arr_elem_sz = sizeof(((type *)0)->arr_field[0]), \ .arr_elem_sz = sizeof(((type *)0)->arr_field[0]), \
.ptr_sz = sizeof(((type *)0)->ptr_field), \ .ptr_sz = 8, /* always 8-byte pointer for BPF */ \
.enum_sz = sizeof(((type *)0)->enum_field), \ .enum_sz = sizeof(((type *)0)->enum_field), \
} }
#define SIZE_CASE(name) { \ #define SIZE_CASE(name) { \
@ -432,20 +432,20 @@ static struct core_reloc_test_case test_cases[] = {
.sb4 = -1, .sb4 = -1,
.sb20 = -0x17654321, .sb20 = -0x17654321,
.u32 = 0xBEEF, .u32 = 0xBEEF,
.s32 = -0x3FEDCBA987654321, .s32 = -0x3FEDCBA987654321LL,
}), }),
BITFIELDS_CASE(bitfields___bitfield_vs_int, { BITFIELDS_CASE(bitfields___bitfield_vs_int, {
.ub1 = 0xFEDCBA9876543210, .ub1 = 0xFEDCBA9876543210LL,
.ub2 = 0xA6, .ub2 = 0xA6,
.ub7 = -0x7EDCBA987654321, .ub7 = -0x7EDCBA987654321LL,
.sb4 = -0x6123456789ABCDE, .sb4 = -0x6123456789ABCDELL,
.sb20 = 0xD00D, .sb20 = 0xD00DLL,
.u32 = -0x76543, .u32 = -0x76543,
.s32 = 0x0ADEADBEEFBADB0B, .s32 = 0x0ADEADBEEFBADB0BLL,
}), }),
BITFIELDS_CASE(bitfields___just_big_enough, { BITFIELDS_CASE(bitfields___just_big_enough, {
.ub1 = 0xF, .ub1 = 0xFLL,
.ub2 = 0x0812345678FEDCBA, .ub2 = 0x0812345678FEDCBALL,
}), }),
BITFIELDS_ERR_CASE(bitfields___err_too_big_bitfield), BITFIELDS_ERR_CASE(bitfields___err_too_big_bitfield),

View File

@ -1,5 +1,10 @@
#include <stdint.h> #include <stdint.h>
#include <stdbool.h> #include <stdbool.h>
void preserce_ptr_sz_fn(long x) {}
#define __bpf_aligned __attribute__((aligned(8)))
/* /*
* KERNEL * KERNEL
*/ */
@ -444,51 +449,51 @@ struct core_reloc_primitives {
char a; char a;
int b; int b;
enum core_reloc_primitives_enum c; enum core_reloc_primitives_enum c;
void *d; void *d __bpf_aligned;
int (*f)(const char *); int (*f)(const char *) __bpf_aligned;
}; };
struct core_reloc_primitives___diff_enum_def { struct core_reloc_primitives___diff_enum_def {
char a; char a;
int b; int b;
void *d; void *d __bpf_aligned;
int (*f)(const char *); int (*f)(const char *) __bpf_aligned;
enum { enum {
X = 100, X = 100,
Y = 200, Y = 200,
} c; /* inline enum def with differing set of values */ } c __bpf_aligned; /* inline enum def with differing set of values */
}; };
struct core_reloc_primitives___diff_func_proto { struct core_reloc_primitives___diff_func_proto {
void (*f)(int); /* incompatible function prototype */ void (*f)(int) __bpf_aligned; /* incompatible function prototype */
void *d; void *d __bpf_aligned;
enum core_reloc_primitives_enum c; enum core_reloc_primitives_enum c __bpf_aligned;
int b; int b;
char a; char a;
}; };
struct core_reloc_primitives___diff_ptr_type { struct core_reloc_primitives___diff_ptr_type {
const char * const d; /* different pointee type + modifiers */ const char * const d __bpf_aligned; /* different pointee type + modifiers */
char a; char a __bpf_aligned;
int b; int b;
enum core_reloc_primitives_enum c; enum core_reloc_primitives_enum c;
int (*f)(const char *); int (*f)(const char *) __bpf_aligned;
}; };
struct core_reloc_primitives___err_non_enum { struct core_reloc_primitives___err_non_enum {
char a[1]; char a[1];
int b; int b;
int c; /* int instead of enum */ int c; /* int instead of enum */
void *d; void *d __bpf_aligned;
int (*f)(const char *); int (*f)(const char *) __bpf_aligned;
}; };
struct core_reloc_primitives___err_non_int { struct core_reloc_primitives___err_non_int {
char a[1]; char a[1];
int *b; /* ptr instead of int */ int *b __bpf_aligned; /* ptr instead of int */
enum core_reloc_primitives_enum c; enum core_reloc_primitives_enum c __bpf_aligned;
void *d; void *d __bpf_aligned;
int (*f)(const char *); int (*f)(const char *) __bpf_aligned;
}; };
struct core_reloc_primitives___err_non_ptr { struct core_reloc_primitives___err_non_ptr {
@ -496,7 +501,7 @@ struct core_reloc_primitives___err_non_ptr {
int b; int b;
enum core_reloc_primitives_enum c; enum core_reloc_primitives_enum c;
int d; /* int instead of ptr */ int d; /* int instead of ptr */
int (*f)(const char *); int (*f)(const char *) __bpf_aligned;
}; };
/* /*
@ -507,7 +512,7 @@ struct core_reloc_mods_output {
}; };
typedef const int int_t; typedef const int int_t;
typedef const char *char_ptr_t; typedef const char *char_ptr_t __bpf_aligned;
typedef const int arr_t[7]; typedef const int arr_t[7];
struct core_reloc_mods_substruct { struct core_reloc_mods_substruct {
@ -523,9 +528,9 @@ typedef struct {
struct core_reloc_mods { struct core_reloc_mods {
int a; int a;
int_t b; int_t b;
char *c; char *c __bpf_aligned;
char_ptr_t d; char_ptr_t d;
int e[3]; int e[3] __bpf_aligned;
arr_t f; arr_t f;
struct core_reloc_mods_substruct g; struct core_reloc_mods_substruct g;
core_reloc_mods_substruct_t h; core_reloc_mods_substruct_t h;
@ -535,9 +540,9 @@ struct core_reloc_mods {
struct core_reloc_mods___mod_swap { struct core_reloc_mods___mod_swap {
int b; int b;
int_t a; int_t a;
char *d; char *d __bpf_aligned;
char_ptr_t c; char_ptr_t c;
int f[3]; int f[3] __bpf_aligned;
arr_t e; arr_t e;
struct { struct {
int y; int y;
@ -555,7 +560,7 @@ typedef arr1_t arr2_t;
typedef arr2_t arr3_t; typedef arr2_t arr3_t;
typedef arr3_t arr4_t; typedef arr3_t arr4_t;
typedef const char * const volatile fancy_char_ptr_t; typedef const char * const volatile fancy_char_ptr_t __bpf_aligned;
typedef core_reloc_mods_substruct_t core_reloc_mods_substruct_tt; typedef core_reloc_mods_substruct_t core_reloc_mods_substruct_tt;
@ -567,7 +572,7 @@ struct core_reloc_mods___typedefs {
arr4_t e; arr4_t e;
fancy_char_ptr_t d; fancy_char_ptr_t d;
fancy_char_ptr_t c; fancy_char_ptr_t c;
int3_t b; int3_t b __bpf_aligned;
int3_t a; int3_t a;
}; };
@ -739,19 +744,19 @@ struct core_reloc_bitfields___bit_sz_change {
int8_t sb4: 1; /* 4 -> 1 */ int8_t sb4: 1; /* 4 -> 1 */
int32_t sb20: 30; /* 20 -> 30 */ int32_t sb20: 30; /* 20 -> 30 */
/* non-bitfields */ /* non-bitfields */
uint16_t u32; /* 32 -> 16 */ uint16_t u32; /* 32 -> 16 */
int64_t s32; /* 32 -> 64 */ int64_t s32 __bpf_aligned; /* 32 -> 64 */
}; };
/* turn bitfield into non-bitfield and vice versa */ /* turn bitfield into non-bitfield and vice versa */
struct core_reloc_bitfields___bitfield_vs_int { struct core_reloc_bitfields___bitfield_vs_int {
uint64_t ub1; /* 3 -> 64 non-bitfield */ uint64_t ub1; /* 3 -> 64 non-bitfield */
uint8_t ub2; /* 20 -> 8 non-bitfield */ uint8_t ub2; /* 20 -> 8 non-bitfield */
int64_t ub7; /* 7 -> 64 non-bitfield signed */ int64_t ub7 __bpf_aligned; /* 7 -> 64 non-bitfield signed */
int64_t sb4; /* 4 -> 64 non-bitfield signed */ int64_t sb4 __bpf_aligned; /* 4 -> 64 non-bitfield signed */
uint64_t sb20; /* 20 -> 16 non-bitfield unsigned */ uint64_t sb20 __bpf_aligned; /* 20 -> 16 non-bitfield unsigned */
int32_t u32: 20; /* 32 non-bitfield -> 20 bitfield */ int32_t u32: 20; /* 32 non-bitfield -> 20 bitfield */
uint64_t s32: 60; /* 32 non-bitfield -> 60 bitfield */ uint64_t s32: 60 __bpf_aligned; /* 32 non-bitfield -> 60 bitfield */
}; };
struct core_reloc_bitfields___just_big_enough { struct core_reloc_bitfields___just_big_enough {