diff options
author | Esben Haabendal <esben@geanix.com> | 2020-02-21 07:47:21 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2020-02-24 10:58:48 -0800 |
commit | 84823ff80f7403752b59e00bb198724100dc611c (patch) | |
tree | e8a373a6d314a81b514f23a20a00b3f1e82855be /drivers/bluetooth | |
parent | net: core: devlink.c: Hold devlink->lock from the beginning of devlink_dpipe_table_register() (diff) | |
download | linux-dev-84823ff80f7403752b59e00bb198724100dc611c.tar.xz linux-dev-84823ff80f7403752b59e00bb198724100dc611c.zip |
net: ll_temac: Fix race condition causing TX hang
It is possible that the interrupt handler fires and frees up space in
the TX ring in between checking for sufficient TX ring space and
stopping the TX queue in temac_start_xmit. If this happens, the
queue wake from the interrupt handler will occur before the queue is
stopped, causing a lost wakeup and the adapter's transmit hanging.
To avoid this, after stopping the queue, check again whether there is
sufficient space in the TX ring. If so, wake up the queue again.
This is a port of the similar fix in axienet driver,
commit 7de44285c1f6 ("net: axienet: Fix race condition causing TX hang").
Fixes: 23ecc4bde21f ("net: ll_temac: fix checksum offload logic")
Signed-off-by: Esben Haabendal <esben@geanix.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/bluetooth')
0 files changed, 0 insertions, 0 deletions