aboutsummaryrefslogtreecommitdiff
path: root/drivers/usb
diff options
context:
space:
mode:
authorAlistair Strachan <alistair.strachan@imgtec.com>2013-04-10 16:35:14 -0700
committerRom Lemarchand <romlem@google.com>2013-10-24 12:09:03 +0000
commit637dd81343b2019938cf6307f75bb7c934a99fc2 (patch)
tree291beeb39da9f7406004febfd27c2c25c063f2ad /drivers/usb
parent29f271de6ffdf6a96375cd244986617e87afc8d0 (diff)
sync: Fix a race condition between release_obj and print_obj
Before this change, a timeline would only be removed from the timeline list *after* the sync driver had its release_obj() called. However, the driver's release_obj() may free resources needed by print_obj(). Although the timeline list is locked when print_obj() is called, it is not locked when release_obj() is called. If one CPU was in print_obj() when another was in release_obj(), the print_obj() may make unsafe accesses. It is not actually necessary to hold the timeline list lock when calling release_obj() if the call is made after the timeline is unlinked from the list, since there is no possibility another thread could be in -- or enter -- print_obj() for that timeline. This change moves the release_obj() call to after the timeline is unlinked, preventing the above race from occurring. Signed-off-by: Alistair Strachan <alistair.strachan@imgtec.com> (cherry picked from commit 3bfc1e9e0c7d0c0e3f52ee1f3803482416afa295) Change-Id: Ib2b2b23fde5be34016f9d86b8b9c5e561b56cd4c
Diffstat (limited to 'drivers/usb')
0 files changed, 0 insertions, 0 deletions