• L
    [PATCH] ep93xx_eth: fix RX/TXstatus ring full handling · 2d38caba
    Lennert Buytenhek 提交于
    Ray Lehtiniemi reported that an incoming UDP packet flood can lock up
    the ep93xx ethernet driver.  Herbert Valerio Riedel noted that due to
    the way ep93xx_eth manages the RX/TXstatus rings, it cannot distinguish
    a full ring from an empty one, and correctly suggested that this was
    likely to be causing this lockup to occur.
    
    Instead of looking at the hardware's RX/TXstatus ring write pointers
    to determine when to stop reading from those rings, we should just check
    every individual RX/TXstatus descriptor's valid bit instead, since there
    is no other way to distinguish an empty ring from a full ring, and if
    there is a descriptor waiting, we take the hit of reading the descriptor
    from memory anyway.
    Signed-off-by: NLennert Buytenhek <buytenh@wantstofly.org>
    Signed-off-by: NJeff Garzik <jeff@garzik.org>
    2d38caba
ep93xx_eth.c 21.5 KB