Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp87638yba; Mon, 20 May 2019 05:29:55 -0700 (PDT) X-Google-Smtp-Source: APXvYqyTUb6YomgI3/m+IVeaWMKUWrV+nliWVLDvB0XVKTcAFqX/yFQjfZumPenZUyMeZd4uykzX X-Received: by 2002:aa7:9e51:: with SMTP id z17mr79473518pfq.212.1558355395380; Mon, 20 May 2019 05:29:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558355395; cv=none; d=google.com; s=arc-20160816; b=QhiOrsfs/SzrOr9QHse2beUKPcwk8qVpTL+8/Bxu87posImpNMc7wKUALHPeNAFjS9 Lb6I58jOboY16F4qc5z7fC/b8NL+CRu2clsAIa/sSCogH03hy/Y7Hf/32J/x/b2HvsUp 2HL6fa5/DETQdLmX+jVhzPIYXzZ3JIrBNYobvdVaq4aHupr+W79FVj4gzIhmvOHqcg68 ZsBe3E4k9PnAcZb4qv1HgqlKVoYr6KWjBQjk61/htm+0Fm2udmMC66egzv2FIj5bwHpG KyCTjQFPNROC7I1HATxC7pHD7volBjhHtpglk8doqAc3Tv3YUVtUfOfbL41kf1+b5zfC PDVg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=uzkecjGuo+kuZRdX2Q1qTrCn+C7UbXpf3TqxRhN3wrc=; b=KPlp/bACHWlerRqPu7wDSRoCDPDT2qppqRGaQ6Y8O9lO2SAJ8TcFN53Rxr4lTu4+7q pduioziqqEyF1/Pl9zsypCCdv3cJYq+bgP+DJUn6snR07H0k/fWrCRdoE4896PrFrkoa hENVLSgtZ7L9KvpIrmHRCed8dR3oRsVvP+llbnnsaiIP+XCFZ41NAdM7N0aw44fn0rH+ ftNQF4yJ1Tt+x9dym8cuwdRPWGfi4S36doWecurVX2M5o8N3FQuOGUWqM4X4ZG9W3Cbu moADtkSwdw5e9I9bEnV7d5ezczXIixp/KnKHKEQdFvIF6G8cbnwYd488Yt35HMX5grC6 +Nwg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=M98EDTkE; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w11si2378176plq.169.2019.05.20.05.29.41; Mon, 20 May 2019 05:29:55 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=M98EDTkE; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389609AbfETM2G (ORCPT + 99 others); Mon, 20 May 2019 08:28:06 -0400 Received: from mail.kernel.org ([198.145.29.99]:43670 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389599AbfETM2D (ORCPT ); Mon, 20 May 2019 08:28:03 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 6CA9C20645; Mon, 20 May 2019 12:28:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1558355282; bh=0KsKzMIexvgz/Ii/Ahfc7GkrA4itaRHT2VqE7RYhjWA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=M98EDTkE3+zPYErT15N1v+/kZrRgoYOoNmw4Q3bv5JpA0Iiy1Gwn/EpZVb5SIe3J0 HtCsF28HiO7t7nD99F3gjFYxdsqqkXFLR+pIO5jgbeaKIpbAkyFwP/ha88x3ruzckm yyJLb/McDKP1XcT15i+5MeXhX404SBYPPw6jWkPE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Julien Thierry , "Peter Zijlstra (Intel)" , Andy Lutomirski , Borislav Petkov , Josh Poimboeuf , Linus Torvalds , Thomas Gleixner , stable@kernel.org, Ingo Molnar Subject: [PATCH 5.0 019/123] sched/x86: Save [ER]FLAGS on context switch Date: Mon, 20 May 2019 14:13:19 +0200 Message-Id: <20190520115246.190287323@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190520115245.439864225@linuxfoundation.org> References: <20190520115245.439864225@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Peter Zijlstra commit 6690e86be83ac75832e461c141055b5d601c0a6d upstream. Effectively reverts commit: 2c7577a75837 ("sched/x86_64: Don't save flags on context switch") Specifically because SMAP uses FLAGS.AC which invalidates the claim that the kernel has clean flags. In particular; while preemption from interrupt return is fine (the IRET frame on the exception stack contains FLAGS) it breaks any code that does synchonous scheduling, including preempt_enable(). This has become a significant issue ever since commit: 5b24a7a2aa20 ("Add 'unsafe' user access functions for batched accesses") provided for means of having 'normal' C code between STAC / CLAC, exposing the FLAGS.AC state. So far this hasn't led to trouble, however fix it before it comes apart. Reported-by: Julien Thierry Signed-off-by: Peter Zijlstra (Intel) Acked-by: Andy Lutomirski Cc: Borislav Petkov Cc: Josh Poimboeuf Cc: Linus Torvalds Cc: Peter Zijlstra Cc: Thomas Gleixner Cc: stable@kernel.org Fixes: 5b24a7a2aa20 ("Add 'unsafe' user access functions for batched accesses") Signed-off-by: Ingo Molnar Signed-off-by: Greg Kroah-Hartman --- arch/x86/entry/entry_32.S | 2 ++ arch/x86/entry/entry_64.S | 2 ++ arch/x86/include/asm/switch_to.h | 1 + arch/x86/kernel/process_32.c | 7 +++++++ arch/x86/kernel/process_64.c | 8 ++++++++ 5 files changed, 20 insertions(+) --- a/arch/x86/entry/entry_32.S +++ b/arch/x86/entry/entry_32.S @@ -650,6 +650,7 @@ ENTRY(__switch_to_asm) pushl %ebx pushl %edi pushl %esi + pushfl /* switch stack */ movl %esp, TASK_threadsp(%eax) @@ -672,6 +673,7 @@ ENTRY(__switch_to_asm) #endif /* restore callee-saved registers */ + popfl popl %esi popl %edi popl %ebx --- a/arch/x86/entry/entry_64.S +++ b/arch/x86/entry/entry_64.S @@ -291,6 +291,7 @@ ENTRY(__switch_to_asm) pushq %r13 pushq %r14 pushq %r15 + pushfq /* switch stack */ movq %rsp, TASK_threadsp(%rdi) @@ -313,6 +314,7 @@ ENTRY(__switch_to_asm) #endif /* restore callee-saved registers */ + popfq popq %r15 popq %r14 popq %r13 --- a/arch/x86/include/asm/switch_to.h +++ b/arch/x86/include/asm/switch_to.h @@ -40,6 +40,7 @@ asmlinkage void ret_from_fork(void); * order of the fields must match the code in __switch_to_asm(). */ struct inactive_task_frame { + unsigned long flags; #ifdef CONFIG_X86_64 unsigned long r15; unsigned long r14; --- a/arch/x86/kernel/process_32.c +++ b/arch/x86/kernel/process_32.c @@ -127,6 +127,13 @@ int copy_thread_tls(unsigned long clone_ struct task_struct *tsk; int err; + /* + * For a new task use the RESET flags value since there is no before. + * All the status flags are zero; DF and all the system flags must also + * be 0, specifically IF must be 0 because we context switch to the new + * task with interrupts disabled. + */ + frame->flags = X86_EFLAGS_FIXED; frame->bp = 0; frame->ret_addr = (unsigned long) ret_from_fork; p->thread.sp = (unsigned long) fork_frame; --- a/arch/x86/kernel/process_64.c +++ b/arch/x86/kernel/process_64.c @@ -392,6 +392,14 @@ int copy_thread_tls(unsigned long clone_ childregs = task_pt_regs(p); fork_frame = container_of(childregs, struct fork_frame, regs); frame = &fork_frame->frame; + + /* + * For a new task use the RESET flags value since there is no before. + * All the status flags are zero; DF and all the system flags must also + * be 0, specifically IF must be 0 because we context switch to the new + * task with interrupts disabled. + */ + frame->flags = X86_EFLAGS_FIXED; frame->bp = 0; frame->ret_addr = (unsigned long) ret_from_fork; p->thread.sp = (unsigned long) fork_frame;