summaryrefslogtreecommitdiff
path: root/block
diff options
context:
space:
mode:
authorGao Feng <fgao@ikuai8.com>2016-08-25 01:45:39 (GMT)
committerDavid S. Miller <davem@davemloft.net>2016-08-26 00:02:48 (GMT)
commitb628d611a2a53858263fc419dba552f32431dba4 (patch)
treea0f36ccc5eba2cc45525c0bd55c7d72b6a1db79b /block
parentf38ff2ee7727994685494bcc4d7c274b35b5418a (diff)
downloadlinux-b628d611a2a53858263fc419dba552f32431dba4.tar.xz
8139cp: Fix one possible deadloop in cp_rx_poll
When cp_rx_poll does not get enough packet, it will check the rx interrupt status again. If so, it will jumpt to rx_status_loop again. But the goto jump resets the rx variable as zero too. As a result, it causes one possible deadloop. Assume this case, rx_status_loop only gets the packet count which is less than budget, and (cpr16(IntrStatus) & cp_rx_intr_mask) condition is always true. It causes the deadloop happens and system is blocked. Signed-off-by: Gao Feng <fgao@ikuai8.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'block')
0 files changed, 0 insertions, 0 deletions