From: Sasha Levin <sashal@kernel.org>
To: patches@lists.linux.dev, stable@vger.kernel.org
Cc: Lifeng Zheng <zhenglifeng1@huawei.com>,
Chanwoo Choi <cw00.choi@samsung.com>,
Sasha Levin <sashal@kernel.org>,
myungjoo.ham@samsung.com, kyungmin.park@samsung.com,
linux-pm@vger.kernel.org
Subject: [PATCH AUTOSEL 5.15 12/44] PM / devfreq: governor: Replace sscanf() with kstrtoul() in set_freq_store()
Date: Sun, 3 Aug 2025 20:38:17 -0400 [thread overview]
Message-ID: <20250804003849.3627024-12-sashal@kernel.org> (raw)
In-Reply-To: <20250804003849.3627024-1-sashal@kernel.org>
From: Lifeng Zheng <zhenglifeng1@huawei.com>
[ Upstream commit 914cc799b28f17d369d5b4db3b941957d18157e8 ]
Replace sscanf() with kstrtoul() in set_freq_store() and check the result
to avoid invalid input.
Signed-off-by: Lifeng Zheng <zhenglifeng1@huawei.com>
Link: https://lore.kernel.org/lkml/20250421030020.3108405-2-zhenglifeng1@huawei.com/
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
---
LLM Generated explanations, may be completely bogus:
## Backport Status: YES
This commit should be backported to stable kernel trees for the
following reasons:
1. **Security Issue - Input Validation Bug**: The original code uses
`sscanf(buf, "%lu", &wanted)` at line 45 without checking the return
value. This is a security vulnerability because:
- `sscanf()` returns the number of successfully parsed items
- If the input is malformed or contains invalid characters,
`sscanf()` may return 0 but leave `wanted` uninitialized
- The code then proceeds to use this potentially uninitialized value
in `data->user_frequency = wanted`
- This could lead to setting arbitrary frequency values from
uninitialized stack data
2. **Real User Impact**: The devfreq userspace governor allows users to
manually set device frequencies through sysfs. Invalid input handling
could cause:
- Setting incorrect frequencies based on uninitialized memory
- Potential system instability if invalid frequencies are applied to
hardware
- Security implications as uninitialized stack data could be used
3. **Small and Contained Fix**: The change is minimal and low-risk:
- Replaces `sscanf()` with `kstrtoul()` which has proper error
checking
- Adds explicit error handling that returns early on invalid input
- The change is confined to a single function (`set_freq_store()`)
- No architectural changes or new features added
4. **Follows Kernel Best Practices**: The kernel has been systematically
replacing `sscanf()` with `kstrto*()` functions for better input
validation. This is evident from similar commits found in the git log
(e.g., commit a5556fa1107d for asus-wmi).
5. **Critical Subsystem**: While devfreq might not be as critical as
core memory management, it controls device frequency scaling which
can affect:
- Power management
- System performance
- Hardware stability
6. **No Negative Side Effects**: The change only adds proper validation
and doesn't modify the core functionality. Valid inputs will continue
to work exactly as before.
The commit fixes a clear bug (missing input validation) that could lead
to undefined behavior and potential security issues, making it an
excellent candidate for stable backporting according to stable tree
rules.
drivers/devfreq/governor_userspace.c | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/drivers/devfreq/governor_userspace.c b/drivers/devfreq/governor_userspace.c
index d69672ccacc4..8d057cea09d5 100644
--- a/drivers/devfreq/governor_userspace.c
+++ b/drivers/devfreq/governor_userspace.c
@@ -9,6 +9,7 @@
#include <linux/slab.h>
#include <linux/device.h>
#include <linux/devfreq.h>
+#include <linux/kstrtox.h>
#include <linux/pm.h>
#include <linux/mutex.h>
#include <linux/module.h>
@@ -39,10 +40,13 @@ static ssize_t set_freq_store(struct device *dev, struct device_attribute *attr,
unsigned long wanted;
int err = 0;
+ err = kstrtoul(buf, 0, &wanted);
+ if (err)
+ return err;
+
mutex_lock(&devfreq->lock);
data = devfreq->governor_data;
- sscanf(buf, "%lu", &wanted);
data->user_frequency = wanted;
data->valid = true;
err = update_devfreq(devfreq);
--
2.39.5
next prev parent reply other threads:[~2025-08-04 0:39 UTC|newest]
Thread overview: 44+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-08-04 0:38 [PATCH AUTOSEL 5.15 01/44] usb: xhci: print xhci->xhc_state when queue_command failed Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 02/44] cpufreq: CPPC: Mark driver with NEED_UPDATE_LIMITS flag Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 03/44] selftests/futex: Define SYS_futex on 32-bit architectures with 64-bit time_t Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 04/44] usb: typec: ucsi: psy: Set current max to 100mA for BC 1.2 and Default Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 05/44] regulator: core: repeat voltage setting request for stepped regulators Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 06/44] usb: xhci: Avoid showing warnings for dying controller Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 07/44] usb: xhci: Set avg_trb_len = 8 for EP0 during Address Device Command Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 08/44] usb: xhci: Avoid showing errors during surprise removal Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 09/44] gpio: wcd934x: check the return value of regmap_update_bits() Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 10/44] cpufreq: Exit governor when failed to start old governor Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 11/44] ARM: rockchip: fix kernel hang during smp initialization Sasha Levin
2025-08-04 0:38 ` Sasha Levin [this message]
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 13/44] EDAC/synopsys: Clear the ECC counters on init Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 14/44] ASoC: soc-dapm: set bias_level if snd_soc_dapm_set_bias_level() was successed Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 15/44] thermal/drivers/qcom-spmi-temp-alarm: Enable stage 2 shutdown when required Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 16/44] tools/nolibc: define time_t in terms of __kernel_old_time_t Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 17/44] gpio: tps65912: check the return value of regmap_update_bits() Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 18/44] ARM: tegra: Use I/O memcpy to write to IRAM Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 19/44] selftests: tracing: Use mutex_unlock for testing glob filter Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 20/44] ACPI: PRM: Reduce unnecessary printing to avoid user confusion Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 21/44] PM: runtime: Clear power.needs_force_resume in pm_runtime_reinit() Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 22/44] thermal: sysfs: Return ENODATA instead of EAGAIN for reads Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 23/44] PM: sleep: console: Fix the black screen issue Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 24/44] ACPI: processor: fix acpi_object initialization Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 25/44] mmc: sdhci-msm: Ensure SD card power isn't ON when card removed Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 26/44] ACPI: APEI: GHES: add TAINT_MACHINE_CHECK on GHES panic path Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 27/44] pps: clients: gpio: fix interrupt handling order in remove path Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 28/44] reset: brcmstb: Enable reset drivers for ARCH_BCM2835 Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 29/44] mmc: rtsx_usb_sdmmc: Fix error-path in sd_set_power_mode() Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 30/44] x86/bugs: Avoid warning when overriding return thunk Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 31/44] ASoC: hdac_hdmi: Rate limit logging on connection and disconnection Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 32/44] ALSA: intel8x0: Fix incorrect codec index usage in mixer for ICH4 Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 33/44] ASoC: core: Check for rtd == NULL in snd_soc_remove_pcm_runtime() Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 34/44] usb: typec: intel_pmc_mux: Defer probe if SCU IPC isn't present Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 35/44] usb: core: usb_submit_urb: downgrade type check Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 36/44] usb: typec: fusb302: fix scheduling while atomic when using virtio-gpio Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 37/44] pm: cpupower: Fix the snapshot-order of tsc,mperf, clock in mperf_stop() Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 38/44] platform/x86: thinkpad_acpi: Handle KCOV __init vs inline mismatches Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 39/44] platform/chrome: cros_ec_typec: Defer probe on missing EC parent Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 40/44] ALSA: hda/ca0132: Fix buffer overflow in add_tuning_control Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 41/44] ALSA: pcm: Rewrite recalculate_boundary() to avoid costly loop Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 42/44] ALSA: usb-audio: Avoid precedence issues in mixer_quirks macros Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 43/44] iio: adc: ad7768-1: Ensure SYNC_IN pulse minimum timing requirement Sasha Levin
2025-08-04 0:38 ` [PATCH AUTOSEL 5.15 44/44] ASoC: codecs: rt5640: Retry DEVICE_ID verification Sasha Levin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250804003849.3627024-12-sashal@kernel.org \
--to=sashal@kernel.org \
--cc=cw00.choi@samsung.com \
--cc=kyungmin.park@samsung.com \
--cc=linux-pm@vger.kernel.org \
--cc=myungjoo.ham@samsung.com \
--cc=patches@lists.linux.dev \
--cc=stable@vger.kernel.org \
--cc=zhenglifeng1@huawei.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox