From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-lj1-f172.google.com (mail-lj1-f172.google.com [209.85.208.172]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EC8B242EEA3 for ; Mon, 11 May 2026 17:54:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.172 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778522096; cv=none; b=clH3CV4HoybCUtxV37ZRjVSmAwIPryFtJxY4LM2lgQPkNEn0d5AxvkZuNcweLcuc20j0AQYbXYot8cvvTu1g+LZ0ttlX3CyRf5RtCWqjJJl768wW8qR4CQyjuQRR84lhiNLH0HYr+7J6BEXN+hmaifT1uHRZz0WuCge1mfyfY84= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778522096; c=relaxed/simple; bh=nf3d6Th/qqcFPA3j+0FA/cKyNhD0kVORFLgt2PalDbc=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=Va0wSLNT777p2JoMnAdKs3Og67i9kzPetpHfid94u65626kXqCX5tA9FArNSvfWn6XZsE8X4yaUtzrmVZJze/a1/tkOR8K4vqA8lYyQw1jnVCUrYjwldk1AU5y5WWuDmXTkTtBKodLFcULzo1V3vFJXi1pLW0zXwscG/TtiFjN8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=pVpeUdue; arc=none smtp.client-ip=209.85.208.172 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="pVpeUdue" Received: by mail-lj1-f172.google.com with SMTP id 38308e7fff4ca-3938d17d6c5so40226771fa.1 for ; Mon, 11 May 2026 10:54:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20251104; t=1778522092; x=1779126892; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=i8n4g8DtMbilWmfrS0Iblc6XB8Z+tIb+ktHpUGgo0p4=; b=pVpeUdueFnnPECTMz//oiyPwZ7dcW/oxkzJmPjU+g3CXQ2JXXg3nrTJ3fmBu1MXNHg rwPU8ByopHGqqC39WK6ODyGKDjIQx3PcU9ItlwMRioCObdG64FO2fvCZLvHK/6GV9lM0 jPkyqNUDTYrNQQoHZWj4cPEwaTzsrUhiO5+hvDk8i8PB6xNPD8GTcurSHZEHdVVJIWdZ vdcNEhP3g/3sqfKWYh9xlkQ76xQz+I+39J4XwvXWhQJmTnYRXXr+Nl92ZZ2N/2s1XMF1 RfVPXve6zbGjrAjE/bs2W8+u517U29wpjyyQWMBLeUrp0YhuDri/aGAgcEatseO8lTUN jj6w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1778522092; x=1779126892; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=i8n4g8DtMbilWmfrS0Iblc6XB8Z+tIb+ktHpUGgo0p4=; b=pbBP8hu3I+5HJW3SLfd7KE0R5sgOBPn7SKO27GhrH2RgtQ+I66s+KyyK8XcfnFHhZa QeY6RX2if9D/6Hn1IH5j/LifElhkLVBBV+hrjnK/lYQ0e/6ZjB5ASO6y3baO3eNbI5BE Aea/dKrjiBAup3YoyiN0MZlkz8tjx/4IoGyD7kD7CnDF4+5GGbgvA4gq98tndAtso+Le dGfB9KRjhxEWsnsr+M0K+3V0pWOy9s0qYt8rV4jCHJTHCv0obLoAd9H/S9C+DKmORUMJ rXWm5NcKr2bfOF6DEtaB/JTae/zUHQ8RqKBMz7ilFnm9m0uFCrWHdNGGhEIAMPnoSHtB bKPQ== X-Forwarded-Encrypted: i=1; AFNElJ+XpDk3WPrX9uT6mOKIABdwsXUe1omcwQ+bzsfFnOy2Ccez+4s6rsa71dY0i5/z1BAwYNtR5JfUsiFE2mI=@vger.kernel.org X-Gm-Message-State: AOJu0YxvrhcLX2u/7qX1v5Ws+VoGRr6zGTDyJKeGZ14ITAoGjZNZ+IQz RKUYTK/OBQOqLPf0iNNrGgNSVeyxhiiwc7kJYYBCUyyNovbe099D0jTF X-Gm-Gg: Acq92OHbpU8+BmF5yZyOCUfcOBviw328H7RPmpM5wzoPrMkUxIX2biDCXl0Z7HN0oro S88V4hFHd4BAB3Bhc6D45pcZG4M4txB4Ty0FNALZn55Lx6l/1b0Wx9BUagd5noG4jUn4AFvOC1i Ro0R+7EtNr4IDlCZuEnptxFH6fSAPoFhSkEYgNEXYwY7zp1ZHT92p7N19OzrxROkPI9U5A5H1C6 3Sbth4VL+Knp0u/UL0A/l/43CKwQrVpBTGcWBopUhO56Z0tKH1fGXrA4c7hun7f98qMWuWAAQsQ rkPLnKFKcv47eyedgCT3MxrOWs9cbplQOog4kDrOKqESjeLPf/id/DgsReLXLJDrZEftDBMHXgc 59fIU93qIWjx4RC4ud5kgnXHmJG0LSX/ZrfgP477VqFA+Vlla9mRkyfPrpGrRe+P3RoMLHp1kHU OOL3TNlnMl8uaNdDU= X-Received: by 2002:a2e:b554:0:b0:393:d562:d51b with SMTP id 38308e7fff4ca-393d562d88dmr49585891fa.9.1778522091997; Mon, 11 May 2026 10:54:51 -0700 (PDT) Received: from localhost.localdomain ([2001:9b1:d5a0:a500::24b]) by smtp.gmail.com with ESMTPSA id 38308e7fff4ca-393f614a5f4sm28968891fa.33.2026.05.11.10.54.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 11 May 2026 10:54:51 -0700 (PDT) From: "Uladzislau Rezki (Sony)" To: "Paul E . McKenney" , Joel Fernandes , Frederic Weisbecker , Boqun Feng Cc: RCU , LKML , Uladzislau Rezki Subject: [PATCH -next v1 02/12] torture: Add torture_sched_set_normal() for user-specified nice values Date: Mon, 11 May 2026 19:54:38 +0200 Message-ID: <20260511175448.153326-3-urezki@gmail.com> X-Mailer: git-send-email 2.47.3 In-Reply-To: <20260511175448.153326-1-urezki@gmail.com> References: <20260511175448.153326-1-urezki@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit From: "Paul E. McKenney" This new torture_sched_set_normal() function clamps the nice value at the MIN_NICE..MAX_NICE limits, splatting it these limits are exceeded. It then invokes sched_set_normal() to set the new value. This prevents more difficult-to-debug failures within the scheduler. Signed-off-by: Paul E. McKenney Signed-off-by: Uladzislau Rezki (Sony) --- include/linux/torture.h | 1 + kernel/torture.c | 16 ++++++++++++++++ 2 files changed, 17 insertions(+) diff --git a/include/linux/torture.h b/include/linux/torture.h index 1b59056c3b18..c9b47d138302 100644 --- a/include/linux/torture.h +++ b/include/linux/torture.h @@ -129,6 +129,7 @@ void _torture_stop_kthread(char *m, struct task_struct **tp); #else #define torture_preempt_schedule() do { } while (0) #endif +void torture_sched_set_normal(struct task_struct *t, int nice); #if IS_ENABLED(CONFIG_RCU_TORTURE_TEST) || IS_MODULE(CONFIG_RCU_TORTURE_TEST) || IS_ENABLED(CONFIG_LOCK_TORTURE_TEST) || IS_MODULE(CONFIG_LOCK_TORTURE_TEST) long torture_sched_setaffinity(pid_t pid, const struct cpumask *in_mask, bool dowarn); diff --git a/kernel/torture.c b/kernel/torture.c index 62c1ac777694..77cb3589b19f 100644 --- a/kernel/torture.c +++ b/kernel/torture.c @@ -972,3 +972,19 @@ void _torture_stop_kthread(char *m, struct task_struct **tp) *tp = NULL; } EXPORT_SYMBOL_GPL(_torture_stop_kthread); + +/* + * Set the specified task's niceness value, saturating at limits. + * Saturating noisily, but saturating. + */ +void torture_sched_set_normal(struct task_struct *t, int nice) +{ + int realnice = nice; + + if (WARN_ON_ONCE(realnice > MAX_NICE)) + realnice = MAX_NICE; + if (WARN_ON_ONCE(realnice < MIN_NICE)) + realnice = MIN_NICE; + sched_set_normal(t, realnice); +} +EXPORT_SYMBOL_GPL(torture_sched_set_normal); -- 2.47.3