summaryrefslogtreecommitdiffstats
path: root/net/smc
diff options
context:
space:
mode:
authorUrsula Braun <ubraun@linux.ibm.com>2018-11-22 04:26:38 -0500
committerDavid S. Miller <davem@davemloft.net>2018-11-23 20:20:32 -0500
commit90d8b29cb4b251cd874aa00a50d11b28a7322986 (patch)
tree7563db747946b6609962c4a7f5a15e46afb47735 /net/smc
parent9ed28556a388fdb894bdf9bd64c05cf6e7783ba3 (diff)
net/smc: no link delete for a never active link
If a link is terminated that has never reached the active state, there is no need to trigger an LLC DELETE LINK. Signed-off-by: Ursula Braun <ubraun@linux.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/smc')
-rw-r--r--net/smc/smc_core.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/net/smc/smc_core.c b/net/smc/smc_core.c
index 4812ca30f1dc..ec7a7ed3b968 100644
--- a/net/smc/smc_core.c
+++ b/net/smc/smc_core.c
@@ -173,8 +173,11 @@ free:
173 spin_unlock_bh(&smc_lgr_list.lock); 173 spin_unlock_bh(&smc_lgr_list.lock);
174 174
175 if (!lgr->is_smcd && !lgr->terminating) { 175 if (!lgr->is_smcd && !lgr->terminating) {
176 struct smc_link *lnk = &lgr->lnk[SMC_SINGLE_LINK];
177
176 /* try to send del link msg, on error free lgr immediately */ 178 /* try to send del link msg, on error free lgr immediately */
177 if (!smc_link_send_delete(&lgr->lnk[SMC_SINGLE_LINK])) { 179 if (lnk->state == SMC_LNK_ACTIVE &&
180 !smc_link_send_delete(lnk)) {
178 /* reschedule in case we never receive a response */ 181 /* reschedule in case we never receive a response */
179 smc_lgr_schedule_free_work(lgr); 182 smc_lgr_schedule_free_work(lgr);
180 return; 183 return;