Commit 7c03621a authored by David Kershner's avatar David Kershner Committed by Greg Kroah-Hartman

staging: unisys: Process more than one response per check

When s-Par is in polling mode it checks every 2 ms to see if there is
a response from the IO service partition in the queue. Currently it
just reads one entry per 2 ms, this needs to be changed so it drains
the queue on each check.
Signed-off-by: default avatarDavid Kershner <david.kershner@unisys.com>
Signed-off-by: default avatarBenjamin Romer <benjamin.romer@unisys.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 3abf4f98
...@@ -1629,93 +1629,95 @@ drain_queue(struct uiscmdrsp *cmdrsp, struct visornic_devdata *devdata) ...@@ -1629,93 +1629,95 @@ drain_queue(struct uiscmdrsp *cmdrsp, struct visornic_devdata *devdata)
/* TODO: CLIENT ACQUIRE -- Don't really need this at the /* TODO: CLIENT ACQUIRE -- Don't really need this at the
* moment */ * moment */
if (!visorchannel_signalremove(devdata->dev->visorchannel, for (;;) {
IOCHAN_FROM_IOPART, if (!visorchannel_signalremove(devdata->dev->visorchannel,
cmdrsp)) IOCHAN_FROM_IOPART,
return; /* queue empty */ cmdrsp))
break; /* queue empty */
switch (cmdrsp->net.type) {
case NET_RCV: switch (cmdrsp->net.type) {
devdata->chstat.got_rcv++; case NET_RCV:
/* process incoming packet */ devdata->chstat.got_rcv++;
visornic_rx(cmdrsp); /* process incoming packet */
break; visornic_rx(cmdrsp);
case NET_XMIT_DONE: break;
spin_lock_irqsave(&devdata->priv_lock, flags); case NET_XMIT_DONE:
devdata->chstat.got_xmit_done++; spin_lock_irqsave(&devdata->priv_lock, flags);
if (cmdrsp->net.xmtdone.xmt_done_result) devdata->chstat.got_xmit_done++;
devdata->chstat.xmit_fail++; if (cmdrsp->net.xmtdone.xmt_done_result)
/* only call queue wake if we stopped it */ devdata->chstat.xmit_fail++;
netdev = ((struct sk_buff *)cmdrsp->net.buf)->dev; /* only call queue wake if we stopped it */
/* ASSERT netdev == vnicinfo->netdev; */ netdev = ((struct sk_buff *)cmdrsp->net.buf)->dev;
if ((netdev == devdata->netdev) && /* ASSERT netdev == vnicinfo->netdev; */
netif_queue_stopped(netdev)) { if ((netdev == devdata->netdev) &&
/* check to see if we have crossed netif_queue_stopped(netdev)) {
* the lower watermark for /* check to see if we have crossed
* netif_wake_queue() * the lower watermark for
*/ * netif_wake_queue()
if (((devdata->chstat.sent_xmit >=
devdata->chstat.got_xmit_done) &&
(devdata->chstat.sent_xmit -
devdata->chstat.got_xmit_done <=
devdata->lower_threshold_net_xmits)) ||
((devdata->chstat.sent_xmit <
devdata->chstat.got_xmit_done) &&
(ULONG_MAX - devdata->chstat.got_xmit_done
+ devdata->chstat.sent_xmit <=
devdata->lower_threshold_net_xmits))) {
/* enough NET_XMITs completed
* so can restart netif queue
*/ */
netif_wake_queue(netdev); if (((devdata->chstat.sent_xmit >=
devdata->flow_control_lower_hits++; devdata->chstat.got_xmit_done) &&
(devdata->chstat.sent_xmit -
devdata->chstat.got_xmit_done <=
devdata->lower_threshold_net_xmits)) ||
((devdata->chstat.sent_xmit <
devdata->chstat.got_xmit_done) &&
(ULONG_MAX - devdata->chstat.got_xmit_done
+ devdata->chstat.sent_xmit <=
devdata->lower_threshold_net_xmits))) {
/* enough NET_XMITs completed
* so can restart netif queue
*/
netif_wake_queue(netdev);
devdata->flow_control_lower_hits++;
}
} }
} skb_unlink(cmdrsp->net.buf, &devdata->xmitbufhead);
skb_unlink(cmdrsp->net.buf, &devdata->xmitbufhead); spin_unlock_irqrestore(&devdata->priv_lock, flags);
spin_unlock_irqrestore(&devdata->priv_lock, flags); kfree_skb(cmdrsp->net.buf);
kfree_skb(cmdrsp->net.buf);
break;
case NET_RCV_ENBDIS_ACK:
devdata->chstat.got_enbdisack++;
netdev = (struct net_device *)
cmdrsp->net.enbdis.context;
spin_lock_irqsave(&devdata->priv_lock, flags);
devdata->enab_dis_acked = 1;
spin_unlock_irqrestore(&devdata->priv_lock, flags);
if (kthread_should_stop())
break; break;
if (devdata->server_down && case NET_RCV_ENBDIS_ACK:
devdata->server_change_state) { devdata->chstat.got_enbdisack++;
/* Inform Linux that the link is up */ netdev = (struct net_device *)
devdata->server_down = false; cmdrsp->net.enbdis.context;
devdata->server_change_state = false;
netif_wake_queue(netdev);
netif_carrier_on(netdev);
}
break;
case NET_CONNECT_STATUS:
netdev = devdata->netdev;
if (cmdrsp->net.enbdis.enable == 1) {
spin_lock_irqsave(&devdata->priv_lock, flags);
devdata->enabled = cmdrsp->net.enbdis.enable;
spin_unlock_irqrestore(&devdata->priv_lock,
flags);
netif_wake_queue(netdev);
netif_carrier_on(netdev);
} else {
netif_stop_queue(netdev);
netif_carrier_off(netdev);
spin_lock_irqsave(&devdata->priv_lock, flags); spin_lock_irqsave(&devdata->priv_lock, flags);
devdata->enabled = cmdrsp->net.enbdis.enable; devdata->enab_dis_acked = 1;
spin_unlock_irqrestore(&devdata->priv_lock, spin_unlock_irqrestore(&devdata->priv_lock, flags);
flags);
if (kthread_should_stop())
break;
if (devdata->server_down &&
devdata->server_change_state) {
/* Inform Linux that the link is up */
devdata->server_down = false;
devdata->server_change_state = false;
netif_wake_queue(netdev);
netif_carrier_on(netdev);
}
break;
case NET_CONNECT_STATUS:
netdev = devdata->netdev;
if (cmdrsp->net.enbdis.enable == 1) {
spin_lock_irqsave(&devdata->priv_lock, flags);
devdata->enabled = cmdrsp->net.enbdis.enable;
spin_unlock_irqrestore(&devdata->priv_lock,
flags);
netif_wake_queue(netdev);
netif_carrier_on(netdev);
} else {
netif_stop_queue(netdev);
netif_carrier_off(netdev);
spin_lock_irqsave(&devdata->priv_lock, flags);
devdata->enabled = cmdrsp->net.enbdis.enable;
spin_unlock_irqrestore(&devdata->priv_lock,
flags);
}
break;
default:
break;
} }
break; /* cmdrsp is now available for reuse */
default:
break;
} }
/* cmdrsp is now available for reuse */
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment