Commit 1ee170ea authored by Kees Cook's avatar Kees Cook

lkdtm: Split WARNING into separate tests

There are three paths through the kernel code exception logging:

- BUG (no configurable printk message)
- WARN_ON (no configurable printk message)
- WARN (configurable printk message)

LKDTM was not testing WARN_ON(). This is needed to evaluate the placement
of the "cut here" line, which needs special handling in each of the
three exceptions (and between architectures that implement instruction
exceptions to implement the code exceptions).
Signed-off-by: default avatarKees Cook <keescook@chromium.org>
parent b0eb93cf
...@@ -75,7 +75,12 @@ static int warn_counter; ...@@ -75,7 +75,12 @@ static int warn_counter;
void lkdtm_WARNING(void) void lkdtm_WARNING(void)
{ {
WARN(1, "Warning message trigger count: %d\n", warn_counter++); WARN_ON(++warn_counter);
}
void lkdtm_WARNING_MESSAGE(void)
{
WARN(1, "Warning message trigger count: %d\n", ++warn_counter);
} }
void lkdtm_EXCEPTION(void) void lkdtm_EXCEPTION(void)
......
...@@ -104,6 +104,7 @@ static const struct crashtype crashtypes[] = { ...@@ -104,6 +104,7 @@ static const struct crashtype crashtypes[] = {
CRASHTYPE(PANIC), CRASHTYPE(PANIC),
CRASHTYPE(BUG), CRASHTYPE(BUG),
CRASHTYPE(WARNING), CRASHTYPE(WARNING),
CRASHTYPE(WARNING_MESSAGE),
CRASHTYPE(EXCEPTION), CRASHTYPE(EXCEPTION),
CRASHTYPE(LOOP), CRASHTYPE(LOOP),
CRASHTYPE(EXHAUST_STACK), CRASHTYPE(EXHAUST_STACK),
......
...@@ -11,6 +11,7 @@ void __init lkdtm_bugs_init(int *recur_param); ...@@ -11,6 +11,7 @@ void __init lkdtm_bugs_init(int *recur_param);
void lkdtm_PANIC(void); void lkdtm_PANIC(void);
void lkdtm_BUG(void); void lkdtm_BUG(void);
void lkdtm_WARNING(void); void lkdtm_WARNING(void);
void lkdtm_WARNING_MESSAGE(void);
void lkdtm_EXCEPTION(void); void lkdtm_EXCEPTION(void);
void lkdtm_LOOP(void); void lkdtm_LOOP(void);
void lkdtm_EXHAUST_STACK(void); void lkdtm_EXHAUST_STACK(void);
......
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