Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/xen/xen bump send queue to 2*NET_TX_RING_SIZE to ma...
details: https://anonhg.NetBSD.org/src/rev/d3d24488abb3
branches: trunk
changeset: 1009543:d3d24488abb3
user: jdolecek <jdolecek%NetBSD.org@localhost>
date: Sun Apr 26 13:09:52 2020 +0000
description:
bump send queue to 2*NET_TX_RING_SIZE to make it less likely packets
are dropped on load
m_defrag() short packets before calling bus_dmamap_load_mbuf() -
if it's fragmented load_mbuf would fail anyway, and even with
eventual feature-sg support it's way faster to pass the short packet
in single fragment
diffstat:
sys/arch/xen/xen/xennetback_xenbus.c | 14 ++++++++++++--
1 files changed, 12 insertions(+), 2 deletions(-)
diffs (42 lines):
diff -r 2c01a15dbdff -r d3d24488abb3 sys/arch/xen/xen/xennetback_xenbus.c
--- a/sys/arch/xen/xen/xennetback_xenbus.c Sun Apr 26 12:58:28 2020 +0000
+++ b/sys/arch/xen/xen/xennetback_xenbus.c Sun Apr 26 13:09:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: xennetback_xenbus.c,v 1.97 2020/04/25 11:33:28 jdolecek Exp $ */
+/* $NetBSD: xennetback_xenbus.c,v 1.98 2020/04/26 13:09:52 jdolecek Exp $ */
/*
* Copyright (c) 2006 Manuel Bouyer.
@@ -25,7 +25,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: xennetback_xenbus.c,v 1.97 2020/04/25 11:33:28 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: xennetback_xenbus.c,v 1.98 2020/04/26 13:09:52 jdolecek Exp $");
#include "opt_xen.h"
@@ -269,6 +269,7 @@
ifp->if_init = xennetback_ifinit;
ifp->if_stop = xennetback_ifstop;
ifp->if_timer = 0;
+ IFQ_SET_MAXLEN(&ifp->if_snd, uimax(2 * NET_TX_RING_SIZE, IFQ_MAXLEN));
IFQ_SET_READY(&ifp->if_snd);
if_attach(ifp);
if_deferred_start_init(ifp, NULL);
@@ -912,6 +913,15 @@
xst = &xneti->xni_xstate[i];
+ /*
+ * For short packets it's always way faster passing
+ * single defragmented packet, even with feature-sg.
+ * Try to defragment first if the result is likely
+ * to fit into a single mbuf.
+ */
+ if (m->m_pkthdr.len < MCLBYTES && m->m_next)
+ (void)m_defrag(m, M_DONTWAIT);
+
if (bus_dmamap_load_mbuf(
xneti->xni_xbusd->xbusd_dmat,
xst->xs_dmamap, m, BUS_DMA_NOWAIT) != 0) {
Home |
Main Index |
Thread Index |
Old Index