diff options
author | Zhang Lixu <lixu.zhang@intel.com> | 2025-02-18 14:37:30 +0800 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.com> | 2025-02-19 10:09:27 +0100 |
commit | 07583a0010696a17fb0942e0b499a62785c5fc9f (patch) | |
tree | df18d8ec1fefc3746ee587c0c62a8105e30dfd06 /tools/perf/scripts/python/exported-sql-viewer.py | |
parent | 823987841424289339fdb4ba90e6d2c3792836db (diff) |
HID: intel-ish-hid: Fix use-after-free issue in ishtp_hid_remove()
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>
Signed-off-by: Jiri Kosina <jkosina@suse.com>
Diffstat (limited to 'tools/perf/scripts/python/exported-sql-viewer.py')
0 files changed, 0 insertions, 0 deletions