NAME
usb_quirk
—
USB quirks module
SYNOPSIS
To compile this module into the kernel, place the following line in your kernel configuration file:
device usb
Alternatively, to load the module at boot time, place the following line in loader.conf(5):
usb_quirk_load="YES"
DESCRIPTION
The usb_quirk
module provides support for
dynamically adding and removing quirks for USB devices with
usbconfig(8).
General quirks:
- UQ_AUDIO_SWAP_LR
- swap left and right channels
- UQ_AU_INP_ASYNC
- input is async despite claim of adaptive
- UQ_AU_NO_FRAC
- do not adjust for fractional samples
- UQ_AU_NO_XU
- audio device has broken extension unit
- UQ_AU_VENDOR_CLASS
- audio device uses vendor class to identify itself
- UQ_AU_SET_SPDIF_CM6206
- audio device needs special programming to enable S/PDIF audio output
- UQ_BAD_ADC
- bad audio spec version number
- UQ_BAD_AUDIO
- device claims audio class, but is not
- UQ_BROKEN_BIDIR
- printer has broken bidir mode
- UQ_BUS_POWERED
- device is bus powered, despite claim
- UQ_HID_IGNORE
- device should be ignored by hid class
- UQ_KBD_IGNORE
- device should be ignored by kbd class
- UQ_KBD_BOOTPROTO
- device should set the boot protocol
- UQ_UMS_IGNORE
- device should be ignored by ums class
- UQ_MS_BAD_CLASS
- does not identify properly
- UQ_MS_LEADING_BYTE
- mouse sends an unknown leading byte
- UQ_MS_REVZ
- mouse has Z-axis reversed
- UQ_NO_STRINGS
- string descriptors are broken
- UQ_POWER_CLAIM
- hub lies about power status
- UQ_SPUR_BUT_UP
- spurious mouse button up events
- UQ_SWAP_UNICODE
- has some Unicode strings swapped
- UQ_CFG_INDEX_1
- select configuration index 1 by default
- UQ_CFG_INDEX_2
- select configuration index 2 by default
- UQ_CFG_INDEX_3
- select configuration index 3 by default
- UQ_CFG_INDEX_4
- select configuration index 4 by default
- UQ_CFG_INDEX_0
- select configuration index 0 by default
- UQ_ASSUME_CM_OVER_DATA
- assume cm over data feature
- UQ_WMT_IGNORE
- device should be ignored by wmt driver
USB Mass Storage quirks:
- UQ_MSC_NO_TEST_UNIT_READY
- send start/stop instead of TUR
- UQ_MSC_NO_RS_CLEAR_UA
- does not reset Unit Att.
- UQ_MSC_NO_START_STOP
- does not support start/stop
- UQ_MSC_NO_GETMAXLUN
- does not support get max LUN
- UQ_MSC_NO_INQUIRY
- fake generic inq response
- UQ_MSC_NO_INQUIRY_EVPD
- does not support inq EVPD
- UQ_MSC_NO_SYNC_CACHE
- does not support sync cache
- UQ_MSC_SHUTTLE_INIT
- requires Shuttle init sequence
- UQ_MSC_ALT_IFACE_1
- switch to alternate interface 1
- UQ_MSC_FLOPPY_SPEED
- does floppy speeds (20kb/s)
- UQ_MSC_IGNORE_RESIDUE
- gets residue wrong
- UQ_MSC_WRONG_CSWSIG
- uses wrong CSW signature
- UQ_MSC_RBC_PAD_TO_12
- pad RBC requests to 12 bytes
- UQ_MSC_READ_CAP_OFFBY1
- reports sector count, not max sec.
- UQ_MSC_FORCE_SHORT_INQ
- does not support full inq.
- UQ_MSC_FORCE_WIRE_BBB
- force BBB wire protocol
- UQ_MSC_FORCE_WIRE_CBI
- force CBI wire protocol
- UQ_MSC_FORCE_WIRE_CBI_I
- force CBI with int. wire protocol
- UQ_MSC_FORCE_PROTO_SCSI
- force SCSI command protocol
- UQ_MSC_FORCE_PROTO_ATAPI
- force ATAPI command protocol
- UQ_MSC_FORCE_PROTO_UFI
- force UFI command protocol
- UQ_MSC_FORCE_PROTO_RBC
- force RBC command protocol
3G Datacard (u3g) quirks:
- UQ_MSC_EJECT_HUAWEI
- ejects after Huawei USB command
- UQ_MSC_EJECT_SIERRA
- ejects after Sierra USB command
- UQ_MSC_EJECT_SCSIEJECT
- ejects after SCSI eject command
0x1b0000000200
- UQ_MSC_EJECT_REZERO
- ejects after SCSI rezero command
0x010000000000
- UQ_MSC_EJECT_ZTESTOR
- ejects after ZTE SCSI command
0x850101011801010101010000
- UQ_MSC_EJECT_CMOTECH
- ejects after C-motech SCSI command
0xff52444556434847
- UQ_MSC_EJECT_WAIT
- wait for the device to eject
- UQ_MSC_EJECT_SAEL_M460
- ejects after Sael USB commands
- UQ_MSC_EJECT_HUAWEISCSI
- ejects after Huawei SCSI command
0x11060000000000000000000000000000
- UQ_MSC_EJECT_TCT
- ejects after TCT SCSI command
0x06f504025270
- UQ_MSC_DYMO_EJECT
- ejects after HID command
0x1b5a01
See /sys/dev/usb/quirk/usb_quirk.h or run "usbconfig dump_quirk_names" for the complete list of supported quirks.
LOADER TUNABLE
The following tunable can be set at the loader(8) prompt before booting the kernel, or stored in loader.conf(5).
- hw.usb.quirk.%d
- The value is a string whose format is:
"VendorId ProductId LowRevision HighRevision UQ_QUIRK,..."
Installs the quirks
UQ_QUIRK,...
for all USB devices matchingVendorId
andProductId
which have a hardware revision between and includingLowRevision
andHighRevision
.VendorId
,ProductId
,LowRevision
andHighRevision
are all 16 bits numbers which can be decimal or hexadecimal based.A maximum of 100 variables
hw.usb.quirk.0, .1, ..., .99
can be defined.If a matching entry is found in the kernel's internal quirks table, it is replaced by the new definition.
Else a new entry is created given that the quirk table is not full.
The kernel iterates over the
hw.usb.quirk.N
variables starting atN = 0
and stops atN = 99
or the first non-existing one.
EXAMPLES
After attaching a u3g
device which appears
as a USB device on ugen0.3:
usbconfig -d ugen0.3 add_quirk UQ_MSC_EJECT_WAIT
Enable a Holtec/Keep Out F85 gaming keyboard on ugen1.4:
usbconfig -d ugen1.4 add_quirk UQ_KBD_BOOTPROTO
To install a quirk at boot time, place one or several lines like the following in loader.conf(5):
hw.usb.quirk.0="0x04d9 0xfa50 0 0xffff UQ_KBD_IGNORE"
SEE ALSO
HISTORY
The usb_quirk
module appeared in
FreeBSD 8.0, and was written by
Hans Petter Selasky
<hselasky@FreeBSD.org>.
This manual page was written by Nick Hibma
<n_hibma@FreeBSD.org>.