umber-kernel/drivers/rpmsg
Gui-Dong Han 2e4a70f3c3 rpmsg: core: fix race in driver_override_show() and use core helper
[ Upstream commit 42023d4b6d2661a40ee2dcf7e1a3528a35c638ca ]

The driver_override_show function reads the driver_override string
without holding the device_lock. However, the store function modifies
and frees the string while holding the device_lock. This creates a race
condition where the string can be freed by the store function while
being read by the show function, leading to a use-after-free.

To fix this, replace the rpmsg_string_attr macro with explicit show and
store functions. The new driver_override_store uses the standard
driver_set_override helper. Since the introduction of
driver_set_override, the comments in include/linux/rpmsg.h have stated
that this helper must be used to set or clear driver_override, but the
implementation was not updated until now.

Because driver_set_override modifies and frees the string while holding
the device_lock, the new driver_override_show now correctly holds the
device_lock during the read operation to prevent the race.

Additionally, since rpmsg_string_attr has only ever been used for
driver_override, removing the macro simplifies the code.

Fixes: 39e47767ec ("rpmsg: Add driver_override device attribute for rpmsg_device")
Cc: stable@vger.kernel.org
Signed-off-by: Gui-Dong Han <hanguidong02@gmail.com>
Link: https://lore.kernel.org/r/20251202174948.12693-1-hanguidong02@gmail.com
Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2026-03-04 07:20:52 -05:00
..
Kconfig
Makefile
mtk_rpmsg.c
qcom_glink_native.c rpmsg: glink: fix rpmsg device leak 2026-01-02 12:57:29 +01:00
qcom_glink_native.h
qcom_glink_rpm.c
qcom_glink_smem.c
qcom_glink_ssr.c
qcom_glink_trace.h
qcom_smd.c rpmsg: qcom_smd: Fix fallback to qcom,ipc parse 2025-09-20 21:29:48 -05:00
rpmsg_char.c rpmsg: char: Export alias for RPMSG ID rpmsg-raw from table 2025-08-25 08:20:21 -06:00
rpmsg_char.h
rpmsg_core.c rpmsg: core: fix race in driver_override_show() and use core helper 2026-03-04 07:20:52 -05:00
rpmsg_ctrl.c
rpmsg_internal.h rpmsg: Remove unused method pointers *send_offchannel 2025-05-06 11:11:45 -06:00
rpmsg_ns.c
virtio_rpmsg_bus.c remoteproc: Don't use %pK through printk 2025-06-17 08:03:24 -05:00