diff options
author | Johan Hovold <[email protected]> | 2022-08-04 17:09:56 +0200 |
---|---|---|
committer | Greg Kroah-Hartman <[email protected]> | 2022-08-18 19:33:40 +0200 |
commit | a872ab303d5ddd4c965f9cd868677781a33ce35a (patch) | |
tree | 18e875aa23f1e9d05c81f0a24f9b6c94768a33ee /tools/perf/scripts/python/syscall-counts.py | |
parent | c06795f114a6c4a423b11c9d9bbeb77ecbfbaa8b (diff) |
usb: dwc3: qcom: fix use-after-free on runtime-PM wakeup
The Qualcomm dwc3 runtime-PM implementation checks the xhci
platform-device pointer in the wakeup-interrupt handler to determine
whether the controller is in host mode and if so triggers a resume.
After a role switch in OTG mode the xhci platform-device would have been
freed and the next wakeup from runtime suspend would access the freed
memory.
Note that role switching is executed from a freezable workqueue, which
guarantees that the pointer is stable during suspend.
Also note that runtime PM has been broken since commit 2664deb09306
("usb: dwc3: qcom: Honor wakeup enabled/disabled state"), which
incidentally also prevents this issue from being triggered.
Fixes: a4333c3a6ba9 ("usb: dwc3: Add Qualcomm DWC3 glue driver")
Cc: [email protected] # 4.18
Reviewed-by: Matthias Kaehlcke <[email protected]>
Reviewed-by: Manivannan Sadhasivam <[email protected]>
Signed-off-by: Johan Hovold <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Greg Kroah-Hartman <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/syscall-counts.py')
0 files changed, 0 insertions, 0 deletions