]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
net/smc: fix handling of delete link requests
authorKarsten Graul <kgraul@linux.ibm.com>
Sat, 18 Jul 2020 13:06:15 +0000 (15:06 +0200)
committerDavid S. Miller <davem@davemloft.net>
Sun, 19 Jul 2020 22:30:22 +0000 (15:30 -0700)
As smc client the delete link requests are assigned to the flow when
_any_ flow is active. This may break other flows that do not expect
delete link requests during their handling. Fix that by assigning the
request only when an add link flow is active. With that fix the code
for smc client and smc server is the same, so remove the separate
handling.

Reviewed-by: Ursula Braun <ubraun@linux.ibm.com>
Fixes: 9ec6bf19ec8b ("net/smc: llc_del_link_work and use the LLC flow for delete link")
Signed-off-by: Karsten Graul <kgraul@linux.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/smc/smc_llc.c

index 30da040ab5b6cf56c1cb016c7958c9afbaaa1fda..fa8cd57a9b32cd88676fc4ccf468a0e35219f552 100644 (file)
@@ -1544,28 +1544,13 @@ static void smc_llc_event_handler(struct smc_llc_qentry *qentry)
                }
                break;
        case SMC_LLC_DELETE_LINK:
-               if (lgr->role == SMC_CLNT) {
-                       /* server requests to delete this link, send response */
-                       if (lgr->llc_flow_lcl.type != SMC_LLC_FLOW_NONE) {
-                               /* DEL LINK REQ during ADD LINK SEQ */
-                               smc_llc_flow_qentry_set(&lgr->llc_flow_lcl,
-                                                       qentry);
-                               wake_up(&lgr->llc_msg_waiter);
-                       } else if (smc_llc_flow_start(&lgr->llc_flow_lcl,
-                                                     qentry)) {
-                               schedule_work(&lgr->llc_del_link_work);
-                       }
-               } else {
-                       if (lgr->llc_flow_lcl.type == SMC_LLC_FLOW_ADD_LINK &&
-                           !lgr->llc_flow_lcl.qentry) {
-                               /* DEL LINK REQ during ADD LINK SEQ */
-                               smc_llc_flow_qentry_set(&lgr->llc_flow_lcl,
-                                                       qentry);
-                               wake_up(&lgr->llc_msg_waiter);
-                       } else if (smc_llc_flow_start(&lgr->llc_flow_lcl,
-                                                     qentry)) {
-                               schedule_work(&lgr->llc_del_link_work);
-                       }
+               if (lgr->llc_flow_lcl.type == SMC_LLC_FLOW_ADD_LINK &&
+                   !lgr->llc_flow_lcl.qentry) {
+                       /* DEL LINK REQ during ADD LINK SEQ */
+                       smc_llc_flow_qentry_set(&lgr->llc_flow_lcl, qentry);
+                       wake_up(&lgr->llc_msg_waiter);
+               } else if (smc_llc_flow_start(&lgr->llc_flow_lcl, qentry)) {
+                       schedule_work(&lgr->llc_del_link_work);
                }
                return;
        case SMC_LLC_CONFIRM_RKEY: