Received: by 2002:a05:6a10:8395:0:0:0:0 with SMTP id n21csp609702pxh; Wed, 10 Nov 2021 06:49:17 -0800 (PST) X-Google-Smtp-Source: ABdhPJx4ZWdOo1I1+E1IXMWs7eGGqVU0snzRDrJdHEVMDVu0/eqpkqEyhqYstgW/n3pQFqMI6UBK X-Received: by 2002:a50:f08b:: with SMTP id v11mr216011edl.96.1636555756840; Wed, 10 Nov 2021 06:49:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1636555756; cv=none; d=google.com; s=arc-20160816; b=P5RsL6EUyNywr+C75Fc88Fr7mFJhbKpV0zsRK5F4PDWVtoeKgnv9u0LO5W3O2E4VxJ Yx0Ti4/eEJKQX09PqsJ6os3sJ83kX+jPX1RXsqRIXEV8xRIdOZtmmqcBxCsvN3Qjb70e 84PDhRZ+qjlhKOvYz1ESE7U/9hVov7Tx1Ts8oGpndYxYdYohOJhz/e0wc3Ob8dIdW1UX XZS00yndjtkm7xN+3csm59kOcXJX45kEAIbxxBPJmshIdS+EkQGhp9TeWsg/S3cEzlKn h+6qmyEz0G4qkepTMubm9l4TGIw6SnJQQIwBvK/DLa+tNULxOp5hypx4IlHGFcufcXFa 3zEw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:references :in-reply-to:subject:cc:to:from; bh=DenZwOFTNFjc4UkQ/7q2LqFx2a40mGUK6SL8bwMues8=; b=nSRSMPapaoV2LQ7NsgALDAgWoIgKbu48fgIt1bDHnzT9NU8S2HTl+mfLhMy4r+Ue4d xq1yHHt7YWZ3lGVUY3RRyaGD8dd9Wr7VFZhW3HfNxFI/3NQG6wbfTkjVDaAjPgVToqXR b3Xx5YtMvMEMhaDFs9tNXSRSVyXj8sNTNC8rodXf4vyQcTpU/ATUJvBt/pdck+7IFrBh pr2cFdGEWQ7mD38PZaQ3psnBo6kUKeJGNkszuZgC7coNIXriJ/o9EjIxMQOQZmqKC5+z kjhv5zKVmjJtHwrlnbCYkHSNrk4GoyN3EYBeLVay6ctlhdgPuxqhOyKzdqQtHOgsjVdp 7kpg== 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=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id sd41si134313ejc.597.2021.11.10.06.48.52; Wed, 10 Nov 2021 06:49:16 -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=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232295AbhKJOsk (ORCPT + 99 others); Wed, 10 Nov 2021 09:48:40 -0500 Received: from foss.arm.com ([217.140.110.172]:47110 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231731AbhKJOsk (ORCPT ); Wed, 10 Nov 2021 09:48:40 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 5D497139F; Wed, 10 Nov 2021 06:45:52 -0800 (PST) Received: from e113632-lin (e113632-lin.cambridge.arm.com [10.1.196.57]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 75C503F718; Wed, 10 Nov 2021 06:45:51 -0800 (PST) From: Valentin Schneider To: Mike Galbraith , Frederic Weisbecker , Marco Elver Cc: linux-kernel@vger.kernel.org, Peter Zijlstra , Ingo Molnar Subject: Re: [PATCH] sched: Split preemption model selection between DYNAMIC & !DYNAMIC In-Reply-To: <87h7cks16n.mognet@arm.com> References: <20211109151057.3489223-1-valentin.schneider@arm.com> <20211110011738.GD288354@lothringen> <87h7cks16n.mognet@arm.com> Date: Wed, 10 Nov 2021 14:45:45 +0000 Message-ID: <87bl2srrvq.mognet@arm.com> MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/11/21 11:24, Valentin Schneider wrote: > Following Frederic's _STATIC suggestion, I got to the below. The nice thing > is if a defconfig picks say PREEMPT_VOLUNTARY and the arch supports > PREEMPT_DYNAMIC, then it'll pick PREEMPT_VOLUNTARY_BEHAVIOUR. The less nice > thing is that we end up selecting PREEMPT_STATIC for PREEMPT_DYNAMIC > kernels, naming's hard... Maybe _BUILD rather than _STATIC? > And now without a legacy compatibility layer crud... --- diff --git a/include/linux/kernel.h b/include/linux/kernel.h index 2776423a587e..9c7d774ef809 100644 --- a/include/linux/kernel.h +++ b/include/linux/kernel.h @@ -88,7 +88,7 @@ struct completion; struct user; -#ifdef CONFIG_PREEMPT_VOLUNTARY +#ifdef CONFIG_PREEMPT_VOLUNTARY_BUILD extern int __cond_resched(void); # define might_resched() __cond_resched() diff --git a/include/linux/vermagic.h b/include/linux/vermagic.h index 1eaaa93c37bf..f2b71920024c 100644 --- a/include/linux/vermagic.h +++ b/include/linux/vermagic.h @@ -15,7 +15,7 @@ #else #define MODULE_VERMAGIC_SMP "" #endif -#ifdef CONFIG_PREEMPT +#ifdef CONFIG_PREEMPT_BUILD #define MODULE_VERMAGIC_PREEMPT "preempt " #elif defined(CONFIG_PREEMPT_RT) #define MODULE_VERMAGIC_PREEMPT "preempt_rt " @@ -39,9 +39,9 @@ #define MODULE_RANDSTRUCT_PLUGIN #endif -#define VERMAGIC_STRING \ +#define VERMAGIC_STRING \ UTS_RELEASE " " \ - MODULE_VERMAGIC_SMP MODULE_VERMAGIC_PREEMPT \ + MODULE_VERMAGIC_SMP MODULE_VERMAGIC_PREEMPT \ MODULE_VERMAGIC_MODULE_UNLOAD MODULE_VERMAGIC_MODVERSIONS \ MODULE_ARCH_VERMAGIC \ MODULE_RANDSTRUCT_PLUGIN diff --git a/init/Makefile b/init/Makefile index 2846113677ee..04eeee12c076 100644 --- a/init/Makefile +++ b/init/Makefile @@ -30,7 +30,7 @@ $(obj)/version.o: include/generated/compile.h quiet_cmd_compile.h = CHK $@ cmd_compile.h = \ $(CONFIG_SHELL) $(srctree)/scripts/mkcompile_h $@ \ - "$(UTS_MACHINE)" "$(CONFIG_SMP)" "$(CONFIG_PREEMPT)" \ + "$(UTS_MACHINE)" "$(CONFIG_SMP)" "$(CONFIG_PREEMPT_BUILD)" \ "$(CONFIG_PREEMPT_RT)" $(CONFIG_CC_VERSION_TEXT) "$(LD)" include/generated/compile.h: FORCE diff --git a/kernel/Kconfig.preempt b/kernel/Kconfig.preempt index 60f1bfc3c7b2..ce77f0265660 100644 --- a/kernel/Kconfig.preempt +++ b/kernel/Kconfig.preempt @@ -1,12 +1,23 @@ # SPDX-License-Identifier: GPL-2.0-only +config PREEMPT_NONE_BUILD + bool + +config PREEMPT_VOLUNTARY_BUILD + bool + +config PREEMPT_BUILD + bool + select PREEMPTION + select UNINLINE_SPIN_UNLOCK if !ARCH_INLINE_SPIN_UNLOCK + choice prompt "Preemption Model" - default PREEMPT_NONE_BEHAVIOUR + default PREEMPT_NONE -config PREEMPT_NONE_BEHAVIOUR +config PREEMPT_NONE bool "No Forced Preemption (Server)" - select PREEMPT_NONE if !PREEMPT_DYNAMIC + select PREEMPT_NONE_BUILD if !PREEMPT_DYNAMIC help This is the traditional Linux preemption model, geared towards throughput. It will still provide good latencies most of the @@ -18,10 +29,10 @@ config PREEMPT_NONE_BEHAVIOUR raw processing power of the kernel, irrespective of scheduling latencies. -config PREEMPT_VOLUNTARY_BEHAVIOUR +config PREEMPT_VOLUNTARY bool "Voluntary Kernel Preemption (Desktop)" depends on !ARCH_NO_PREEMPT - select PREEMPT_VOLUNTARY if !PREEMPT_DYNAMIC + select PREEMPT_VOLUNTARY_BUILD if !PREEMPT_DYNAMIC help This option reduces the latency of the kernel by adding more "explicit preemption points" to the kernel code. These new @@ -37,10 +48,10 @@ config PREEMPT_VOLUNTARY_BEHAVIOUR Select this if you are building a kernel for a desktop system. -config PREEMPT_BEHAVIOUR +config PREEMPT bool "Preemptible Kernel (Low-Latency Desktop)" depends on !ARCH_NO_PREEMPT - select PREEMPT + select PREEMPT_BUILD help This option reduces the latency of the kernel by making all kernel code (that is not executing in a critical section) @@ -58,7 +69,7 @@ config PREEMPT_BEHAVIOUR config PREEMPT_RT bool "Fully Preemptible Kernel (Real-Time)" - depends on EXPERT && ARCH_SUPPORTS_RT && !PREEMPT_DYNAMIC + depends on EXPERT && ARCH_SUPPORTS_RT select PREEMPTION help This option turns the kernel into a real-time kernel by replacing @@ -75,17 +86,6 @@ config PREEMPT_RT endchoice -config PREEMPT_NONE - bool - -config PREEMPT_VOLUNTARY - bool - -config PREEMPT - bool - select PREEMPTION - select UNINLINE_SPIN_UNLOCK if !ARCH_INLINE_SPIN_UNLOCK - config PREEMPT_COUNT bool @@ -95,8 +95,8 @@ config PREEMPTION config PREEMPT_DYNAMIC bool "Preemption behaviour defined on boot" - depends on HAVE_PREEMPT_DYNAMIC - select PREEMPT + depends on HAVE_PREEMPT_DYNAMIC && !PREEMPT_RT + select PREEMPT_BUILD default y help This option allows to define the preemption model on the kernel diff --git a/kernel/kcsan/kcsan_test.c b/kernel/kcsan/kcsan_test.c index dc55fd5a36fc..845b17cf7811 100644 --- a/kernel/kcsan/kcsan_test.c +++ b/kernel/kcsan/kcsan_test.c @@ -1005,13 +1005,13 @@ static const void *nthreads_gen_params(const void *prev, char *desc) else nthreads *= 2; - if (!IS_ENABLED(CONFIG_PREEMPT) || !IS_ENABLED(CONFIG_KCSAN_INTERRUPT_WATCHER)) { + if (!IS_ENABLED(CONFIG_PREEMPTION) || !IS_ENABLED(CONFIG_KCSAN_INTERRUPT_WATCHER)) { /* * Without any preemption, keep 2 CPUs free for other tasks, one * of which is the main test case function checking for * completion or failure. */ - const long min_unused_cpus = IS_ENABLED(CONFIG_PREEMPT_NONE) ? 2 : 0; + const long min_unused_cpus = IS_ENABLED(CONFIG_PREEMPT_NONE_BUILD) ? 2 : 0; const long min_required_cpus = 2 + min_unused_cpus; if (num_online_cpus() < min_required_cpus) { diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 7896d30d90f7..3b3226ffbafa 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -4271,11 +4271,11 @@ print_trace_header(struct seq_file *m, struct trace_iterator *iter) entries, total, buf->cpu, -#if defined(CONFIG_PREEMPT_NONE) +#if defined(CONFIG_PREEMPT_NONE_BUILD) "server", -#elif defined(CONFIG_PREEMPT_VOLUNTARY) +#elif defined(CONFIG_PREEMPT_VOLUNTARY_BUILD) "desktop", -#elif defined(CONFIG_PREEMPT) +#elif defined(CONFIG_PREEMPT_BUILD) "preempt", #elif defined(CONFIG_PREEMPT_RT) "preempt_rt",