]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/blame - Documentation/usb/acm.rst
Merge branch 'i2c/for-5.9' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux
[mirror_ubuntu-hirsute-kernel.git] / Documentation / usb / acm.rst
CommitLineData
d80b5005
MCC
1======================
2Linux ACM driver v0.16
3======================
4
5Copyright (c) 1999 Vojtech Pavlik <vojtech@suse.cz>
6
7Sponsored by SuSE
1da177e4
LT
8
90. Disclaimer
10~~~~~~~~~~~~~
d80b5005 11This program is free software; you can redistribute it and/or modify it
1da177e4
LT
12under the terms of the GNU General Public License as published by the Free
13Software Foundation; either version 2 of the License, or (at your option)
14any later version.
15
d80b5005 16This program is distributed in the hope that it will be useful, but
1da177e4
LT
17WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
18or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
19more details.
20
d80b5005 21You should have received a copy of the GNU General Public License along
1da177e4
LT
22with this program; if not, write to the Free Software Foundation, Inc., 59
23Temple Place, Suite 330, Boston, MA 02111-1307 USA
24
d80b5005
MCC
25Should you need to contact me, the author, you can do so either by e-mail -
26mail your message to <vojtech@suse.cz>, or by paper mail: Vojtech Pavlik,
1da177e4
LT
27Ucitelska 1576, Prague 8, 182 00 Czech Republic
28
d80b5005 29For your convenience, the GNU General Public License version 2 is included
1da177e4
LT
30in the package: See the file COPYING.
31
321. Usage
33~~~~~~~~
d80b5005 34The drivers/usb/class/cdc-acm.c drivers works with USB modems and USB ISDN terminal
1da177e4
LT
35adapters that conform to the Universal Serial Bus Communication Device Class
36Abstract Control Model (USB CDC ACM) specification.
37
d80b5005 38Many modems do, here is a list of those I know of:
1da177e4 39
d80b5005
MCC
40 - 3Com OfficeConnect 56k
41 - 3Com Voice FaxModem Pro
42 - 3Com Sportster
43 - MultiTech MultiModem 56k
44 - Zoom 2986L FaxModem
45 - Compaq 56k FaxModem
46 - ELSA Microlink 56k
1da177e4 47
d80b5005 48I know of one ISDN TA that does work with the acm driver:
1da177e4 49
d80b5005 50 - 3Com USR ISDN Pro TA
1da177e4 51
d80b5005 52Some cell phones also connect via USB. I know the following phones work:
684a0e70 53
d80b5005 54 - SonyEricsson K800i
684a0e70 55
d80b5005 56Unfortunately many modems and most ISDN TAs use proprietary interfaces and
1da177e4
LT
57thus won't work with this drivers. Check for ACM compliance before buying.
58
d80b5005 59To use the modems you need these modules loaded::
1da177e4
LT
60
61 usbcore.ko
62 uhci-hcd.ko ohci-hcd.ko or ehci-hcd.ko
63 cdc-acm.ko
64
d80b5005 65After that, the modem[s] should be accessible. You should be able to use
1da177e4
LT
66minicom, ppp and mgetty with them.
67
682. Verifying that it works
69~~~~~~~~~~~~~~~~~~~~~~~~~~
d80b5005
MCC
70
71The first step would be to check /sys/kernel/debug/usb/devices, it should look
72like this::
73
74 T: Bus=01 Lev=00 Prnt=00 Port=00 Cnt=00 Dev#= 1 Spd=12 MxCh= 2
75 B: Alloc= 0/900 us ( 0%), #Int= 0, #Iso= 0
76 D: Ver= 1.00 Cls=09(hub ) Sub=00 Prot=00 MxPS= 8 #Cfgs= 1
77 P: Vendor=0000 ProdID=0000 Rev= 0.00
78 S: Product=USB UHCI Root Hub
79 S: SerialNumber=6800
80 C:* #Ifs= 1 Cfg#= 1 Atr=40 MxPwr= 0mA
81 I: If#= 0 Alt= 0 #EPs= 1 Cls=09(hub ) Sub=00 Prot=00 Driver=hub
82 E: Ad=81(I) Atr=03(Int.) MxPS= 8 Ivl=255ms
83 T: Bus=01 Lev=01 Prnt=01 Port=01 Cnt=01 Dev#= 2 Spd=12 MxCh= 0
84 D: Ver= 1.00 Cls=02(comm.) Sub=00 Prot=00 MxPS= 8 #Cfgs= 2
85 P: Vendor=04c1 ProdID=008f Rev= 2.07
86 S: Manufacturer=3Com Inc.
87 S: Product=3Com U.S. Robotics Pro ISDN TA
88 S: SerialNumber=UFT53A49BVT7
89 C: #Ifs= 1 Cfg#= 1 Atr=60 MxPwr= 0mA
90 I: If#= 0 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=ff Prot=ff Driver=acm
91 E: Ad=85(I) Atr=02(Bulk) MxPS= 64 Ivl= 0ms
92 E: Ad=04(O) Atr=02(Bulk) MxPS= 64 Ivl= 0ms
93 E: Ad=81(I) Atr=03(Int.) MxPS= 16 Ivl=128ms
94 C:* #Ifs= 2 Cfg#= 2 Atr=60 MxPwr= 0mA
95 I: If#= 0 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=02 Prot=01 Driver=acm
96 E: Ad=81(I) Atr=03(Int.) MxPS= 16 Ivl=128ms
97 I: If#= 1 Alt= 0 #EPs= 2 Cls=0a(data ) Sub=00 Prot=00 Driver=acm
98 E: Ad=85(I) Atr=02(Bulk) MxPS= 64 Ivl= 0ms
99 E: Ad=04(O) Atr=02(Bulk) MxPS= 64 Ivl= 0ms
1da177e4
LT
100
101The presence of these three lines (and the Cls= 'comm' and 'data' classes)
102is important, it means it's an ACM device. The Driver=acm means the acm
103driver is used for the device. If you see only Cls=ff(vend.) then you're out
d80b5005
MCC
104of luck, you have a device with vendor specific-interface::
105
106 D: Ver= 1.00 Cls=02(comm.) Sub=00 Prot=00 MxPS= 8 #Cfgs= 2
107 I: If#= 0 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=02 Prot=01 Driver=acm
108 I: If#= 1 Alt= 0 #EPs= 2 Cls=0a(data ) Sub=00 Prot=00 Driver=acm
109
110In the system log you should see::
111
112 usb.c: USB new device connect, assigned device number 2
113 usb.c: kmalloc IF c7691fa0, numif 1
114 usb.c: kmalloc IF c7b5f3e0, numif 2
115 usb.c: skipped 4 class/vendor specific interface descriptors
116 usb.c: new device strings: Mfr=1, Product=2, SerialNumber=3
117 usb.c: USB device number 2 default language ID 0x409
118 Manufacturer: 3Com Inc.
119 Product: 3Com U.S. Robotics Pro ISDN TA
120 SerialNumber: UFT53A49BVT7
121 acm.c: probing config 1
122 acm.c: probing config 2
123 ttyACM0: USB ACM device
124 acm.c: acm_control_msg: rq: 0x22 val: 0x0 len: 0x0 result: 0
125 acm.c: acm_control_msg: rq: 0x20 val: 0x0 len: 0x7 result: 7
126 usb.c: acm driver claimed interface c7b5f3e0
127 usb.c: acm driver claimed interface c7b5f3f8
128 usb.c: acm driver claimed interface c7691fa0
1da177e4
LT
129
130If all this seems to be OK, fire up minicom and set it to talk to the ttyACM
131device and try typing 'at'. If it responds with 'OK', then everything is
132working.