Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci Use if_initialize() and if_register()
details: https://anonhg.NetBSD.org/src/rev/52be0c7b040b
branches: trunk
changeset: 1012438:52be0c7b040b
user: yamaguchi <yamaguchi%NetBSD.org@localhost>
date: Fri Jul 31 09:34:33 2020 +0000
description:
Use if_initialize() and if_register()
diffstat:
sys/dev/pci/if_ixl.c | 18 ++++++++++++++----
1 files changed, 14 insertions(+), 4 deletions(-)
diffs (67 lines):
diff -r 5ddeddf503d6 -r 52be0c7b040b sys/dev/pci/if_ixl.c
--- a/sys/dev/pci/if_ixl.c Fri Jul 31 09:25:42 2020 +0000
+++ b/sys/dev/pci/if_ixl.c Fri Jul 31 09:34:33 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_ixl.c,v 1.70 2020/07/31 09:25:42 yamaguchi Exp $ */
+/* $NetBSD: if_ixl.c,v 1.71 2020/07/31 09:34:33 yamaguchi Exp $ */
/*
* Copyright (c) 2013-2015, Intel Corporation
@@ -74,7 +74,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_ixl.c,v 1.70 2020/07/31 09:25:42 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_ixl.c,v 1.71 2020/07/31 09:34:33 yamaguchi Exp $");
#ifdef _KERNEL_OPT
#include "opt_net_mpsafe.h"
@@ -701,6 +701,7 @@
struct ixl_dmamem sc_hmc_pd;
struct ixl_hmc_entry sc_hmc_entries[IXL_HMC_COUNT];
+ struct if_percpuq *sc_ipq;
unsigned int sc_tx_ring_ndescs;
unsigned int sc_rx_ring_ndescs;
unsigned int sc_nqueue_pairs;
@@ -1418,7 +1419,13 @@
ifmedia_add(&sc->sc_media, IFM_ETHER | IFM_NONE, 0, NULL);
ifmedia_set(&sc->sc_media, IFM_ETHER | IFM_AUTO);
- if_attach(ifp);
+ rv = if_initialize(ifp);
+ if (rv != 0) {
+ aprint_error_dev(self, "if_initialize failed=%d\n", rv);
+ goto teardown_wqs;
+ }
+
+ sc->sc_ipq = if_percpuq_create(ifp);
if_deferred_start_init(ifp, NULL);
ether_ifattach(ifp, sc->sc_enaddr);
ether_set_ifflags_cb(&sc->sc_ec, ixl_ifflags_cb);
@@ -1470,6 +1477,8 @@
sc->sc_itr_rx = IXL_ITR_RX;
sc->sc_itr_tx = IXL_ITR_TX;
sc->sc_attached = true;
+ if_register(ifp);
+
return;
teardown_wqs:
@@ -1556,6 +1565,7 @@
sc->sc_workq_txrx = NULL;
}
+ if_percpuq_destroy(sc->sc_ipq);
ether_ifdetach(ifp);
if_detach(ifp);
ifmedia_fini(&sc->sc_media);
@@ -3332,7 +3342,7 @@
if_statinc_ref(nsr, if_ipackets);
if_statadd_ref(nsr, if_ibytes,
m->m_pkthdr.len);
- if_percpuq_enqueue(ifp->if_percpuq, m);
+ if_percpuq_enqueue(sc->sc_ipq, m);
} else {
if_statinc_ref(nsr, if_ierrors);
m_freem(m);
Home |
Main Index |
Thread Index |
Old Index