]> git.baikalelectronics.ru Git - kernel.git/commit
net/smc: Fix hung_task when removing SMC-R devices
authorWen Gu <guwen@linux.alibaba.com>
Sun, 16 Jan 2022 07:43:42 +0000 (15:43 +0800)
committerDavid S. Miller <davem@davemloft.net>
Sun, 16 Jan 2022 12:30:28 +0000 (12:30 +0000)
commit65d4ad791034f24b4c8dac7a5f99e17d6a88f2ce
tree4284ef0b3b561af97ab5bd2dd8a6686fe86f7420
parent3e390c58f3ea262f8d5a3b01a7f4123f3491a0cd
net/smc: Fix hung_task when removing SMC-R devices

A hung_task is observed when removing SMC-R devices. Suppose that
a link group has two active links(lnk_A, lnk_B) associated with two
different SMC-R devices(dev_A, dev_B). When dev_A is removed, the
link group will be removed from smc_lgr_list and added into
lgr_linkdown_list. lnk_A will be cleared and smcibdev(A)->lnk_cnt
will reach to zero. However, when dev_B is removed then, the link
group can't be found in smc_lgr_list and lnk_B won't be cleared,
making smcibdev->lnk_cnt never reaches zero, which causes a hung_task.

This patch fixes this issue by restoring the implementation of
smc_smcr_terminate_all() to what it was before commit 05f6ef58da86
("net/smc: fix kernel panic caused by race of smc_sock"). The original
implementation also satisfies the intention that make sure QP destroy
earlier than CQ destroy because we will always wait for smcibdev->lnk_cnt
reaches zero, which guarantees QP has been destroyed.

Fixes: 05f6ef58da86 ("net/smc: fix kernel panic caused by race of smc_sock")
Signed-off-by: Wen Gu <guwen@linux.alibaba.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/smc/smc_core.c