Commit 4f198289 authored by Kees Cook's avatar Kees Cook Committed by Greg Kroah-Hartman

lkdtm: fix stack protector trigger

The -fstack-protector compiler flag will only build stack protections if
a character array is seen. Additionally, the offset to the saved
instruction pointer changes based on architecture, so stomp much harder
(64 bytes) when corrupting the stack.
Signed-off-by: default avatarKees Cook <keescook@chromium.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 7b5d4122
...@@ -295,10 +295,10 @@ static void lkdtm_do_action(enum ctype which) ...@@ -295,10 +295,10 @@ static void lkdtm_do_action(enum ctype which)
(void) recursive_loop(0); (void) recursive_loop(0);
break; break;
case CT_CORRUPT_STACK: { case CT_CORRUPT_STACK: {
volatile u32 data[8]; /* Make sure the compiler creates and uses an 8 char array. */
volatile u32 *p = data; volatile char data[8];
p[12] = 0x12345678; memset((void *)data, 0, 64);
break; break;
} }
case CT_UNALIGNED_LOAD_STORE_WRITE: { case CT_UNALIGNED_LOAD_STORE_WRITE: {
......
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