summaryrefslogtreecommitdiffstats
path: root/drivers/cpufreq/cpufreq_ondemand.h
diff options
context:
space:
mode:
authorAlan Stern <stern@rowland.harvard.edu>2020-04-22 22:18:48 +0200
committerJiri Kosina <jkosina@suse.cz>2020-04-29 16:24:26 +0200
commit0ed08faded1da03eb3def61502b27f81aef2e615 (patch)
tree35b05447dc4293e0a4c29368253c432d8e071048 /drivers/cpufreq/cpufreq_ondemand.h
parentRevert "HID: wacom: generic: read the number of expected touches on a per col... (diff)
downloadlinux-0ed08faded1da03eb3def61502b27f81aef2e615.tar.xz
linux-0ed08faded1da03eb3def61502b27f81aef2e615.zip
HID: usbhid: Fix race between usbhid_close() and usbhid_stop()
The syzbot fuzzer discovered a bad race between in the usbhid driver between usbhid_stop() and usbhid_close(). In particular, usbhid_stop() does: usb_free_urb(usbhid->urbin); ... usbhid->urbin = NULL; /* don't mess up next start */ and usbhid_close() does: usb_kill_urb(usbhid->urbin); with no mutual exclusion. If the two routines happen to run concurrently so that usb_kill_urb() is called in between the usb_free_urb() and the NULL assignment, it will access the deallocated urb structure -- a use-after-free bug. This patch adds a mutex to the usbhid private structure and uses it to enforce mutual exclusion of the usbhid_start(), usbhid_stop(), usbhid_open() and usbhid_close() callbacks. Reported-and-tested-by: syzbot+7bf5a7b0f0a1f9446f4c@syzkaller.appspotmail.com Signed-off-by: Alan Stern <stern@rowland.harvard.edu> CC: <stable@vger.kernel.org> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'drivers/cpufreq/cpufreq_ondemand.h')
0 files changed, 0 insertions, 0 deletions