Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/netbsd-9]: src/sys/modules/usbnet Pull up following revision(s) (request...
details: https://anonhg.NetBSD.org/src/rev/204d9590c16e
branches: netbsd-9
changeset: 1000770:204d9590c16e
user: martin <martin%NetBSD.org@localhost>
date: Sun Sep 01 13:00:36 2019 +0000
description:
Pull up following revision(s) (requested by mrg in ticket #135):
distrib/sets/lists/comp/mi 1.2279
distrib/sets/lists/modules/mi 1.123
share/man/man9/Makefile 1.438
share/man/man9/usbnet.9 1.1-1.9
sys/dev/ic/rndisreg.h 1.3
sys/dev/usb/TODO 1.47-1.52
sys/dev/usb/TODO.usbmp 1.15,1.16
sys/dev/usb/files.usb 1.157-1.167
sys/dev/usb/if_aue.c 1.155-1.161
sys/dev/usb/if_auereg.h 1.30-1.32
sys/dev/usb/if_axe.c 1.103-1.119
sys/dev/usb/if_axen.c 1.51-1.53,1.55-1.67
sys/dev/usb/if_axenreg.h 1.15
sys/dev/usb/if_cdce.c 1.54-1.67
sys/dev/usb/if_cue.c 1.85,1.86
sys/dev/usb/if_cuereg.h 1.23
sys/dev/usb/if_kue.c 1.97-1.100
sys/dev/usb/if_kuereg.h 1.23,1.24
sys/dev/usb/if_mue.c 1.51-1.55
sys/dev/usb/if_muereg.h 1.6
sys/dev/usb/if_muevar.h 1.9
sys/dev/usb/if_smsc.c 1.46-1.61
sys/dev/usb/if_smscreg.h 1.6
sys/dev/usb/if_smscvar.h delete
sys/dev/usb/if_udav.c 1.60-1.71
sys/dev/usb/if_udavreg.h 1.14,1.15
sys/dev/usb/if_upl.c 1.65,1.66
sys/dev/usb/if_ure.c 1.15-1.31
sys/dev/usb/if_urevar.h 1.4,1.5
sys/dev/usb/if_url.c 1.67-1.70
sys/dev/usb/if_urlreg.h 1.14
sys/dev/usb/if_urndis.c 1.22-1.33
sys/dev/usb/if_urtwn.c 1.72
sys/dev/usb/ohci.c 1.290
sys/dev/usb/uhub.c 1.143
sys/dev/usb/usb.c 1.180
sys/dev/usb/usb.h 1.118
sys/dev/usb/usb_mem.c 1.71
sys/dev/usb/usb_subr.c 1.238,1.239
sys/dev/usb/usbdevs 1.772
sys/dev/usb/usbdi.c 1.183,1.186
sys/dev/usb/usbdi.h 1.97
sys/dev/usb/usbdi_util.c 1.75
sys/dev/usb/usbhist.h 1.5,1.6
sys/dev/usb/usbnet.c 1.1-1.24
sys/dev/usb/usbnet.h 1.1-1.14
sys/dev/usb/usbroothub.c 1.9
sys/dev/usb/xhci.c 1.109,1.110
sys/modules/Makefile 1.223
sys/modules/usbnet/Makefile 1.1
usbnet(9): Add common framework for USB network devices.
This bring various safety fixes to all updated drivers,
and includes locking clean up, detach safety when being
used or not, separate rx/tx locks to improve performance,
porting to NET_MPSAFE, many edge/error case bugs in
drivers fixed, as well as resovling PRs 54303 and 54308.
These drivers are converted: axe(4), axen(4), aue(4),
cdce(4), cue(4), kue(4), mue(4), smsc(4), udav(4),
upl(4), ure(4), url(4), and urndis(4).
diffstat:
distrib/sets/lists/comp/mi | 5 +-
distrib/sets/lists/modules/mi | 4 +-
share/man/man9/Makefile | 15 +-
share/man/man9/usbnet.9 | 894 +++++++++++++++++++++++
sys/dev/ic/rndisreg.h | 11 +-
sys/dev/usb/TODO | 28 +-
sys/dev/usb/TODO.usbmp | 44 +-
sys/dev/usb/files.usb | 32 +-
sys/dev/usb/if_auereg.h | 78 +-
sys/dev/usb/if_axe.c | 1376 ++++++-----------------------------
sys/dev/usb/if_axen.c | 1571 ++++++++--------------------------------
sys/dev/usb/if_axenreg.h | 11 +-
sys/dev/usb/if_cdce.c | 876 ++--------------------
sys/dev/usb/if_cue.c | 1125 ++++++----------------------
sys/dev/usb/if_cuereg.h | 73 +-
sys/dev/usb/if_kue.c | 903 +++++------------------
sys/dev/usb/if_kuereg.h | 67 +-
sys/dev/usb/if_mue.c | 1524 +++++++++++----------------------------
sys/dev/usb/if_muereg.h | 6 +-
sys/dev/usb/if_muevar.h | 67 +-
sys/dev/usb/if_smsc.c | 1440 ++++++++++---------------------------
sys/dev/usb/if_smscreg.h | 8 +-
sys/dev/usb/if_smscvar.h | 106 --
sys/dev/usb/if_udav.c | 1418 ++++++++----------------------------
sys/dev/usb/if_udavreg.h | 62 +-
sys/dev/usb/if_upl.c | 909 ++--------------------
sys/dev/usb/if_ure.c | 1362 +++++++++--------------------------
sys/dev/usb/if_urevar.h | 75 +-
sys/dev/usb/if_url.c | 1354 +++++++---------------------------
sys/dev/usb/if_urlreg.h | 60 +-
sys/dev/usb/if_urndis.c | 971 ++++++-------------------
sys/dev/usb/if_urtwn.c | 11 +-
sys/dev/usb/ohci.c | 6 +-
sys/dev/usb/uhub.c | 24 +-
sys/dev/usb/usb.c | 19 +-
sys/dev/usb/usb.h | 23 +-
sys/dev/usb/usb_mem.c | 12 +-
sys/dev/usb/usb_subr.c | 173 ++-
sys/dev/usb/usbdi.c | 98 +-
sys/dev/usb/usbdi.h | 5 +-
sys/dev/usb/usbdi_util.c | 130 +-
sys/dev/usb/usbhist.h | 14 +-
sys/dev/usb/usbnet.c | 1566 ++++++++++++++++++++++++++++++++++++++++
sys/dev/usb/usbnet.h | 397 ++++++++++
sys/dev/usb/usbroothub.c | 19 +-
sys/dev/usb/xhci.c | 9 +-
sys/modules/Makefile | 3 +-
sys/modules/usbnet/Makefile | 12 +
48 files changed, 6594 insertions(+), 12402 deletions(-)
diffs (truncated from 25915 to 300 lines):
diff -r cdedaaf6d785 -r 204d9590c16e distrib/sets/lists/comp/mi
--- a/distrib/sets/lists/comp/mi Sun Sep 01 11:12:45 2019 +0000
+++ b/distrib/sets/lists/comp/mi Sun Sep 01 13:00:36 2019 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.2278.2.3 2019/08/16 19:28:26 martin Exp $
+# $NetBSD: mi,v 1.2278.2.4 2019/09/01 13:00:37 martin Exp $
#
# Note: don't delete entries from here - mark them as "obsolete" instead.
./etc/mtree/set.comp comp-sys-root
@@ -11967,6 +11967,7 @@
./usr/share/man/cat9/uprintf.0 comp-sys-catman .cat
./usr/share/man/cat9/usbd_status.0 comp-sys-catman .cat
./usr/share/man/cat9/usbdi.0 comp-sys-catman .cat
+./usr/share/man/cat9/usbnet.0 comp-sys-catman .cat
./usr/share/man/cat9/useracc.0 comp-obsolete obsolete
./usr/share/man/cat9/userret.0 comp-sys-catman .cat
./usr/share/man/cat9/ustore.0 comp-sys-catman .cat
@@ -19854,6 +19855,7 @@
./usr/share/man/html9/uprintf.html comp-sys-htmlman html
./usr/share/man/html9/usbd_status.html comp-sys-htmlman html
./usr/share/man/html9/usbdi.html comp-sys-htmlman html
+./usr/share/man/html9/usbnet.html comp-sys-htmlman html
./usr/share/man/html9/userret.html comp-sys-htmlman html
./usr/share/man/html9/ustore.html comp-sys-htmlman html
./usr/share/man/html9/ustore_16.html comp-sys-htmlman html
@@ -27948,6 +27950,7 @@
./usr/share/man/man9/uprintf.9 comp-sys-man .man
./usr/share/man/man9/usbd_status.9 comp-sys-man .man
./usr/share/man/man9/usbdi.9 comp-sys-man .man
+./usr/share/man/man9/usbnet.9 comp-sys-man .man
./usr/share/man/man9/useracc.9 comp-obsolete obsolete
./usr/share/man/man9/userret.9 comp-sys-man .man
./usr/share/man/man9/ustore.9 comp-sys-man .man
diff -r cdedaaf6d785 -r 204d9590c16e distrib/sets/lists/modules/mi
--- a/distrib/sets/lists/modules/mi Sun Sep 01 11:12:45 2019 +0000
+++ b/distrib/sets/lists/modules/mi Sun Sep 01 13:00:36 2019 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.122 2019/06/20 03:31:55 pgoyette Exp $
+# $NetBSD: mi,v 1.122.2.1 2019/09/01 13:00:37 martin Exp $
#
# Note: don't delete entries from here - mark them as "obsolete" instead.
#
@@ -440,6 +440,8 @@
./@MODULEDIR@/umap/umap.kmod base-kernel-modules kmod
./@MODULEDIR@/union base-kernel-modules kmod
./@MODULEDIR@/union/union.kmod base-kernel-modules kmod
+./@MODULEDIR@/usbnet base-kernel-modules kmod
+./@MODULEDIR@/usbnet/usbnet.kmod base-kernel-modules kmod
./@MODULEDIR@/usbverbose base-kernel-modules kmod
./@MODULEDIR@/usbverbose/usbverbose.kmod base-kernel-modules kmod
./@MODULEDIR@/v7fs base-kernel-modules kmod
diff -r cdedaaf6d785 -r 204d9590c16e share/man/man9/Makefile
--- a/share/man/man9/Makefile Sun Sep 01 11:12:45 2019 +0000
+++ b/share/man/man9/Makefile Sun Sep 01 13:00:36 2019 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.437 2019/05/08 14:25:39 isaki Exp $
+# $NetBSD: Makefile,v 1.437.2.1 2019/09/01 13:00:37 martin Exp $
# Makefile for section 9 (kernel function and variable) manual pages.
@@ -53,17 +53,18 @@
SET.9 setbit.9 setjmp.9 shutdownhook_establish.9 \
signal.9 skpc.9 sockopt.9 softintr.9 spl.9 specificdata.9 \
spi.9 splraiseipl.9 \
+ store.9 \
suspendsched.9 \
sysctl.9 sysmon_envsys.9 sysmon_pswitch.9 sysmon_taskq.9 tc.9 \
tcp_congctl.9 threadpool.9 timecounter.9 time_second.9 todr.9 \
ts2timo.9 tvtohz.9 \
- ucas.9 uiomove.9 ucom.9 userret.9 \
+ ubc.9 ucas.9 ucom.9 ufetch.9 uiomove.9 \
+ usbd_status.9 usbdi.9 usbnet.9 \
+ userret.9 \
+ uvm.9 uvm_hotplug.9 uvm_km.9 uvm_map.9 \
vattr.9 veriexec.9 vcons.9 vfs.9 vfs_hooks.9 vfsops.9 vfssubr.9 \
- video.9 vme.9 \
- vnfileops.9 vnode.9 vnodeops.9 vnsubr.9 \
- ubc.9 ufetch.9 usbd_status.9 usbdi.9 ustore.9 uvm.9 uvm_hotplug.9 \
- uvm_km.9 uvm_map.9 \
- vmem.9 wapbl.9 wdc.9 workqueue.9 \
+ video.9 vme.9 vnfileops.9 vnode.9 vnodeops.9 vnsubr.9 vmem.9 \
+ wapbl.9 wdc.9 workqueue.9 \
wsbell.9 wscons.9 wsdisplay.9 wsfont.9 wskbd.9 wsmouse.9 \
xcall.9
diff -r cdedaaf6d785 -r 204d9590c16e share/man/man9/usbnet.9
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/share/man/man9/usbnet.9 Sun Sep 01 13:00:36 2019 +0000
@@ -0,0 +1,894 @@
+.\" $NetBSD: usbnet.9,v 1.9.2.2 2019/09/01 13:00:37 martin Exp $
+.\"
+.\" Copyright (c) 2019 Matthew R. Green
+.\" All rights reserved.
+.\"
+.\" Redistribution and use in source and binary forms, with or without
+.\" modification, are permitted provided that the following conditions
+.\" are met:
+.\" 1. Redistributions of source code must retain the above copyright
+.\" notice, this list of conditions and the following disclaimer.
+.\" 2. Redistributions in binary form must reproduce the above copyright
+.\" notice, this list of conditions and the following disclaimer in the
+.\" documentation and/or other materials provided with the distribution.
+.\" 3. The name of the author may not be used to endorse or promote products
+.\" derived from this software without specific prior written permission.
+.\"
+.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
+.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+.\" BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+.\" LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+.\" AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+.\" OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+.\" SUCH DAMAGE.
+.\"
+.Dd August 22, 2019
+.Dt USBNET 9
+.Os
+.Sh NAME
+.Nm usbnet
+.Nd common USB Ethernet driver framework
+.Sh SYNOPSIS
+.In dev/usb/usbnet.h
+.Ss Functions offered by usbnet.h
+.Ft void
+.Fn usbnet_set_link "struct usbnet *un" "bool link"
+.Ft void
+.Fn usbnet_set_dying "struct usbnet *un" "bool dying"
+.Ft struct ifnet *
+.Fn usbnet_ifp "struct usbnet *un"
+.Ft struct ethercom *
+.Fn usbnet_ec "struct usbnet *un"
+.Ft struct mii_data *
+.Fn usbnet_mii "struct usbnet *un"
+.Ft krndsource_t *
+.Fn usbnet_rndsrc "struct usbnet *un"
+.Ft void *
+.Fn usbnet_softc "struct usbnet *un"
+.Ft bool
+.Fn usbnet_havelink "struct usbnet *un"
+.Ft bool
+.Fn usbnet_isdying "struct usbnet *un"
+.Ft void
+.Fn usbnet_lock "struct usbnet *un"
+.Ft void
+.Fn usbnet_unlock "struct usbnet *un"
+.Ft kmutex_t *
+.Fn usbnet_mutex "struct usbnet *un"
+.Ft void
+.Fn usbnet_isowned "struct usbnet *un"
+.Ft void
+.Fn usbnet_lock_rx "struct usbnet *un"
+.Ft void
+.Fn usbnet_unlock_rx "struct usbnet *un"
+.Ft kmutex_t *
+.Fn usbnet_mutex_rx "struct usbnet *un"
+.Ft void
+.Fn usbnet_isowned_rx "struct usbnet *un"
+.Ft void
+.Fn usbnet_lock_tx "struct usbnet *un"
+.Ft void
+.Fn usbnet_unlock_tx "struct usbnet *un"
+.Ft kmutex_t *
+.Fn usbnet_mutex_tx "struct usbnet *un"
+.Ft void
+.Fn usbnet_isowned_tx "struct usbnet *un"
+.Ft int
+.Fn usbnet_init_rx_tx "struct usbnet *un" "unsigned rxflags" "unsigned txflags"
+.Ft void
+.Fn usbnet_lock_mii "struct usbnet *un"
+.Ft void
+.Fn usbnet_lock_mii_un_locked "struct usbnet *un"
+.Ft void
+.Fn usbnet_unlock_mii "struct usbnet *un"
+.Ft void
+.Fn usbnet_unlock_mii_un_locked "struct usbnet *un"
+.Ft kmutex_t *
+.Fn usbnet_mutex_mii "struct usbnet *un"
+.Ft void
+.Fn usbnet_isowned_mii "struct usbnet *un"
+.Ft int
+.Fn usbnet_miibus_readreg "device_t dev" "int phy" "int reg" "uint16_t *val"
+.Ft int
+.Fn usbnet_miibus_writereg "device_t dev" "int phy" "int reg" "uint16_t val"
+.Ft void
+.Fn usbnet_miibus_statchg "struct ifnet *"
+.Ft void
+.Fn usbnet_enqueue "struct usbnet *un" "uint8_t *buf" "size_t buflen" "int csum_flags" "uint32_t csum_data" "int mbuf_flags"
+.Ft void
+.Fn usbnet_input "struct usbnet *un" "uint8_t *buf" "size_t buflen"
+.Ft void
+.Fn usbnet_attach "struct usbnet *un" "const char *detname"
+.Ft void
+.Fn usbnet_attach_ifp "struct usbnet *un" "unsigned if_flags" "unsigned if_extflags" "const struct usbnet_mii *unm"
+.Ft int
+.Fn usbnet_detach "device_t dev" "int flags"
+.Ft int
+.Fn usbnet_activate "device_t dev" "devact_t act"
+.Ft void
+.Fn usbnet_stop "struct usbnet *un" "struct ifnet *ifp" "int disable"
+.Sh DESCRIPTION
+The
+.Nm
+framework provides methods usable for USB Ethernet drivers.
+The framework has support for these features:
+.Bl -bullet -offset 8n
+.It
+Partial autoconf handling
+.It
+USB endpoint pipe handling
+.It
+Rx and Tx chain handling
+.It
+Generic handlers or support for several struct ifnet callbacks
+.It
+MII bus locking
+.It
+Interrupt handling
+.El
+.Pp
+.Nm
+provides many or all of the traditional
+.Dq softc
+members inside
+.Va struct usbnet ,
+which can be used directly as the device softc structure if
+no additional storage is required.
+A structure exists for receive and transmit chain management,
+.Va struct usbnet_chain ,
+that tracks the metadata for each transfer descriptor available,
+minimum of one each for Rx and Tx slot, and will be passed
+to the Rx and Tx callbacks.
+.Pp
+There is a
+.Va struct usbnet_ops
+structure that provides a number of optional and required callbacks
+that will be described below.
+.Pp
+For autoconfiguration the device attach routine is expected to
+ensure that this device's
+.Va struct usbnet
+is the first member of the device softc, if it can not be used directly
+as the device softc, as well as set up the necessary structure members,
+find end-points, find the Ethernet address if relevant, call
+.Fn usbnet_attach ,
+set up interface, Ethernet, and MII capabilities, and finally call
+.Fn usbnet_attach_ifp .
+The device detach routine should free any resources allocated
+by attach and then call
+.Fn usbnet_detach ,
+possibly directly using
+.Fn usbnet_detach
+as most consumers have no additional resources not owned and
+released by the
+.Nm
+framework itself.
+The device activate function should be set to
+.Fn usbnet_activate .
+.Pp
+To manage all Rx and Tx chains the
+.Dq uno_init
+callback of
+.Va struct usbnet_ops
+should perform any device specific initialization and then call
+.Fn usbnet_init_rx_tx
+which will allocate chains, set up and open pipes, and start the
+Rx transfers so that packets can arrived.
+These allocations and pipes can be closed and destroyed by calling
+.Fn usbnet_stop .
+Both of
+.Fn usbnet_init_rx_tx
+and
+.Fn usbnet_stop
+must be called with the
+.Nm
+lock held, see
+.Fn usbnet_lock
+and
+.Fn usbnet_unlock .
+See the
+.Sx RECEIVE AND SEND
+section for details on using the chains.
+.Pp
+The interface init, ioctl, start, and stop, routines are handled by the
+framework with callbacks for device-specific handling.
+For interface init (i.e., when bringing the interface up), the
+.Dq uno_init
+callback should perform any device specific initialization and then call
+.Fn usbnet_init_rx_tx
+to finalize Rx and Tx queue initialization.
+For interface ioctl, most of the handling is in the framework and the
+optional
+.Dq uno_ioctl
+callback should be used to program special settings
+like multicast filters or offload handling.
+If ioctl handling requires capturing device-specific ioctls then the
+.Dq uno_override_ioctl
+callback may be used instead to replace the framework's
Home |
Main Index |
Thread Index |
Old Index