linux-input.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [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).