OSDN Git Service

signal/vm86_32: Replace open coded BUG_ON with an actual BUG_ON
authorEric W. Biederman <ebiederm@xmission.com>
Wed, 20 Oct 2021 17:43:55 +0000 (12:43 -0500)
committerEric W. Biederman <ebiederm@xmission.com>
Mon, 25 Oct 2021 20:56:29 +0000 (15:56 -0500)
The function save_v86_state is only called when userspace was
operating in vm86 mode before entering the kernel.  Not having vm86
state in the task_struct should never happen.  So transform the hand
rolled BUG_ON into an actual BUG_ON to make it clear what is
happening.

Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Borislav Petkov <bp@alien8.de>
Cc: x86@kernel.org
Cc: H Peter Anvin <hpa@zytor.com>
Link: https://lkml.kernel.org/r/20211020174406.17889-9-ebiederm@xmission.com
Signed-off-by: Eric W. Biederman <ebiederm@xmission.com>
arch/x86/kernel/vm86_32.c

index e5a7a10..63486da 100644 (file)
@@ -106,10 +106,8 @@ void save_v86_state(struct kernel_vm86_regs *regs, int retval)
         */
        local_irq_enable();
 
-       if (!vm86 || !vm86->user_vm86) {
-               pr_alert("no user_vm86: BAD\n");
-               do_exit(SIGSEGV);
-       }
+       BUG_ON(!vm86 || !vm86->user_vm86);
+
        set_flags(regs->pt.flags, VEFLAGS, X86_EFLAGS_VIF | vm86->veflags_mask);
        user = vm86->user_vm86;