diff options
author | 2014-04-14 11:19:53 +0800 | |
---|---|---|
committer | 2014-04-16 10:11:47 -0500 | |
commit | 97839ca4b06ab27790700ad7da6be9a75fc0cc1d (patch) | |
tree | 1aad06a0dfb7fd602f3f276bbce68013186ee3e3 /tools/perf/scripts/python/syscall-counts.py | |
parent | usb: phy: return an error in usb_get_phy() if try_module_get() fails (diff) | |
download | linux-dev-97839ca4b06ab27790700ad7da6be9a75fc0cc1d.tar.xz linux-dev-97839ca4b06ab27790700ad7da6be9a75fc0cc1d.zip |
usb: gadget: ffs: race between ffs_epfile_io() and ffs_func_eps_disable()
ffs_epfile_io() is called from userspace, while ffs_func_eps_disable() might be
called from USB disconnect interrupt, the two functions would run in parallel
but they are not well protected, that epfile->ep would be removed by
ffs_func_eps_disable() during ffs_epfile_io() is referring this pointer, then
it leads to kernel PANIC.
The scenario is as below:
Thread 1 Thread 2
| |
SyS_read dwc3_gadget_disconnect_interrupt
| |
ffs_epfile_read reset_config
| |
ffs_epfile_io ffs_func_eps_disable
| |
----- usb_ep_disable(): epfile->ep->ep->desc = NULL
| |
usb_ep_align_maybe(): -----
it refers ep->desc->wMaxPacketSize -----
Signed-off-by: Chao Bi <chao.bi@intel.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
Diffstat (limited to 'tools/perf/scripts/python/syscall-counts.py')
0 files changed, 0 insertions, 0 deletions