net/ncsi: Don't deselect package in suspend if active
authorSamuel Mendoza-Jonas <sam@mendozajonas.com>
Fri, 16 Nov 2018 04:51:56 +0000 (15:51 +1100)
committerDavid S. Miller <davem@davemloft.net>
Sun, 18 Nov 2018 05:09:49 +0000 (21:09 -0800)
When a package is deselected all channels of that package cease
communication. If there are other channels active on the package of the
suspended channel this will disable them as well, so only send a
deselect-package command if no other channels are active.

Signed-off-by: Samuel Mendoza-Jonas <sam@mendozajonas.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ncsi/ncsi-manage.c

index 02421d1a22c950cd5f7e2b46682a171277f2868e..b8b4e765a04c22308c9727f87d3cead98ca6b8d5 100644 (file)
@@ -440,12 +440,14 @@ static void ncsi_request_timeout(struct timer_list *t)
 static void ncsi_suspend_channel(struct ncsi_dev_priv *ndp)
 {
        struct ncsi_dev *nd = &ndp->ndev;
-       struct ncsi_package *np = ndp->active_package;
-       struct ncsi_channel *nc = ndp->active_channel;
+       struct ncsi_package *np;
+       struct ncsi_channel *nc, *tmp;
        struct ncsi_cmd_arg nca;
        unsigned long flags;
        int ret;
 
+       np = ndp->active_package;
+       nc = ndp->active_channel;
        nca.ndp = ndp;
        nca.req_flags = NCSI_REQ_FLAG_EVENT_DRIVEN;
        switch (nd->state) {
@@ -521,6 +523,15 @@ static void ncsi_suspend_channel(struct ncsi_dev_priv *ndp)
                if (ret)
                        goto error;
 
+               NCSI_FOR_EACH_CHANNEL(np, tmp) {
+                       /* If there is another channel active on this package
+                        * do not deselect the package.
+                        */
+                       if (tmp != nc && tmp->state == NCSI_CHANNEL_ACTIVE) {
+                               nd->state = ncsi_dev_state_suspend_done;
+                               break;
+                       }
+               }
                break;
        case ncsi_dev_state_suspend_deselect:
                ndp->pending_req_num = 1;