2010-03-22 21:58:31 +03:00
|
|
|
.\" $NetBSD: usb.4,v 1.92 2010/03/22 18:58:31 joerg Exp $
|
1999-04-14 00:25:28 +04:00
|
|
|
.\"
|
2008-03-25 22:53:13 +03:00
|
|
|
.\" Copyright (c) 1999-2008 The NetBSD Foundation, Inc.
|
1998-07-12 23:51:55 +04:00
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
1999-04-14 00:25:28 +04:00
|
|
|
.\" This code is derived from software contributed to The NetBSD Foundation
|
|
|
|
.\" by Lennart Augustsson.
|
|
|
|
.\"
|
1998-07-12 23:51:55 +04:00
|
|
|
.\" 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.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
|
|
|
.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
|
|
.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
1999-01-14 09:29:18 +03:00
|
|
|
.\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
1998-07-12 23:51:55 +04:00
|
|
|
.\" 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.
|
|
|
|
.\"
|
2008-03-25 22:53:13 +03:00
|
|
|
.Dd March 25, 2008
|
1998-07-12 23:51:55 +04:00
|
|
|
.Dt USB 4
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm usb
|
1999-01-14 09:29:18 +03:00
|
|
|
.Nd Universal Serial Bus driver
|
1998-07-12 23:51:55 +04:00
|
|
|
.Sh SYNOPSIS
|
2005-09-09 18:11:39 +04:00
|
|
|
.Cd "ehci* at cardbus? function ?"
|
2001-11-16 20:08:12 +03:00
|
|
|
.Cd "ehci* at pci? dev ? function ?"
|
2005-09-09 18:11:39 +04:00
|
|
|
.Cd "ohci* at cardbus? function ?"
|
1999-11-09 01:30:32 +03:00
|
|
|
.Cd "ohci* at pci? dev ? function ?"
|
2002-08-11 23:28:05 +04:00
|
|
|
.Cd "slhci* at isa? port ? irq ?"
|
2009-04-10 19:02:03 +04:00
|
|
|
.Cd "slhci* at pcmcia? function ?"
|
2005-09-09 18:11:39 +04:00
|
|
|
.Cd "uhci* at cardbus? function ?"
|
2001-11-16 20:08:12 +03:00
|
|
|
.Cd "uhci* at pci? dev ? function ?"
|
|
|
|
.Cd "usb* at ehci? flags X"
|
1999-12-23 02:54:09 +03:00
|
|
|
.Cd "usb* at ohci? flags X"
|
2001-11-16 20:08:12 +03:00
|
|
|
.Cd "usb* at uhci? flags X"
|
2002-08-11 17:24:55 +04:00
|
|
|
.Cd "usb* at slhci? flags X"
|
1998-07-12 23:51:55 +04:00
|
|
|
.Cd "uhub* at usb?"
|
1999-05-16 16:01:08 +04:00
|
|
|
.Cd "uhub* at uhub? port ? configuration ? interface ? vendor ? product ? release ?"
|
|
|
|
.Cd "XX* at uhub? port ? configuration ? interface ? vendor ? product ? release ?"
|
1998-07-12 23:51:55 +04:00
|
|
|
.Pp
|
2002-09-28 02:31:41 +04:00
|
|
|
.Cd options USBVERBOSE
|
|
|
|
.Pp
|
2004-05-12 02:42:47 +04:00
|
|
|
.In dev/usb/usb.h
|
|
|
|
.In dev/usb/usbhid.h
|
2002-03-06 17:43:02 +03:00
|
|
|
.Sh DESCRIPTION
|
1998-07-12 23:51:55 +04:00
|
|
|
.Nx
|
1999-01-14 09:29:18 +03:00
|
|
|
provides machine-independent bus support and drivers for
|
|
|
|
.Tn USB
|
|
|
|
devices.
|
1998-07-12 23:51:55 +04:00
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Nx
|
1999-01-14 09:29:18 +03:00
|
|
|
.Nm
|
1998-07-12 23:51:55 +04:00
|
|
|
driver has three layers (like
|
|
|
|
.Xr scsi 4
|
|
|
|
and
|
2001-06-10 19:51:33 +04:00
|
|
|
.Xr pcmcia 4 ) :
|
1998-07-12 23:51:55 +04:00
|
|
|
the controller, the bus, and the device layer.
|
|
|
|
The controller attaches to a physical bus (like
|
2001-06-10 19:51:33 +04:00
|
|
|
.Xr pci 4 ) .
|
1999-01-14 09:29:18 +03:00
|
|
|
The
|
|
|
|
.Tn USB
|
|
|
|
bus attaches to the controller and the root hub attaches
|
2003-01-01 19:09:19 +03:00
|
|
|
to the bus.
|
1999-01-14 09:29:18 +03:00
|
|
|
Further devices, which may include further hubs,
|
|
|
|
attach to other hubs.
|
|
|
|
The attachment forms the same tree structure as the physical
|
|
|
|
.Tn USB
|
|
|
|
device tree.
|
|
|
|
For each
|
|
|
|
.Tn USB
|
|
|
|
device there may be additional drivers attached to it.
|
1998-07-12 23:51:55 +04:00
|
|
|
.Pp
|
|
|
|
The
|
|
|
|
.Cm uhub
|
1999-01-14 09:29:18 +03:00
|
|
|
device controls
|
|
|
|
.Tn USB
|
|
|
|
hubs and must always be present since there is at least a root hub in any
|
|
|
|
.Tn USB
|
|
|
|
system.
|
1998-07-12 23:51:55 +04:00
|
|
|
.Pp
|
1999-12-23 02:54:09 +03:00
|
|
|
The
|
|
|
|
.Va flags
|
|
|
|
argument to the
|
|
|
|
.Va usb
|
|
|
|
device affects the order in which the device detection happens
|
|
|
|
during cold boot.
|
|
|
|
Normally, only the USB host controller and the
|
|
|
|
.Va usb
|
|
|
|
device are detected during the autoconfiguration when the
|
2009-05-05 00:42:00 +04:00
|
|
|
machine is booted.
|
|
|
|
The rest of the devices are detected once
|
1999-12-23 02:54:09 +03:00
|
|
|
the system becomes functional and the kernel thread for the
|
|
|
|
.Va usb
|
|
|
|
device is started.
|
|
|
|
Sometimes it is desirable to have a device detected early in the
|
2009-05-05 00:42:00 +04:00
|
|
|
boot process, e.g., the console keyboard.
|
|
|
|
To achieve this use a
|
1999-12-23 02:54:09 +03:00
|
|
|
.Va flags
|
|
|
|
value of 1.
|
2008-03-25 01:49:20 +03:00
|
|
|
.Pp
|
1999-11-23 04:46:32 +03:00
|
|
|
.Nx
|
2008-03-25 01:49:20 +03:00
|
|
|
supports the following machine-independent
|
1999-11-23 04:46:32 +03:00
|
|
|
.Tn USB
|
2008-03-25 01:49:20 +03:00
|
|
|
drivers:
|
|
|
|
.Ss Storage devices
|
|
|
|
.Bl -tag -width 12n -offset ind -compact
|
|
|
|
.It Xr umass 4
|
1999-11-23 04:46:32 +03:00
|
|
|
.Tn USB
|
2008-03-25 01:49:20 +03:00
|
|
|
Mass Storage Devices, e.g., external disk drives
|
|
|
|
.El
|
|
|
|
.Ss Wired network interfaces
|
|
|
|
.Bl -tag -width 12n -offset ind -compact
|
|
|
|
.It Xr aue 4
|
|
|
|
ADMtek AN986/ADM8511 Pegasus family 10/100 USB Ethernet device
|
|
|
|
.It Xr axe 4
|
|
|
|
ASIX Electronics AX88172/AX88178/AX88772 10/100/Gigabit USB Ethernet device
|
|
|
|
.It Xr cdce 4
|
|
|
|
USB Communication Device Class Ethernet device
|
|
|
|
.It Xr cue 4
|
|
|
|
CATC USB-EL1201A USB Ethernet device
|
|
|
|
.It Xr kue 4
|
|
|
|
Kawasaki LSI KL5KUSB101B USB Ethernet device
|
|
|
|
.It Xr udav 4
|
|
|
|
Davicom DM9601 10/100 USB Ethernet device
|
|
|
|
.It Xr url 4
|
|
|
|
Realtek RTL8150L 10/100 USB Ethernet device
|
|
|
|
.El
|
|
|
|
.Ss Wireless network interfaces
|
|
|
|
.Bl -tag -width 12n -offset ind -compact
|
|
|
|
.It Xr atu 4
|
|
|
|
Atmel AT76C50x IEEE 802.11b wireless network device
|
|
|
|
.It Xr ral 4
|
|
|
|
Ralink Technology USB IEEE 802.11b/g wireless network device
|
|
|
|
.It Xr rum 4
|
|
|
|
Ralink Technology USB IEEE 802.11a/b/g wireless network device
|
|
|
|
.It Xr ubt 4
|
|
|
|
USB Bluetooth dongles
|
|
|
|
.It Xr zyd 4
|
|
|
|
ZyDAS ZD1211/ZD1211B USB IEEE 802.11b/g wireless network device
|
|
|
|
.El
|
|
|
|
.Ss Serial and parallel interfaces
|
|
|
|
.Bl -tag -width 12n -offset ind -compact
|
|
|
|
.It Xr ubsa 4
|
|
|
|
Belkin USB serial adapter
|
|
|
|
.It Xr uchcom 4
|
|
|
|
WinChipHead CH341/340 based USB serial adapter
|
|
|
|
.It Xr ucom 4
|
|
|
|
USB tty support
|
|
|
|
.It Xr ucycom 4
|
|
|
|
Cypress microcontroller based USB serial adapter
|
|
|
|
.It Xr uftdi 4
|
|
|
|
FT8U100AX USB serial adapter
|
|
|
|
.It Xr ugensa 4
|
|
|
|
USB generic serial adapter
|
|
|
|
.It Xr uhmodem 4
|
|
|
|
USB Huawei 3G wireless modem device
|
|
|
|
.It Xr uipaq 4
|
|
|
|
iPAQ USB units
|
|
|
|
.It Xr ukyopon 4
|
|
|
|
USB Kyocera AIR-EDGE PHONE device
|
|
|
|
.It Xr ulpt 4
|
|
|
|
USB printer support
|
|
|
|
.It Xr umct 4
|
|
|
|
MCT USB-RS232 USB serial adapter
|
|
|
|
.It Xr umodem 4
|
|
|
|
USB modem support
|
|
|
|
.It Xr uplcom 4
|
|
|
|
Prolific PL-2303 USB serial adapter
|
|
|
|
.It Xr uslsa 4
|
|
|
|
Silicon Laboratories CP2101/CP2102 based USB serial adapter
|
|
|
|
.It Xr uvisor 4
|
|
|
|
USB Handspring Visor
|
|
|
|
.It Xr uvscom 4
|
|
|
|
SUNTAC Slipper U VS-10U USB serial adapter
|
|
|
|
.El
|
|
|
|
.Ss Audio devices
|
|
|
|
.Bl -tag -width 12n -offset ind -compact
|
|
|
|
.It Xr uaudio 4
|
|
|
|
USB audio devices
|
|
|
|
.It Xr umidi 4
|
|
|
|
USB MIDI devices
|
|
|
|
.It Xr urio 4
|
|
|
|
Diamond Multimedia Rio MP3 players
|
|
|
|
.El
|
|
|
|
.Ss Radio receiver devices
|
|
|
|
.Bl -tag -width 12n -offset ind -compact
|
|
|
|
.It Xr udsbr 4
|
|
|
|
D-Link DSB-R100 USB radio device
|
|
|
|
.El
|
|
|
|
.Ss Human Interface Devices
|
|
|
|
.Bl -tag -width 12n -offset ind -compact
|
|
|
|
.It Xr uhid 4
|
|
|
|
Generic driver for Human Interface Devices
|
|
|
|
.It Xr uhidev 4
|
|
|
|
Base driver for all Human Interface Devices
|
|
|
|
.It Xr ukbd 4
|
|
|
|
.Tn USB
|
|
|
|
keyboards that follow the boot protocol
|
|
|
|
.It Xr ums 4
|
|
|
|
.Tn USB
|
|
|
|
mouse devices
|
|
|
|
.El
|
|
|
|
.Ss Miscellaneous devices
|
|
|
|
.Bl -tag -width 12n -offset ind -compact
|
2008-03-25 22:53:13 +03:00
|
|
|
.It Xr stuirda 4
|
|
|
|
Sigmaltel 4116/4220 USB-IrDA bridge
|
2008-03-25 01:49:20 +03:00
|
|
|
.It Xr uep 4
|
|
|
|
USB eGalax touch-panel
|
|
|
|
.It Xr ugen 4
|
|
|
|
USB generic devices
|
|
|
|
.It Xr uirda 4
|
|
|
|
USB IrDA bridges
|
|
|
|
.It Xr upl 4
|
|
|
|
Prolific based host-to-host adapters
|
|
|
|
.It Xr uscanner 4
|
|
|
|
USB scanner support
|
|
|
|
.It Xr usscanner 4
|
|
|
|
SCSI-over-USB scanners
|
|
|
|
.It Xr ustir 4
|
|
|
|
SigmaTel STIr4200 USB IrDA bridges
|
|
|
|
.It Xr utoppy 4
|
|
|
|
Topfield TF5000PVR range of digital video recorders
|
|
|
|
.It Xr uyap 4
|
|
|
|
USB YAP phone firmware loader
|
1999-11-23 04:46:32 +03:00
|
|
|
.El
|
1998-07-12 23:51:55 +04:00
|
|
|
.Sh INTRODUCTION TO USB
|
1999-01-14 09:29:18 +03:00
|
|
|
The
|
|
|
|
.Tn USB
|
2001-11-16 20:08:12 +03:00
|
|
|
1.x is a 12 Mb/s serial bus with 1.5 Mb/s for low speed devices.
|
|
|
|
.Tn USB
|
|
|
|
2.x handles 480 Mb/s.
|
1999-01-14 09:29:18 +03:00
|
|
|
Each
|
|
|
|
.Tn USB
|
|
|
|
has a host controller that is the master of the bus;
|
1998-07-12 23:51:55 +04:00
|
|
|
all other devices on the bus only speak when spoken to.
|
|
|
|
.Pp
|
|
|
|
There can be up to 127 devices (apart from the host controller)
|
1999-01-14 09:29:18 +03:00
|
|
|
on a bus, each with its own address.
|
|
|
|
The addresses are assigned
|
1998-10-22 14:42:01 +04:00
|
|
|
dynamically by the host when each device is attached to the bus.
|
1998-07-12 23:51:55 +04:00
|
|
|
.Pp
|
1999-01-14 09:29:18 +03:00
|
|
|
Within each device there can be up to 16 endpoints.
|
|
|
|
Each endpoint
|
1998-07-12 23:51:55 +04:00
|
|
|
is individually addressed and the addresses are static.
|
|
|
|
Each of these endpoints will communicate in one of four different modes:
|
1999-01-14 09:29:18 +03:00
|
|
|
control, isochronous, bulk, or interrupt.
|
|
|
|
A device always has at least one endpoint.
|
|
|
|
This endpoint has address 0 and is a control
|
1998-10-22 14:42:01 +04:00
|
|
|
endpoint and is used to give commands to and extract basic data,
|
|
|
|
such as descriptors, from the device.
|
|
|
|
Each endpoint, except the control endpoint, is unidirectional.
|
1998-07-12 23:51:55 +04:00
|
|
|
.Pp
|
1999-01-14 09:29:18 +03:00
|
|
|
The endpoints in a device are grouped into interfaces.
|
1999-12-06 17:52:08 +03:00
|
|
|
An interface is a logical unit within a device; e.g.,
|
1999-01-14 09:29:18 +03:00
|
|
|
a compound device with both a keyboard and a trackball would present
|
|
|
|
one interface for each.
|
|
|
|
An interface can sometimes be set into different modes,
|
1998-07-12 23:51:55 +04:00
|
|
|
called alternate settings, which affects how it operates.
|
|
|
|
Different alternate settings can have different endpoints
|
|
|
|
within it.
|
|
|
|
.Pp
|
1999-01-14 09:29:18 +03:00
|
|
|
A device may operate in different configurations.
|
|
|
|
Depending on the
|
1998-07-12 23:51:55 +04:00
|
|
|
configuration the device may present different sets of endpoints
|
|
|
|
and interfaces.
|
1998-12-08 17:21:48 +03:00
|
|
|
.Pp
|
1999-01-14 09:29:18 +03:00
|
|
|
Each device located on a hub has several
|
2005-06-20 17:25:23 +04:00
|
|
|
.Xr config 1
|
1999-01-14 09:29:18 +03:00
|
|
|
locators:
|
1999-12-06 17:52:08 +03:00
|
|
|
.Bl -tag -compact -width xxxxxxxxx
|
1999-01-14 09:29:18 +03:00
|
|
|
.It Cd port
|
1998-12-08 17:21:48 +03:00
|
|
|
this is the number of the port on closest upstream hub.
|
1999-01-14 09:29:18 +03:00
|
|
|
.It Cd configuration
|
1998-12-08 17:21:48 +03:00
|
|
|
this is the configuration the device must be in for this driver to attach.
|
1999-01-14 09:29:18 +03:00
|
|
|
This locator does not set the configuration; it is iterated by the bus
|
1998-12-08 17:21:48 +03:00
|
|
|
enumeration.
|
1999-01-14 09:29:18 +03:00
|
|
|
.It Cd interface
|
|
|
|
this is the interface number within a device that an interface driver
|
1998-12-08 17:21:48 +03:00
|
|
|
attaches to.
|
1999-05-16 16:01:08 +04:00
|
|
|
.It Cd vendor
|
|
|
|
this is the 16 bit vendor id of the device.
|
|
|
|
.It Cd product
|
|
|
|
this is the 16 bit product id of the device.
|
|
|
|
.It Cd release
|
|
|
|
this is the 16 bit release (revision) number of the device.
|
1998-12-08 17:21:48 +03:00
|
|
|
.El
|
1999-05-16 16:01:08 +04:00
|
|
|
The first locator can be used to pin down a particular device
|
|
|
|
according to its physical position in the device tree.
|
|
|
|
The last three locators can be used to pin down a particular
|
|
|
|
device according to what device it actually is.
|
1998-12-08 17:21:48 +03:00
|
|
|
.Pp
|
1999-01-14 09:29:18 +03:00
|
|
|
The bus enumeration of the
|
|
|
|
.Tn USB
|
|
|
|
bus proceeds in several steps:
|
|
|
|
.Bl -enum
|
|
|
|
.It
|
2009-05-18 04:07:47 +04:00
|
|
|
Any device specific driver can attach to the device.
|
1999-01-14 09:29:18 +03:00
|
|
|
.It
|
1998-12-08 17:21:48 +03:00
|
|
|
If none is found, any device class specific driver can attach.
|
1999-01-14 09:29:18 +03:00
|
|
|
.It
|
1998-12-08 17:21:48 +03:00
|
|
|
If none is found, all configurations are iterated over.
|
|
|
|
For each configuration all the interface are iterated over and interface
|
1999-01-14 09:29:18 +03:00
|
|
|
drivers can attach.
|
|
|
|
If any interface driver attached in a certain
|
1998-12-08 17:21:48 +03:00
|
|
|
configuration the iteration over configurations is stopped.
|
1999-01-14 09:29:18 +03:00
|
|
|
.It
|
|
|
|
If still no drivers have been found, the generic
|
|
|
|
.Tn USB
|
|
|
|
driver can attach.
|
1998-12-08 17:21:48 +03:00
|
|
|
.El
|
1998-07-27 02:22:26 +04:00
|
|
|
.Sh USB CONTROLLER INTERFACE
|
1999-01-14 09:29:18 +03:00
|
|
|
Use the following to get access to the
|
|
|
|
.Tn USB
|
2001-06-10 19:51:33 +04:00
|
|
|
specific structures and defines.
|
1999-01-14 09:29:18 +03:00
|
|
|
.Bd -literal
|
2004-05-08 14:14:00 +04:00
|
|
|
#include \*[Lt]dev/usb/usb.h\*[Gt]
|
1998-07-27 02:22:26 +04:00
|
|
|
.Ed
|
1998-07-12 23:51:55 +04:00
|
|
|
.Pp
|
1998-07-27 02:22:26 +04:00
|
|
|
The
|
|
|
|
.Pa /dev/usbN
|
|
|
|
can be opened and a few operations can be performed on it.
|
|
|
|
The
|
|
|
|
.Xr poll 2
|
|
|
|
system call will say that I/O is possible on the controller device when a
|
1999-01-14 09:29:18 +03:00
|
|
|
.Tn USB
|
|
|
|
device has been connected or disconnected to the bus.
|
1998-07-27 02:22:26 +04:00
|
|
|
.Pp
|
|
|
|
The following
|
|
|
|
.Xr ioctl 2
|
|
|
|
commands are supported on the controller device:
|
1999-01-14 09:29:18 +03:00
|
|
|
.Bl -tag -width xxxxxx
|
1999-07-29 18:20:32 +04:00
|
|
|
.\" .It Dv USB_DISCOVER
|
|
|
|
.\" This command will cause a complete bus discovery to be initiated.
|
|
|
|
.\" If any devices attached or detached from the bus they will be
|
|
|
|
.\" processed during this command.
|
|
|
|
.\" This is the only way that new devices are found on the bus.
|
1999-01-14 09:29:18 +03:00
|
|
|
.It Dv USB_DEVICEINFO Fa "struct usb_device_info"
|
1998-07-27 02:22:26 +04:00
|
|
|
This command can be used to retrieve some information about a device
|
1999-01-14 09:29:18 +03:00
|
|
|
on the bus.
|
|
|
|
The
|
1998-07-27 02:22:26 +04:00
|
|
|
.Va addr
|
1999-01-14 09:29:18 +03:00
|
|
|
field should be filled before the call and the other fields will
|
|
|
|
be filled by information about the device on that address.
|
|
|
|
Should no such device exist an error is reported.
|
1998-07-27 02:22:26 +04:00
|
|
|
.Bd -literal
|
|
|
|
struct usb_device_info {
|
2005-12-26 22:40:14 +03:00
|
|
|
uint8_t udi_bus;
|
|
|
|
uint8_t udi_addr;
|
2004-05-08 14:14:00 +04:00
|
|
|
usb_event_cookie_t udi_cookie;
|
2005-08-29 15:49:36 +04:00
|
|
|
char udi_product[USB_MAX_ENCODED_STRING_LEN];
|
|
|
|
char udi_vendor[USB_MAX_ENCODED_STRING_LEN];
|
2004-05-08 14:14:00 +04:00
|
|
|
char udi_release[8];
|
2005-08-29 15:49:36 +04:00
|
|
|
char udi_serial[USB_MAX_ENCODED_STRING_LEN];
|
2005-12-26 22:40:14 +03:00
|
|
|
uint16_t udi_productNo;
|
|
|
|
uint16_t udi_vendorNo;
|
|
|
|
uint16_t udi_releaseNo;
|
|
|
|
uint8_t udi_class;
|
|
|
|
uint8_t udi_subclass;
|
|
|
|
uint8_t udi_protocol;
|
|
|
|
uint8_t udi_config;
|
|
|
|
uint8_t udi_speed;
|
2004-05-12 03:16:59 +04:00
|
|
|
#define USB_SPEED_LOW 1
|
2004-05-08 14:14:00 +04:00
|
|
|
#define USB_SPEED_FULL 2
|
|
|
|
#define USB_SPEED_HIGH 3
|
|
|
|
int udi_power;
|
|
|
|
int udi_nports;
|
|
|
|
char udi_devnames[USB_MAX_DEVNAMES][USB_MAX_DEVNAMELEN];
|
2005-12-26 22:40:14 +03:00
|
|
|
uint8_t udi_ports[16];
|
1998-07-27 02:22:26 +04:00
|
|
|
#define USB_PORT_ENABLED 0xff
|
|
|
|
#define USB_PORT_SUSPENDED 0xfe
|
|
|
|
#define USB_PORT_POWERED 0xfd
|
|
|
|
#define USB_PORT_DISABLED 0xfc
|
|
|
|
};
|
|
|
|
.Ed
|
1999-01-14 09:29:18 +03:00
|
|
|
.Pp
|
1998-07-27 02:22:26 +04:00
|
|
|
The
|
|
|
|
.Va product ,
|
|
|
|
.Va vendor ,
|
2005-08-29 15:49:36 +04:00
|
|
|
.Va release ,
|
1998-07-27 02:22:26 +04:00
|
|
|
and
|
2005-08-29 15:49:36 +04:00
|
|
|
.Va serial
|
1999-01-14 09:29:18 +03:00
|
|
|
fields contain self-explanatory descriptions of the device.
|
|
|
|
.Pp
|
1998-07-27 02:22:26 +04:00
|
|
|
The
|
|
|
|
.Va class
|
1998-10-22 14:42:01 +04:00
|
|
|
field contains the device class.
|
1999-01-14 09:29:18 +03:00
|
|
|
.Pp
|
1998-07-27 02:22:26 +04:00
|
|
|
The
|
|
|
|
.Va config
|
|
|
|
field shows the current configuration of the device.
|
1999-01-14 09:29:18 +03:00
|
|
|
.Pp
|
1998-07-27 02:22:26 +04:00
|
|
|
The
|
|
|
|
.Va lowspeed
|
|
|
|
field
|
1999-01-14 09:29:18 +03:00
|
|
|
is set if the device is a
|
|
|
|
.Tn USB
|
|
|
|
low speed device.
|
|
|
|
.Pp
|
1998-07-27 02:22:26 +04:00
|
|
|
The
|
|
|
|
.Va power
|
1999-01-14 09:29:18 +03:00
|
|
|
field shows the power consumption in milli-amps drawn at 5 volts,
|
|
|
|
or zero if the device is self powered.
|
1998-07-27 02:22:26 +04:00
|
|
|
.Pp
|
|
|
|
If the device is a hub the
|
|
|
|
.Va nports
|
|
|
|
field is non-zero and the
|
|
|
|
.Va ports
|
|
|
|
field contains the addresses of the connected devices.
|
|
|
|
If no device is connected to a port one of the
|
|
|
|
.Va USB_PORT_*
|
|
|
|
values indicates its status.
|
1999-01-14 09:29:18 +03:00
|
|
|
.It Dv USB_DEVICESTATS Fa "struct usb_device_stats"
|
|
|
|
This command retrieves statistics about the controller.
|
1998-07-27 02:22:26 +04:00
|
|
|
.Bd -literal
|
|
|
|
struct usb_device_stats {
|
2004-05-08 14:14:00 +04:00
|
|
|
u_long uds_requests[4];
|
1998-07-27 02:22:26 +04:00
|
|
|
};
|
|
|
|
.Ed
|
1999-01-14 09:29:18 +03:00
|
|
|
.Pp
|
1998-07-27 02:22:26 +04:00
|
|
|
The
|
|
|
|
.Va requests
|
1999-01-14 09:29:18 +03:00
|
|
|
field is indexed by the transfer kind, i.e.
|
1998-07-27 02:22:26 +04:00
|
|
|
.Va UE_* ,
|
2009-05-18 04:07:47 +04:00
|
|
|
and indicates how many transfers of each kind have been completed
|
1998-10-22 14:42:01 +04:00
|
|
|
by the controller.
|
1999-01-14 09:29:18 +03:00
|
|
|
.It Dv USB_REQUEST Fa "struct usb_ctl_request"
|
|
|
|
This command can be used to execute arbitrary requests on the control pipe.
|
|
|
|
This is
|
|
|
|
.Em DANGEROUS
|
|
|
|
and should be used with great care since it
|
1998-10-22 14:42:01 +04:00
|
|
|
can destroy the bus integrity.
|
1998-07-27 02:22:26 +04:00
|
|
|
.El
|
1998-12-07 16:11:47 +03:00
|
|
|
.Pp
|
|
|
|
The include file
|
2010-03-22 21:58:31 +03:00
|
|
|
.In dev/usb/usb.h
|
1999-01-14 09:29:18 +03:00
|
|
|
contains definitions for the types used by the various
|
1998-12-07 16:11:47 +03:00
|
|
|
.Xr ioctl 2
|
1999-01-14 09:29:18 +03:00
|
|
|
calls.
|
|
|
|
The naming convention of the fields for the various
|
|
|
|
.Tn USB
|
|
|
|
descriptors exactly follows the naming in the
|
|
|
|
.Tn USB
|
|
|
|
specification.
|
1998-12-07 16:11:47 +03:00
|
|
|
Byte sized fields can be accessed directly, but word (16 bit)
|
|
|
|
sized fields must be access by the
|
1999-01-14 09:29:18 +03:00
|
|
|
.Fn UGETW field
|
1998-12-07 16:11:47 +03:00
|
|
|
and
|
1999-01-14 09:29:18 +03:00
|
|
|
.Fn USETW field value
|
1998-12-07 16:11:47 +03:00
|
|
|
macros to handle byte order and alignment properly.
|
1999-01-14 09:29:18 +03:00
|
|
|
.Pp
|
1998-12-07 16:11:47 +03:00
|
|
|
The include file
|
2010-03-22 21:58:31 +03:00
|
|
|
.In dev/usb/usbhid.h
|
1999-01-14 09:29:18 +03:00
|
|
|
similarly contains the definitions for
|
|
|
|
Human Interface Devices
|
|
|
|
.Pq Tn HID .
|
2000-09-24 21:22:08 +04:00
|
|
|
.Sh USB EVENT INTERFACE
|
|
|
|
All
|
|
|
|
.Tn USB
|
|
|
|
events are reported via the
|
|
|
|
.Pa /dev/usb
|
2009-05-05 00:42:00 +04:00
|
|
|
device.
|
|
|
|
This devices can be opened for reading and each
|
2000-09-24 21:22:08 +04:00
|
|
|
.Xr read 2
|
|
|
|
will yield an event record (if something has happened).
|
|
|
|
The
|
|
|
|
.Xr poll 2
|
|
|
|
system call can be used to determine if an event record is available
|
|
|
|
for reading.
|
|
|
|
.Pp
|
|
|
|
The event record has the following definition:
|
|
|
|
.Bd -literal
|
|
|
|
struct usb_event {
|
|
|
|
int ue_type;
|
|
|
|
#define USB_EVENT_CTRLR_ATTACH 1
|
|
|
|
#define USB_EVENT_CTRLR_DETACH 2
|
|
|
|
#define USB_EVENT_DEVICE_ATTACH 3
|
|
|
|
#define USB_EVENT_DEVICE_DETACH 4
|
|
|
|
#define USB_EVENT_DRIVER_ATTACH 5
|
|
|
|
#define USB_EVENT_DRIVER_DETACH 6
|
|
|
|
struct timespec ue_time;
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
int ue_bus;
|
|
|
|
} ue_ctrlr;
|
|
|
|
struct usb_device_info ue_device;
|
|
|
|
struct {
|
|
|
|
usb_event_cookie_t ue_cookie;
|
|
|
|
char ue_devname[16];
|
|
|
|
} ue_driver;
|
|
|
|
} u;
|
|
|
|
};
|
|
|
|
.Ed
|
2009-04-10 19:02:03 +04:00
|
|
|
.Pp
|
2000-09-24 21:22:08 +04:00
|
|
|
The
|
|
|
|
.Va ue_type
|
|
|
|
field identifies the type of event that is described.
|
|
|
|
The possible events are attach/detach of a host controller,
|
2009-05-05 00:42:00 +04:00
|
|
|
a device, or a device driver.
|
|
|
|
The union contains information
|
2000-09-24 21:22:08 +04:00
|
|
|
pertinent to the different types of events.
|
2009-04-10 19:02:03 +04:00
|
|
|
.Pp
|
2000-09-24 21:22:08 +04:00
|
|
|
The
|
|
|
|
.Va ue_bus
|
|
|
|
contains the number of the
|
|
|
|
.Tn USB
|
|
|
|
bus for host controller events.
|
2009-04-10 19:02:03 +04:00
|
|
|
.Pp
|
2000-09-24 21:22:08 +04:00
|
|
|
The
|
|
|
|
.Va ue_device
|
|
|
|
record contains information about the device in a device event event.
|
2009-04-10 19:02:03 +04:00
|
|
|
.Pp
|
2000-09-24 21:22:08 +04:00
|
|
|
The
|
|
|
|
.Va ue_cookie
|
2004-10-04 23:12:52 +04:00
|
|
|
is an opaque value that uniquely determines which
|
2000-09-24 21:22:08 +04:00
|
|
|
device a device driver has been attached to (i.e., it equals
|
|
|
|
the cookie value in the device that the driver attached to).
|
|
|
|
The
|
|
|
|
.Va ue_devname
|
|
|
|
contains the name of the device (driver) as seen in, e.g.,
|
|
|
|
kernel messages.
|
|
|
|
.Pp
|
2004-10-04 23:12:52 +04:00
|
|
|
Note that there is a separation between device and device
|
2009-05-05 00:42:00 +04:00
|
|
|
driver events.
|
|
|
|
A device event is generated when a physical
|
|
|
|
USB device is attached or detached.
|
|
|
|
A single USB device may
|
2000-09-24 21:22:08 +04:00
|
|
|
have zero, one, or many device drivers associated with it.
|
2004-01-07 17:31:05 +03:00
|
|
|
.Sh KERNEL THREADS
|
|
|
|
For each USB bus, i.e., for each host controller, there is
|
|
|
|
a kernel thread that handles attach and detach of devices on
|
|
|
|
that bus.
|
|
|
|
The thread is named
|
|
|
|
.Va usbN
|
|
|
|
where
|
|
|
|
.Va N
|
|
|
|
is the bus number.
|
|
|
|
.Pp
|
|
|
|
In addition there is a kernel thread,
|
|
|
|
.Va usbtask ,
|
|
|
|
which handles various minor tasks that are initiated from
|
|
|
|
an interrupt context, but need to sleep, e.g., time-out
|
|
|
|
abort of transfers.
|
1998-07-12 23:51:55 +04:00
|
|
|
.Sh SEE ALSO
|
2001-06-10 19:51:33 +04:00
|
|
|
The
|
|
|
|
.Tn USB
|
2000-06-09 19:11:01 +04:00
|
|
|
specifications can be found at:
|
2003-05-06 22:59:20 +04:00
|
|
|
.D1 http://www.usb.org/developers/docs/
|
1999-01-14 14:07:44 +03:00
|
|
|
.Pp
|
2008-03-25 01:49:20 +03:00
|
|
|
.Xr usbhidaction 1 ,
|
|
|
|
.Xr usbhidctl 1 ,
|
1999-11-09 01:30:32 +03:00
|
|
|
.Xr cardbus 4 ,
|
2001-11-16 20:08:12 +03:00
|
|
|
.Xr ehci 4 ,
|
2002-08-11 23:28:05 +04:00
|
|
|
.Xr isa 4 ,
|
2001-11-16 20:08:12 +03:00
|
|
|
.Xr ohci 4 ,
|
2001-11-19 01:49:36 +03:00
|
|
|
.Xr pci 4 ,
|
2007-08-21 14:59:53 +04:00
|
|
|
.Xr pcmcia 4 ,
|
2002-08-11 17:24:55 +04:00
|
|
|
.Xr slhci 4 ,
|
2001-11-16 20:08:12 +03:00
|
|
|
.Xr uhci 4 ,
|
1998-07-13 00:56:23 +04:00
|
|
|
.Xr usbdevs 8
|
1998-07-12 23:51:55 +04:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
driver
|
|
|
|
appeared in
|
|
|
|
.Nx 1.4 .
|
2001-09-12 03:18:55 +04:00
|
|
|
.Sh BUGS
|
|
|
|
There should be a serial number locator, but
|
|
|
|
.Nx
|
|
|
|
does not have string valued locators.
|