Received: by 2002:a05:6a10:9afc:0:0:0:0 with SMTP id t28csp308007pxm; Wed, 2 Mar 2022 16:01:08 -0800 (PST) X-Google-Smtp-Source: ABdhPJxQSRG7p6+LddxjFhJ2ktkyZBWMy5cyIzkffevuD2zGLKyp/jAPVHwYqYmKOT8tln/lvIPk X-Received: by 2002:a05:6871:4207:b0:d7:39a0:feb4 with SMTP id li7-20020a056871420700b000d739a0feb4mr2005283oab.110.1646265668262; Wed, 02 Mar 2022 16:01:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1646265668; cv=none; d=google.com; s=arc-20160816; b=koQJ0XdWLyQCtp5Ca0Mc3BfsIklku8mXVwbqBdiFV7YqmxxsoK0VudMW6h+DbQ4si1 j0sOv01Mqb91Ghkz973hzcNJYhaeiPxouNfAPnGrhljNgad/7tmhzWPIbxNp/AbyQRyi 5Ekz8TnjlDUwBMuww9v+bQq+Xy2maOZHT0Lkx7aTxFKYxDIJ0XTm7YOTQIcblxF8vfnt DHAlByOP5jrSCHXg0REhxxYfzED07hnIJboVObzkeQt/eYJyOLawd+hiEXviQBGBBvji NtQG+vBGGL28Syn+mzzJlL2e8Wdbt/xnwcvWLvc5wF8UqTXTPQRwD6v+a7S7yzF6xY3v hShA== 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 :dkim-signature; bh=giwbXSzSoehC/9vwhpl2T8Bw+JAxRwtOo3PVoCeVKVU=; b=s6udj1IAkUbNBNs0NrG2RC9CnAvzusEnlZONA6/wcJ20+uIpChXy0LzdZtplw6pfxe IfCpY2SG0ojQNv1DbZHqVQNWszVZzwY2Q1ZJs0adhVSdp9hSE7xjJuIsw4BGSvaQsaEK neLCD7/kRu57y6kSCux4FeD5zwip1MMK8ZPmVyFPFEH3iyHc2DcY+DRyDBfjx+Nkb5PP lHf15P1Jx01YWX8yT3QvE2CE1XhprW7AGucsXGlbJEhDe5ONqYkLdWw4vuo+Rq9NUj3K Ear0SxGhYbkpx3yFmBcC6oQHzUHIMrbpXzSlPDiFq/enEq3H42sxmi7rOoiso0g/MOmL PC4w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=PMa3KGaR; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id j7-20020a9d7f07000000b005afaed719d7si340026otq.206.2022.03.02.16.01.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 02 Mar 2022 16:01:08 -0800 (PST) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=PMa3KGaR; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (out1.vger.email [IPv6:2620:137:e000::1:20]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A3E7619E711; Wed, 2 Mar 2022 15:20:27 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240816AbiCBPtW (ORCPT + 99 others); Wed, 2 Mar 2022 10:49:22 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53342 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240739AbiCBPtS (ORCPT ); Wed, 2 Mar 2022 10:49:18 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 624AE28992 for ; Wed, 2 Mar 2022 07:48:27 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 0B507B82082 for ; Wed, 2 Mar 2022 15:48:26 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 995BFC340ED; Wed, 2 Mar 2022 15:48:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1646236104; bh=xdaFWjEPuZZ7+O1T/pWENcxRLDLAM4Um3CNcb2LkEbM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=PMa3KGaRCHoapiIry4hesvZv+djJ4pqgxEX7ey67y9R4tpzGS5PBCkEAJtqc6G0C6 L9tTHPwiYoZBVFGUfUvP2I4W+xoTje7eej2JD459RaU5LSlAIAnKVf4tMhj99pfifs zEm2xbjziErlN3Qe6cqeNUDsToJM62L4NEMQznEJo6lrw9NOrJydE92tzKlqGEYxXI oZvjdW9t3uXcOhn2SOaJLKYgYKoJWuO5DMvU0I2LYqWHrbZ19e7XFuLEkpwboR2IRK 2MkZFTzEFvaCzYaywC/19mJ4xgNDzs9ytWXEKiwtcCiQc7C8cSNnBINa1JzrXXepql rhRB2c7TyL5qA== From: Frederic Weisbecker To: LKML Cc: Frederic Weisbecker , Peter Zijlstra , Phil Auld , Alex Belits , Nicolas Saenz Julienne , Xiongfeng Wang , Neeraj Upadhyay , Thomas Gleixner , Yu Liao , Boqun Feng , "Paul E . McKenney" , Marcelo Tosatti , Paul Gortmaker , Uladzislau Rezki , Joel Fernandes Subject: [PATCH 02/19] context_tracking: Rename context_tracking_user_enter/exit() to user_enter/exit_callable() Date: Wed, 2 Mar 2022 16:47:53 +0100 Message-Id: <20220302154810.42308-3-frederic@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220302154810.42308-1-frederic@kernel.org> References: <20220302154810.42308-1-frederic@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,MAILING_LIST_MULTI, RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org context_tracking_user_enter() and context_tracking_user_exit() are ASM callable versions of user_enter() and user_exit() for architectures that didn't manage to check the context tracking static key from ASM. Change those function names to better reflect their purpose. Signed-off-by: Frederic Weisbecker Cc: Paul E. McKenney Cc: Peter Zijlstra Cc: Thomas Gleixner Cc: Neeraj Upadhyay Cc: Uladzislau Rezki Cc: Joel Fernandes Cc: Boqun Feng Cc: Nicolas Saenz Julienne Cc: Marcelo Tosatti Cc: Xiongfeng Wang Cc: Yu Liao Cc: Phil Auld Cc: Paul Gortmaker Cc: Alex Belits --- arch/arm/kernel/entry-header.S | 8 ++++---- arch/csky/kernel/entry.S | 4 ++-- arch/riscv/kernel/entry.S | 6 +++--- include/linux/context_tracking.h | 4 ++-- kernel/context_tracking.c | 18 ++++++++++++++---- 5 files changed, 25 insertions(+), 15 deletions(-) diff --git a/arch/arm/kernel/entry-header.S b/arch/arm/kernel/entry-header.S index ae24dd54e9ef..3af2a521e1d6 100644 --- a/arch/arm/kernel/entry-header.S +++ b/arch/arm/kernel/entry-header.S @@ -364,10 +364,10 @@ #ifdef CONFIG_CONTEXT_TRACKING .if \save stmdb sp!, {r0-r3, ip, lr} - bl context_tracking_user_exit + bl user_exit_callable ldmia sp!, {r0-r3, ip, lr} .else - bl context_tracking_user_exit + bl user_exit_callable .endif #endif .endm @@ -376,10 +376,10 @@ #ifdef CONFIG_CONTEXT_TRACKING .if \save stmdb sp!, {r0-r3, ip, lr} - bl context_tracking_user_enter + bl user_enter_callable ldmia sp!, {r0-r3, ip, lr} .else - bl context_tracking_user_enter + bl user_enter_callable .endif #endif .endm diff --git a/arch/csky/kernel/entry.S b/arch/csky/kernel/entry.S index a4ababf25e24..bc734d17c16f 100644 --- a/arch/csky/kernel/entry.S +++ b/arch/csky/kernel/entry.S @@ -23,7 +23,7 @@ mfcr a0, epsr btsti a0, 31 bt 1f - jbsr context_tracking_user_exit + jbsr user_exit_callable ldw a0, (sp, LSAVE_A0) ldw a1, (sp, LSAVE_A1) ldw a2, (sp, LSAVE_A2) @@ -160,7 +160,7 @@ ret_from_exception: cmpnei r10, 0 bt exit_work #ifdef CONFIG_CONTEXT_TRACKING - jbsr context_tracking_user_enter + jbsr user_enter_callable #endif 1: #ifdef CONFIG_PREEMPTION diff --git a/arch/riscv/kernel/entry.S b/arch/riscv/kernel/entry.S index ed29e9c8f660..5fbaa7be18a2 100644 --- a/arch/riscv/kernel/entry.S +++ b/arch/riscv/kernel/entry.S @@ -112,11 +112,11 @@ _save_context: #endif #ifdef CONFIG_CONTEXT_TRACKING - /* If previous state is in user mode, call context_tracking_user_exit. */ + /* If previous state is in user mode, call user_exit_callable(). */ li a0, SR_PP and a0, s1, a0 bnez a0, skip_context_tracking - call context_tracking_user_exit + call user_exit_callable skip_context_tracking: #endif @@ -252,7 +252,7 @@ resume_userspace: bnez s1, work_pending #ifdef CONFIG_CONTEXT_TRACKING - call context_tracking_user_enter + call user_enter_callable #endif /* Save unwound kernel stack pointer in thread_info */ diff --git a/include/linux/context_tracking.h b/include/linux/context_tracking.h index 773035124bad..69532cd18f72 100644 --- a/include/linux/context_tracking.h +++ b/include/linux/context_tracking.h @@ -19,8 +19,8 @@ extern void __ct_user_exit(enum ctx_state state); extern void context_tracking_enter(enum ctx_state state); extern void context_tracking_exit(enum ctx_state state); -extern void context_tracking_user_enter(void); -extern void context_tracking_user_exit(void); +extern void user_enter_callable(void); +extern void user_exit_callable(void); static inline void user_enter(void) { diff --git a/kernel/context_tracking.c b/kernel/context_tracking.c index ad2a973393a6..83e050675b23 100644 --- a/kernel/context_tracking.c +++ b/kernel/context_tracking.c @@ -125,11 +125,16 @@ void context_tracking_enter(enum ctx_state state) NOKPROBE_SYMBOL(context_tracking_enter); EXPORT_SYMBOL_GPL(context_tracking_enter); -void context_tracking_user_enter(void) +/** + * user_enter_callable() - Unfortunate ASM callable version of user_enter() for + * archs that didn't manage to check the context tracking + * static key from low level code. + */ +void user_enter_callable(void) { user_enter(); } -NOKPROBE_SYMBOL(context_tracking_user_enter); +NOKPROBE_SYMBOL(user_enter_callable); /** * __ct_user_exit - Inform the context tracking that the CPU is @@ -182,11 +187,16 @@ void context_tracking_exit(enum ctx_state state) NOKPROBE_SYMBOL(context_tracking_exit); EXPORT_SYMBOL_GPL(context_tracking_exit); -void context_tracking_user_exit(void) +/** + * user_exit_callable() - Unfortunate ASM callable version of user_exit() for + * archs that didn't manage to check the context tracking + * static key from low level code. + */ +void user_exit_callable(void) { user_exit(); } -NOKPROBE_SYMBOL(context_tracking_user_exit); +NOKPROBE_SYMBOL(user_exit_callable); void __init context_tracking_cpu_set(int cpu) { -- 2.25.1