Blame view

Documentation/usb/gadget_multi.txt 5.35 KB
c7ba69229   Michal Nazarewicz   USB: gadget: g_mu...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
                                                               -*- org -*-
  
  * Overview
  
  The Multifunction Composite Gadget (or g_multi) is a composite gadget
  that makes extensive use of the composite framework to provide
  a... multifunction gadget.
  
  In it's standard configuration it provides a single USB configuration
  with RNDIS[1] (that is Ethernet), USB CDC[2] ACM (that is serial) and
  USB Mass Storage functions.
  
  A CDC ECM (Ethernet) function may be turned on via a Kconfig option
  and RNDIS can be turned off.  If they are both enabled the gadget will
  have two configurations -- one with RNDIS and another with CDC ECM[3].
  
  Please not that if you use non-standard configuration (that is enable
  CDC ECM) you may need to change vendor and/or product ID.
  
  * Host drivers
  
  To make use of the gadget one needs to make it work on host side --
  without that there's no hope of achieving anything with the gadget.
  As one might expect, things one need to do very from system to system.
  
  ** Linux host drivers
  
  Since the gadget uses standard composite framework and appears as such
  to Linux host it does not need any additional drivers on Linux host
  side.  All the functions are handled by respective drivers developed
  for them.
  
  This is also true for two configuration set-up with RNDIS
  configuration being the first one.  Linux host will use the second
  configuration with CDC ECM which should work better under Linux.
  
  ** Windows host drivers
  
  For the gadget two work under Windows two conditions have to be met:
  
  *** Detecting as composite gadget
  
  First of all, Windows need to detect the gadget as an USB composite
  gadget which on its own have some conditions[4].  If they are met,
  Windows lets USB Generic Parent Driver[5] handle the device which then
  tries to much drivers for each individual interface (sort of, don't
  get into too many details).
  
  The good news is: you do not have to worry about most of the
  conditions!
  
  The only thing to worry is that the gadget has to have a single
  configuration so a dual RNDIS and CDC ECM gadget won't work unless you
  create a proper INF -- and of course, if you do submit it!
  
  *** Installing drivers for each function
  
  The other, trickier thing is making Windows install drivers for each
  individual function.
  
  For mass storage it is trivial since Windows detect it's an interface
  implementing USB Mass Storage class and selects appropriate driver.
  
  Things are harder with RDNIS and CDC ACM.
  
  **** RNDIS
  
  To make Windows select RNDIS drivers for the first function in the
  gadget, one needs to use the [[file:linux.inf]] file provided with this
  document.  It "attaches" Window's RNDIS driver to the first interface
  of the gadget.
  
  Please note, that while testing we encountered some issues[6] when
  RNDIS was not the first interface.  You do not need to worry abut it
  unless you are trying to develop your own gadget in which case watch
  out for this bug.
  
  **** CDC ACM
  
  Similarly, [[file:linux-cdc-acm.inf]] is provided for CDC ACM.
  
  **** Customising the gadget
  
  If you intend to hack the g_multi gadget be advised that rearranging
  functions will obviously change interface numbers for each of the
  functionality.  As an effect provided INFs won't work since they have
  interface numbers hard-coded in them (it's not hard to change those
  though[7]).
  
  This also means, that after experimenting with g_multi and changing
  provided functions one should change gadget's vendor and/or product ID
  so there will be no collision with other customised gadgets or the
  original gadget.
  
  Failing to comply may cause brain damage after wondering for hours why
  things don't work as intended before realising Windows have cached
  some drivers information (changing USB port may sometimes help plus
  you might try using USBDeview[8] to remove the phantom device).
  
  **** INF testing
  
  Provided INF files have been tested on Windows XP SP3, Windows Vista
  and Windows 7, all 32-bit versions.  It should work on 64-bit versions
  as well.  It most likely won't work on Windows prior to Windows XP
  SP2.
  
  ** Other systems
  
  At this moment, drivers for any other systems have not been tested.
  Knowing how MacOS is based on BSD and BSD is an Open Source it is
  believed that it should (read: "I have no idea whether it will") work
  out-of-the-box.
  
  For more exotic systems I have even less to say...
  
  Any testing and drivers *are* *welcome*!
  
  * Authors
  
  This document has been written by Michal Nazarewicz
  ([[mailto:mina86@mina86.com]]).  INF files have been hacked with
  support of Marek Szyprowski ([[mailto:m.szyprowski@samsung.com]]) and
  Xiaofan Chen ([[mailto:xiaofanc@gmail.com]]) basing on the MS RNDIS
  template[9], Microchip's CDC ACM INF file and David Brownell's
  ([[mailto:dbrownell@users.sourceforge.net]]) original INF files.
  
  * Footnotes
  
  [1] Remote Network Driver Interface Specification,
  [[http://msdn.microsoft.com/en-us/library/ee484414.aspx]].
  
  [2] Communications Device Class Abstract Control Model, spec for this
  and other USB classes can be found at
  [[http://www.usb.org/developers/devclass_docs/]].
  
  [3] CDC Ethernet Control Model.
  
  [4] [[http://msdn.microsoft.com/en-us/library/ff537109(v=VS.85).aspx]]
  
  [5] [[http://msdn.microsoft.com/en-us/library/ff539234(v=VS.85).aspx]]
  
  [6] To put it in some other nice words, Windows failed to respond to
  any user input.
  
  [7] You may find [[http://www.cygnal.org/ubb/Forum9/HTML/001050.html]]
  useful.
  
  [8] http://www.nirsoft.net/utils/usb_devices_view.html
  
  [9] [[http://msdn.microsoft.com/en-us/library/ff570620.aspx]]