summaryrefslogtreecommitdiff
path: root/drivers/nvmem/zynqmp_nvmem.c
diff options
context:
space:
mode:
authorJulian Wiedmann <jwi@linux.ibm.com>2019-04-17 19:17:35 +0300
committerDavid S. Miller <davem@davemloft.net>2019-04-17 20:33:59 +0300
commit54a50941b7db8726732919daa859b931a9f496e2 (patch)
tree8d34ae098a862a52ff80102c5344d959e2998c79 /drivers/nvmem/zynqmp_nvmem.c
parente6c15b5f34a9c7dede9ba4b251f90abe5fbd40f6 (diff)
downloadlinux-54a50941b7db8726732919daa859b931a9f496e2.tar.xz
s390/qeth: stop/wake TX queues based on their fill level
Current xmit code only stops the txq after attempting to fill an IO buffer that hasn't been TX-completed yet. In many-connection scenarios, this can result in frequent rejected TX attempts, requeuing of skbs with NETDEV_TX_BUSY and extra overhead. Now that we have a proper 1-to-1 relation between stack-side txqs and our HW Queues, overhaul the stop/wake logic so that the xmit code stops the txq as needed. Given that we might map multiple skbs into a single buffer, it's crucial to ensure that the queue always provides an _entirely_ empty IO buffer. Otherwise large skbs (eg TSO) might not fit into the last available buffer. So whenever qeth_do_send_packet() first utilizes an _empty_ buffer, it updates & checks the used_buffers count. This now ensures that an skb passed to qeth_xmit() can always be mapped into an IO buffer, so remove all of the -EBUSY roll-back handling in the TX path. We preserve the minimal safety-checks ("Is this IO buffer really available?"), just in case some nasty future bug ever attempts to corrupt an in-use buffer. Signed-off-by: Julian Wiedmann <jwi@linux.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/nvmem/zynqmp_nvmem.c')
0 files changed, 0 insertions, 0 deletions