提交 5123662a 编写于 作者: K Kees Cook 提交者: Greg Kroah-Hartman

lkdtm: clean up sparse warnings

Since lkdtm intentionally does "bad" things, we need to convince sparse
that we're doing these things on purpose. This adds an explicit cast
to the call to copy_to_user() and marks the spin lock as expecting
to dead-lock.
Reported-by: NFengguang Wu <fengguang.wu@intel.com>
Signed-off-by: NKees Cook <keescook@chromium.org>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 36fe66c1
...@@ -334,9 +334,10 @@ static void execute_location(void *dst) ...@@ -334,9 +334,10 @@ static void execute_location(void *dst)
static void execute_user_location(void *dst) static void execute_user_location(void *dst)
{ {
/* Intentionally crossing kernel/user memory boundary. */
void (*func)(void) = dst; void (*func)(void) = dst;
if (copy_to_user(dst, do_nothing, EXEC_SIZE)) if (copy_to_user((void __user *)dst, do_nothing, EXEC_SIZE))
return; return;
func(); func();
} }
...@@ -408,6 +409,8 @@ static void lkdtm_do_action(enum ctype which) ...@@ -408,6 +409,8 @@ static void lkdtm_do_action(enum ctype which)
case CT_SPINLOCKUP: case CT_SPINLOCKUP:
/* Must be called twice to trigger. */ /* Must be called twice to trigger. */
spin_lock(&lock_me_up); spin_lock(&lock_me_up);
/* Let sparse know we intended to exit holding the lock. */
__release(&lock_me_up);
break; break;
case CT_HUNG_TASK: case CT_HUNG_TASK:
set_current_state(TASK_UNINTERRUPTIBLE); set_current_state(TASK_UNINTERRUPTIBLE);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册