mirror of
git://git.yoctoproject.org/linux-yocto.git
synced 2025-10-22 23:13:01 +02:00
lib/test_stackinit: Fix static initializer test
commitf9398f1560
upstream. The static initializer test got accidentally converted to a dynamic initializer. Fix this and retain the giant padding hole without using an aligned struct member. Fixes:50ceaa95ea
("lib: Introduce test_stackinit module") Cc: Ard Biesheuvel <ardb@kernel.org> Cc: stable@vger.kernel.org Signed-off-by: Kees Cook <keescook@chromium.org> Link: https://lore.kernel.org/r/20210723221933.3431999-2-keescook@chromium.org Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
00cdb2fb4d
commit
5944d0e2b0
|
@ -67,10 +67,10 @@ static bool range_contains(char *haystack_start, size_t haystack_size,
|
||||||
#define INIT_STRUCT_none /**/
|
#define INIT_STRUCT_none /**/
|
||||||
#define INIT_STRUCT_zero = { }
|
#define INIT_STRUCT_zero = { }
|
||||||
#define INIT_STRUCT_static_partial = { .two = 0, }
|
#define INIT_STRUCT_static_partial = { .two = 0, }
|
||||||
#define INIT_STRUCT_static_all = { .one = arg->one, \
|
#define INIT_STRUCT_static_all = { .one = 0, \
|
||||||
.two = arg->two, \
|
.two = 0, \
|
||||||
.three = arg->three, \
|
.three = 0, \
|
||||||
.four = arg->four, \
|
.four = 0, \
|
||||||
}
|
}
|
||||||
#define INIT_STRUCT_dynamic_partial = { .two = arg->two, }
|
#define INIT_STRUCT_dynamic_partial = { .two = arg->two, }
|
||||||
#define INIT_STRUCT_dynamic_all = { .one = arg->one, \
|
#define INIT_STRUCT_dynamic_all = { .one = arg->one, \
|
||||||
|
@ -84,8 +84,7 @@ static bool range_contains(char *haystack_start, size_t haystack_size,
|
||||||
var.one = 0; \
|
var.one = 0; \
|
||||||
var.two = 0; \
|
var.two = 0; \
|
||||||
var.three = 0; \
|
var.three = 0; \
|
||||||
memset(&var.four, 0, \
|
var.four = 0
|
||||||
sizeof(var.four))
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @name: unique string name for the test
|
* @name: unique string name for the test
|
||||||
|
@ -210,18 +209,13 @@ struct test_small_hole {
|
||||||
unsigned long four;
|
unsigned long four;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Try to trigger unhandled padding in a structure. */
|
/* Trigger unhandled padding in a structure. */
|
||||||
struct test_aligned {
|
|
||||||
u32 internal1;
|
|
||||||
u64 internal2;
|
|
||||||
} __aligned(64);
|
|
||||||
|
|
||||||
struct test_big_hole {
|
struct test_big_hole {
|
||||||
u8 one;
|
u8 one;
|
||||||
u8 two;
|
u8 two;
|
||||||
u8 three;
|
u8 three;
|
||||||
/* 61 byte padding hole here. */
|
/* 61 byte padding hole here. */
|
||||||
struct test_aligned four;
|
u8 four __aligned(64);
|
||||||
} __aligned(64);
|
} __aligned(64);
|
||||||
|
|
||||||
struct test_trailing_hole {
|
struct test_trailing_hole {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user