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