Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp1635901pxb; Fri, 13 Nov 2020 19:32:42 -0800 (PST) X-Google-Smtp-Source: ABdhPJwtK9DKpgnQVlWBqkBQHcVRZ5hADqvQ6KGHBaAnRcXiOZU/ZQpbxujCWYrteEunE1iCcJxD X-Received: by 2002:a05:6402:a46:: with SMTP id bt6mr6082722edb.101.1605324761903; Fri, 13 Nov 2020 19:32:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605324761; cv=none; d=google.com; s=arc-20160816; b=MEitJNfqLKeqgQlO7Wi0x9G4/BvxPzoaHxnPLZcnf4OSq2Oh6zJrcf0Unhf6Azg+ht TmQiyVh2BCoRQQ5mLdFHROMcBdtX4LX4ZNEHRaEkwZcCglsrqqdVWiRVtuSyMyLxJWXH D/C51v7e3FY/LKzwUCf5p7KP4InMkOFlbtHlC2wkrLl+38fDuLjWSkSGgb7fVKOGpaXF r+0IrzsNvrgArKYBYgeK9fTB5FaA654l4KSHazeDiI/jJT6kek8IalaZTsycpmMwoO7A X1Rb/LlE0y2ikBuf28ROFNTCjj2hN53hNxml5x+jMdPXS9pmY7p3o59n2/+BWG2m17kV gJlg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=lOKDDkAswu+FcFoCkVN9XXGu2A32VQ7y08s6kVzZguY=; b=Up2li/1KcUmRQxKHFU2NT1Y+urDeQVkKnMOATjFPysn9SniAd1HvIDIEu8et7PLWvn z/mZebCgNFBnpfflGeU31hmmmu/HCVNLsMvrFtRSWasXMt2RVgMGh9AOVQFXBsGDFvqg YwFWQyB/9rziRxDyMjemGyxH/ZxTwriXJuELv095g0KdWDh68sDrp6+T35G3z+jsPeee fMN3M3psfnoyurZs22JbGLMRWxv3yvqqC39ocadAs7HqJcj7sj2Zu3fch9ChqBAbM1mp +SxyzW/FswrToiOKOFsZ8ZM0iYQwjyCuQtxdX9E7ggnYtY5sA8nejZQ7U6KVq89ze+gt 8Oeg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bx14si7407883edb.13.2020.11.13.19.32.19; Fri, 13 Nov 2020 19:32:41 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726449AbgKND3v (ORCPT + 99 others); Fri, 13 Nov 2020 22:29:51 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40074 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725981AbgKND3v (ORCPT ); Fri, 13 Nov 2020 22:29:51 -0500 Received: from bhuna.collabora.co.uk (bhuna.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e3e3]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F2411C0613D1; Fri, 13 Nov 2020 19:29:50 -0800 (PST) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: krisman) with ESMTPSA id 8C8C51F479A9 From: Gabriel Krisman Bertazi To: tglx@linutronix.de Cc: mingo@redhat.com, keescook@chromium.org, arnd@arndb.de, luto@amacapital.net, wad@chromium.org, rostedt@goodmis.org, paul@paul-moore.com, eparis@redhat.com, oleg@redhat.com, linux-arch@vger.kernel.org, linux-kernel@vger.kernel.org, x86@kernel.org, Gabriel Krisman Bertazi , kernel@collabora.com Subject: [PATCH 03/10] kernel: entry: Wire up syscall_work in common entry code Date: Fri, 13 Nov 2020 22:29:10 -0500 Message-Id: <20201114032917.1205658-4-krisman@collabora.com> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201114032917.1205658-1-krisman@collabora.com> References: <20201114032917.1205658-1-krisman@collabora.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Prepares the common entry code to use the SYSCALL_WORK flags. They will be defined in subsequent patches for each type of syscall work. SYSCALL_WORK_ENTRY/EXIT are defined for the transition, as they will replace the TIF_ equivalent defines. Signed-off-by: Gabriel Krisman Bertazi --- include/linux/entry-common.h | 3 +++ kernel/entry/common.c | 15 +++++++++------ 2 files changed, 12 insertions(+), 6 deletions(-) diff --git a/include/linux/entry-common.h b/include/linux/entry-common.h index 1a128baf3628..cbc5c702ee4d 100644 --- a/include/linux/entry-common.h +++ b/include/linux/entry-common.h @@ -64,6 +64,9 @@ (_TIF_SYSCALL_TRACE | _TIF_SYSCALL_AUDIT | \ _TIF_SYSCALL_TRACEPOINT | ARCH_SYSCALL_EXIT_WORK) +#define SYSCALL_WORK_ENTER (0) +#define SYSCALL_WORK_EXIT (0) + /* * TIF flags handled in exit_to_user_mode_loop() */ diff --git a/kernel/entry/common.c b/kernel/entry/common.c index bc75c114c1b3..5a4bb72ff28e 100644 --- a/kernel/entry/common.c +++ b/kernel/entry/common.c @@ -42,7 +42,7 @@ static inline void syscall_enter_audit(struct pt_regs *regs, long syscall) } static long syscall_trace_enter(struct pt_regs *regs, long syscall, - unsigned long ti_work) + unsigned long ti_work, unsigned long work) { long ret = 0; @@ -75,10 +75,11 @@ static __always_inline long __syscall_enter_from_user_work(struct pt_regs *regs, long syscall) { unsigned long ti_work; + unsigned long work = READ_ONCE(current_thread_info()->syscall_work); ti_work = READ_ONCE(current_thread_info()->flags); - if (ti_work & SYSCALL_ENTER_WORK) - syscall = syscall_trace_enter(regs, syscall, ti_work); + if (work & SYSCALL_WORK_ENTER || ti_work & SYSCALL_ENTER_WORK) + syscall = syscall_trace_enter(regs, syscall, ti_work, work); return syscall; } @@ -225,7 +226,8 @@ static inline bool report_single_step(unsigned long ti_work) } #endif -static void syscall_exit_work(struct pt_regs *regs, unsigned long ti_work) +static void syscall_exit_work(struct pt_regs *regs, unsigned long ti_work, + unsigned long work) { bool step; @@ -246,6 +248,7 @@ static void syscall_exit_work(struct pt_regs *regs, unsigned long ti_work) static void syscall_exit_to_user_mode_prepare(struct pt_regs *regs) { u32 cached_flags = READ_ONCE(current_thread_info()->flags); + unsigned long work = READ_ONCE(current_thread_info()->syscall_work); unsigned long nr = syscall_get_nr(current, regs); CT_WARN_ON(ct_state() != CONTEXT_KERNEL); @@ -262,8 +265,8 @@ static void syscall_exit_to_user_mode_prepare(struct pt_regs *regs) * enabled, we want to run them exactly once per syscall exit with * interrupts enabled. */ - if (unlikely(cached_flags & SYSCALL_EXIT_WORK)) - syscall_exit_work(regs, cached_flags); + if (unlikely(work & SYSCALL_WORK_EXIT || cached_flags & SYSCALL_EXIT_WORK)) + syscall_exit_work(regs, cached_flags, work); } __visible noinstr void syscall_exit_to_user_mode(struct pt_regs *regs) -- 2.29.2