xref: /freebsd/share/man/man4/usb_quirk.4 (revision c243e4902be8df1e643c76b5f18b68bb77cc5268)
1.\"
2.\" Copyright (c) 2010 AnyWi Technologies
3.\" All rights reserved.
4.\"
5.\" Permission to use, copy, modify, and distribute this software for any
6.\" purpose with or without fee is hereby granted, provided that the above
7.\" copyright notice and this permission notice appear in all copies.
8.\"
9.\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10.\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11.\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12.\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13.\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16.\"
17.\" $FreeBSD$
18.\"
19.Dd February 8, 2012
20.Dt USB_QUIRK 4
21.Os
22.Sh NAME
23.Nm usb_quirk
24.Nd USB quirks module
25.Sh SYNOPSIS
26To compile this module into the kernel,
27place the following line in your
28kernel configuration file:
29.Bd -ragged -offset indent
30.Cd "device usb_quirk"
31.Ed
32.Pp
33Alternatively, to load the module at boot
34time, place the following line in
35.Xr loader.conf 5 :
36.Bd -literal -offset indent
37usb_quirk_load="YES"
38.Ed
39.Sh DESCRIPTION
40The
41.Nm
42module provides support for dynamically adding and removing quirks for
43USB devices with
44.Xr usbconfig 8 .
45.Sh General quirks:
46.Bl -tag -width Ds
47.It UQ_AUDIO_SWAP_LR
48swap left and right channels
49.It UQ_AU_INP_ASYNC
50input is async despite claim of adaptive
51.It UQ_AU_NO_FRAC
52don't adjust for fractional samples
53.It UQ_AU_NO_XU
54audio device has broken extension unit
55.It UQ_BAD_ADC
56bad audio spec version number
57.It UQ_BAD_AUDIO
58device claims audio class, but isn't
59.It UQ_BROKEN_BIDIR
60printer has broken bidir mode
61.It UQ_BUS_POWERED
62device is bus powered, despite claim
63.It UQ_HID_IGNORE
64device should be ignored by hid class
65.It UQ_KBD_IGNORE
66device should be ignored by kbd class
67.It UQ_KBD_BOOTPROTO
68device should set the boot protocol
69.It UQ_MS_BAD_CLASS
70doesn't identify properly
71.It UQ_MS_LEADING_BYTE
72mouse sends an unknown leading byte
73.It UQ_MS_REVZ
74mouse has Z-axis reversed
75.It UQ_NO_STRINGS
76string descriptors are broken
77.It UQ_OPEN_CLEARSTALL
78device needs clear endpoint stall
79.It UQ_POWER_CLAIM
80hub lies about power status
81.It UQ_SPUR_BUT_UP
82spurious mouse button up events
83.It UQ_SWAP_UNICODE
84has some Unicode strings swapped
85.It UQ_CFG_INDEX_1
86select configuration index 1 by default
87.It UQ_CFG_INDEX_2
88select configuration index 2 by default
89.It UQ_CFG_INDEX_3
90select configuration index 3 by default
91.It UQ_CFG_INDEX_4
92select configuration index 4 by default
93.It UQ_CFG_INDEX_0
94select configuration index 0 by default
95.It UQ_ASSUME_CM_OVER_DATA
96assume cm over data feature
97.El
98.Sh USB Mass Storage Quirks
99.Bl -tag -width Ds
100.It UQ_MSC_NO_TEST_UNIT_READY
101send start/stop instead of TUR
102.It UQ_MSC_NO_RS_CLEAR_UA
103does not reset Unit Att.
104.It UQ_MSC_NO_START_STOP
105does not support start/stop
106.It UQ_MSC_NO_GETMAXLUN
107does not support get max LUN
108.It UQ_MSC_NO_INQUIRY
109fake generic inq response
110.It UQ_MSC_NO_INQUIRY_EVPD
111does not support inq EVPD
112.It UQ_MSC_NO_SYNC_CACHE
113does not support sync cache
114.It UQ_MSC_SHUTTLE_INIT
115requires Shuttle init sequence
116.It UQ_MSC_ALT_IFACE_1
117switch to alternate interface 1
118.It UQ_MSC_FLOPPY_SPEED
119does floppy speeds (20kb/s)
120.It UQ_MSC_IGNORE_RESIDUE
121gets residue wrong
122.It UQ_MSC_WRONG_CSWSIG
123uses wrong CSW signature
124.It UQ_MSC_RBC_PAD_TO_12
125pad RBC requests to 12 bytes
126.It UQ_MSC_READ_CAP_OFFBY1
127reports sector count, not max sec.
128.It UQ_MSC_FORCE_SHORT_INQ
129does not support full inq.
130.It UQ_MSC_FORCE_WIRE_BBB
131force BBB wire protocol
132.It UQ_MSC_FORCE_WIRE_CBI
133force CBI wire protocol
134.It UQ_MSC_FORCE_WIRE_CBI_I
135force CBI with int. wire protocol
136.It UQ_MSC_FORCE_PROTO_SCSI
137force SCSI command protocol
138.It UQ_MSC_FORCE_PROTO_ATAPI
139force ATAPI command protocol
140.It UQ_MSC_FORCE_PROTO_UFI
141force UFI command protocol
142.It UQ_MSC_FORCE_PROTO_RBC
143force RBC command protocol
144.El
145.Sh Mass Storage Change (u3g) quirks:
146.Bl -tag -width Ds
147.It UQ_MSC_EJECT_HUAWEI
148ejects after Huawei USB command
149.It UQ_MSC_EJECT_SIERRA
150ejects after Sierra USB command
151.It UQ_MSC_EJECT_SCSIEJECT
152ejects after SCSI eject command
1530x1b0000000200
154.It UQ_MSC_EJECT_REZERO
155ejects after SCSI rezero command
1560x010000000000
157.It UQ_MSC_EJECT_ZTESTOR
158ejects after ZTE SCSI command
1590x850101011801010101010000
160.It UQ_MSC_EJECT_CMOTECH
161ejects after C-motech SCSI command
1620xff52444556434847
163.It UQ_MSC_EJECT_WAIT
164wait for the device to eject
165.It UQ_MSC_EJECT_SAEL_M460
166ejects after Sael USB commands
167.It UQ_MSC_EJECT_HUAWEISCSI
168ejects after Huawei SCSI command
1690x11060000000000000000000000000000
170.It UQ_MSC_EJECT_TCT
171ejects after TCT SCSI command
1720x06f504025270
173.El
174See
175.Pa /sys/dev/usb/quirk/usb_quirk.h
176for the complete list of supported quirks.
177.Sh EXAMPLES
178After attaching a
179.Nm u3g
180device which appears as a USB device on
181.Pa ugen0.3 :
182.Bd -literal -offset indent
183usbconfig -d ugen0.3 add_quirk UQ_MSC_EJECT_WAIT
184.Ed
185.Sh SEE ALSO
186.Xr usbconfig 8
187.Sh HISTORY
188The
189.Nm
190module appeared in
191.Fx 8.0 ,
192and was written by
193.An Hans Petter Selasky Aq hselasky@FreeBSD.org .
194This manual page was written by
195.An Nick Hibma Aq n_hibma@FreeBSD.org .
196