aboutsummaryrefslogtreecommitdiff
path: root/tools/perf/scripts/python
diff options
context:
space:
mode:
authorArvid Brodin <[email protected]>2011-11-23 18:13:02 +0100
committerGreg Kroah-Hartman <[email protected]>2011-11-26 20:02:47 -0800
commitc64391f264b7658c00515173cca58f5b054af1a2 (patch)
tree67a403acfca8903a10bd45b86fe22488de476472 /tools/perf/scripts/python
parente08f6a2790aaf3563e7800399321c0fb9a6c6636 (diff)
usb/isp1760: Fix race condition memory leak
This fixes a memory leak reported by Catalin Marinas: schedule_ptds() is called from isp1760_irq() and removes the qh from the controlqhs queue but ep->hcpriv still points to the qh and therefore it is not freed. Shortly after this, the isp1760_endpoint_disable() function sets ep->hcpriv to NULL and calls schedule_ptds() but since the corresponding qh is no longer in the queue, it is simply forgotten and reported by kmemleak. With this patch, the qh is always freed at endpoint_disable, instead, and the corresponding entry removed from the queue head list. While I was at it, I also replaced the lines in isp1760_endpoint_disable() that removed remaining qtds from the qh with a WARN_ON check for non-empty qh, in line with earlier comments from Alan Stern (linux-usb list, 2011-07-20). Signed-off-by: Arvid Brodin <[email protected]> Tested-by: Catalin Marinas <[email protected]> Signed-off-by: Greg Kroah-Hartman <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python')
0 files changed, 0 insertions, 0 deletions