* [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process
@ 2025-02-18 6:37 Zhang Lixu
2025-02-18 6:37 ` [PATCH 1/2] HID: intel-ish-hid: Fix use-after-free issue in hid_ishtp_cl_remove() Zhang Lixu
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: Zhang Lixu @ 2025-02-18 6:37 UTC (permalink / raw)
To: linux-input, srinivas.pandruvada, jikos, benjamin.tissoires
Cc: lixu.zhang, stable
These patches address use-after-free issues in the `intel_ishtp_hid` driver
during the removal process.
Zhang Lixu (2):
HID: intel-ish-hid: Fix use-after-free issue in hid_ishtp_cl_remove()
HID: intel-ish-hid: Fix use-after-free issue in ishtp_hid_remove()
drivers/hid/intel-ish-hid/ishtp-hid-client.c | 2 +-
drivers/hid/intel-ish-hid/ishtp-hid.c | 4 +++-
2 files changed, 4 insertions(+), 2 deletions(-)
base-commit: 0ae0fa3bf0b44c8611d114a9f69985bf451010c3
--
2.43.0
^ permalink raw reply [flat|nested] 4+ messages in thread
* [PATCH 1/2] HID: intel-ish-hid: Fix use-after-free issue in hid_ishtp_cl_remove()
2025-02-18 6:37 [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process Zhang Lixu
@ 2025-02-18 6:37 ` Zhang Lixu
2025-02-18 6:37 ` [PATCH 2/2] HID: intel-ish-hid: Fix use-after-free issue in ishtp_hid_remove() Zhang Lixu
2025-02-19 9:09 ` [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process Jiri Kosina
2 siblings, 0 replies; 4+ messages in thread
From: Zhang Lixu @ 2025-02-18 6:37 UTC (permalink / raw)
To: linux-input, srinivas.pandruvada, jikos, benjamin.tissoires
Cc: lixu.zhang, stable
During the `rmmod` operation for the `intel_ishtp_hid` driver, a
use-after-free issue can occur in the hid_ishtp_cl_remove() function.
The function hid_ishtp_cl_deinit() is called before ishtp_hid_remove(),
which can lead to accessing freed memory or resources during the
removal process.
Call Trace:
? ishtp_cl_send+0x168/0x220 [intel_ishtp]
? hid_output_report+0xe3/0x150 [hid]
hid_ishtp_set_feature+0xb5/0x120 [intel_ishtp_hid]
ishtp_hid_request+0x7b/0xb0 [intel_ishtp_hid]
hid_hw_request+0x1f/0x40 [hid]
sensor_hub_set_feature+0x11f/0x190 [hid_sensor_hub]
_hid_sensor_power_state+0x147/0x1e0 [hid_sensor_trigger]
hid_sensor_runtime_resume+0x22/0x30 [hid_sensor_trigger]
sensor_hub_remove+0xa8/0xe0 [hid_sensor_hub]
hid_device_remove+0x49/0xb0 [hid]
hid_destroy_device+0x6f/0x90 [hid]
ishtp_hid_remove+0x42/0x70 [intel_ishtp_hid]
hid_ishtp_cl_remove+0x6b/0xb0 [intel_ishtp_hid]
ishtp_cl_device_remove+0x4a/0x60 [intel_ishtp]
...
Additionally, ishtp_hid_remove() is a HID level power off, which should
occur before the ISHTP level disconnect.
This patch resolves the issue by reordering the calls in
hid_ishtp_cl_remove(). The function ishtp_hid_remove() is now
called before hid_ishtp_cl_deinit().
Fixes: f645a90e8ff7 ("HID: intel-ish-hid: ishtp-hid-client: use helper functions for connection")
Signed-off-by: Zhang Lixu <lixu.zhang@intel.com>
Acked-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
---
drivers/hid/intel-ish-hid/ishtp-hid-client.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/hid/intel-ish-hid/ishtp-hid-client.c b/drivers/hid/intel-ish-hid/ishtp-hid-client.c
index cb04cd1d980b..6550ad5bfbb5 100644
--- a/drivers/hid/intel-ish-hid/ishtp-hid-client.c
+++ b/drivers/hid/intel-ish-hid/ishtp-hid-client.c
@@ -832,9 +832,9 @@ static void hid_ishtp_cl_remove(struct ishtp_cl_device *cl_device)
hid_ishtp_cl);
dev_dbg(ishtp_device(cl_device), "%s\n", __func__);
- hid_ishtp_cl_deinit(hid_ishtp_cl);
ishtp_put_device(cl_device);
ishtp_hid_remove(client_data);
+ hid_ishtp_cl_deinit(hid_ishtp_cl);
hid_ishtp_cl = NULL;
--
2.43.0
^ permalink raw reply related [flat|nested] 4+ messages in thread
* [PATCH 2/2] HID: intel-ish-hid: Fix use-after-free issue in ishtp_hid_remove()
2025-02-18 6:37 [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process Zhang Lixu
2025-02-18 6:37 ` [PATCH 1/2] HID: intel-ish-hid: Fix use-after-free issue in hid_ishtp_cl_remove() Zhang Lixu
@ 2025-02-18 6:37 ` Zhang Lixu
2025-02-19 9:09 ` [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process Jiri Kosina
2 siblings, 0 replies; 4+ messages in thread
From: Zhang Lixu @ 2025-02-18 6:37 UTC (permalink / raw)
To: linux-input, srinivas.pandruvada, jikos, benjamin.tissoires
Cc: lixu.zhang, stable
The system can experience a random crash a few minutes after the driver is
removed. This issue occurs due to improper handling of memory freeing in
the ishtp_hid_remove() function.
The function currently frees the `driver_data` directly within the loop
that destroys the HID devices, which can lead to accessing freed memory.
Specifically, `hid_destroy_device()` uses `driver_data` when it calls
`hid_ishtp_set_feature()` to power off the sensor, so freeing
`driver_data` beforehand can result in accessing invalid memory.
This patch resolves the issue by storing the `driver_data` in a temporary
variable before calling `hid_destroy_device()`, and then freeing the
`driver_data` after the device is destroyed.
Fixes: 0b28cb4bcb17 ("HID: intel-ish-hid: ISH HID client driver")
Signed-off-by: Zhang Lixu <lixu.zhang@intel.com>
Acked-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
---
drivers/hid/intel-ish-hid/ishtp-hid.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/hid/intel-ish-hid/ishtp-hid.c b/drivers/hid/intel-ish-hid/ishtp-hid.c
index 00c6f0ebf356..be2c62fc8251 100644
--- a/drivers/hid/intel-ish-hid/ishtp-hid.c
+++ b/drivers/hid/intel-ish-hid/ishtp-hid.c
@@ -261,12 +261,14 @@ int ishtp_hid_probe(unsigned int cur_hid_dev,
*/
void ishtp_hid_remove(struct ishtp_cl_data *client_data)
{
+ void *data;
int i;
for (i = 0; i < client_data->num_hid_devices; ++i) {
if (client_data->hid_sensor_hubs[i]) {
- kfree(client_data->hid_sensor_hubs[i]->driver_data);
+ data = client_data->hid_sensor_hubs[i]->driver_data;
hid_destroy_device(client_data->hid_sensor_hubs[i]);
+ kfree(data);
client_data->hid_sensor_hubs[i] = NULL;
}
}
--
2.43.0
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process
2025-02-18 6:37 [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process Zhang Lixu
2025-02-18 6:37 ` [PATCH 1/2] HID: intel-ish-hid: Fix use-after-free issue in hid_ishtp_cl_remove() Zhang Lixu
2025-02-18 6:37 ` [PATCH 2/2] HID: intel-ish-hid: Fix use-after-free issue in ishtp_hid_remove() Zhang Lixu
@ 2025-02-19 9:09 ` Jiri Kosina
2 siblings, 0 replies; 4+ messages in thread
From: Jiri Kosina @ 2025-02-19 9:09 UTC (permalink / raw)
To: Zhang Lixu; +Cc: linux-input, srinivas.pandruvada, benjamin.tissoires, stable
On Tue, 18 Feb 2025, Zhang Lixu wrote:
> These patches address use-after-free issues in the `intel_ishtp_hid` driver
> during the removal process.
>
> Zhang Lixu (2):
> HID: intel-ish-hid: Fix use-after-free issue in hid_ishtp_cl_remove()
> HID: intel-ish-hid: Fix use-after-free issue in ishtp_hid_remove()
>
> drivers/hid/intel-ish-hid/ishtp-hid-client.c | 2 +-
> drivers/hid/intel-ish-hid/ishtp-hid.c | 4 +++-
> 2 files changed, 4 insertions(+), 2 deletions(-)
Applied to hid.git#for-6.14/upstream-fixes, thanks.
--
Jiri Kosina
SUSE Labs
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2025-02-19 9:09 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-02-18 6:37 [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process Zhang Lixu
2025-02-18 6:37 ` [PATCH 1/2] HID: intel-ish-hid: Fix use-after-free issue in hid_ishtp_cl_remove() Zhang Lixu
2025-02-18 6:37 ` [PATCH 2/2] HID: intel-ish-hid: Fix use-after-free issue in ishtp_hid_remove() Zhang Lixu
2025-02-19 9:09 ` [PATCH 0/2] HID: intel-ish-hid: Fix use-after-free issues in driver removal process Jiri Kosina
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).