Update contrib.
1 // Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
2 // All rights reserved.
3 // This component and the accompanying materials are made available
4 // under the terms of the License "Eclipse Public License v1.0"
5 // which accompanies this distribution, and is available
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
23 @return The name of the driver
27 inline const TDesC& RUsbOtgDriver::Name()
29 _LIT( KDriverName, "USBOTGDRIVER" );
36 @return The version number of the driver
40 inline TVersion RUsbOtgDriver::VersionRequired()
42 const TInt KBuildVersionNumber = KE32BuildVersionNumber;
44 return TVersion( KMajorVersionNumber, KMinorVersionNumber, KBuildVersionNumber );
47 #ifndef __KERNEL_MODE__
50 Open a a logical channel to the OTG driver
52 @return System-wide error code giving status of connection attempt.
54 inline TInt RUsbOtgDriver::Open()
58 // Check to see if this object has already been opened - if it has,
59 // there will be a handle set.
63 User::Panic(OtgdiPanics::KUsbOtgDriverPanicCat, OtgdiPanics::EUsbOtgDriverAlreadyOpened);
66 rc = DoCreate( Name(), VersionRequired(), KNullUnit, NULL, NULL, EOwnerThread );
68 // We expect back KErrNone - any other problem indicates an attempt by
69 // the caller to double-open the driver, which is forbidden
73 RDebug::Print(_L("********************************"));
74 RDebug::Print(_L("* RUsbOtgDriver::Open() Fault! *"));
75 RDebug::Print(_L("********************************"));
82 Special method to alter the default behaviour of the stack:
84 Test mode is activated (special)
86 @return Driver-specific error code or system-wide success
88 inline TInt RUsbOtgDriver::ActivateOptTestMode()
90 return DoControl( EActivateOptTestMode );
94 Overall command to start USB stacks
96 @return Driver-specific error code or system-wide success
98 inline TInt RUsbOtgDriver::StartStacks()
100 return DoControl( EStartStacks );
104 Overall command to stop USB stacks
106 inline void RUsbOtgDriver::StopStacks()
108 static_cast<void>(DoControl( EStopStacks ));
112 Generic event-reporting mechanism, provided in the form of a standard
113 watcher which registers and allows user to block until notification.
115 To cater for rapidly-occurring events, this function will return the
116 earliest event code (assuming a FIFO stack model for recording such
119 The notification function does not support multiple instances, it is expected
120 to be limited solely to ownership by USBMAN
122 @param aOldestEvent parameter to collect the TOtgEvent
123 @param aStatus standard request completion
125 inline void RUsbOtgDriver::QueueOtgEventRequest(TOtgEvent& aOldestEvent, TRequestStatus& aStatus)
127 DoRequest( EQueueOtgEventRequest, aStatus, &aOldestEvent );
131 Cancellation method for event notification
133 Note that the 'cancel' function does not return an error code in the event
134 that there is no registered watcher: it is assumed that the code
135 within will contain an ASSERT_DEBUG check to confirm watcher validity.
137 inline void RUsbOtgDriver::CancelOtgEventRequest()
139 static_cast<void>(DoControl( ECancelOtgEventRequest ));
143 Generic state-reporting mechanism, provided in the form of a standard
144 watcher which registers and allows user to block until notification.
146 To cater for rapidly-occurring changes, this function will return the
147 earliest state code (assuming a FIFO stack model for recording such
150 The notification function does not support multiple instances, it is expected
151 to be limited solely to ownership by USBMAN
153 @param aState parameter to collect the TOtgState
154 @param aStatus standard request completion
156 inline void RUsbOtgDriver::QueueOtgStateRequest(TOtgState& aState, TRequestStatus& aStatus)
158 DoRequest( EQueueOtgStateRequest, aStatus, &aState );
162 Cancellation method for state notification
164 Note that the 'cancel' function does not return an error code in the event
165 that there is no registered watcher: it is assumed that the code
166 within will contain an ASSERT_DEBUG check to confirm watcher validity.
168 inline void RUsbOtgDriver::CancelOtgStateRequest()
170 static_cast<void>(DoControl( ECancelOtgStateRequest ));
174 Generic message-reporting mechanism, provided in the form of a standard
175 watcher which registers and allows user to block until notification.
177 To cater for rapidly-occurring changes, this function will return the
178 earliest message code (assuming a FIFO stack model for recording such
181 The notification function does not support multiple instances, it is expected
182 to be limited solely to ownership by USBMAN
184 @param aMessage parameter to collect the TOtgMessage
185 @param aStatus standard request completion
187 inline void RUsbOtgDriver::QueueOtgMessageRequest(TOtgMessage& aMessage, TRequestStatus& aStatus)
189 DoRequest( EQueueOtgMessageRequest, aStatus, &aMessage );
193 Cancellation method for message notification
195 Note that the 'cancel' function does not return an error code in the event
196 that there is no registered watcher: it is assumed that the code
197 within will contain an ASSERT_DEBUG check to confirm watcher validity.
199 inline void RUsbOtgDriver::CancelOtgMessageRequest()
201 static_cast<void>(DoControl( ECancelOtgMessageRequest ));
205 Single-purpose instant-report mechanism to return the current state
206 of the ID-Pin on the MIni/Micro-AB connector.
208 This method is expected to complete immediately and return the
209 *current* state of the ID-Pin, it will omit any intermediate
210 changes that may have occurred since it was last called.
212 @param aCurrentIdPin parameter to collect the ID-Pin state
213 @param aStatus standard request completion
215 inline void RUsbOtgDriver::QueueOtgIdPinNotification(TOtgIdPin& aCurrentIdPin, TRequestStatus& aStatus)
217 DoRequest( EQueueOtgIdPinNotification, aStatus, &aCurrentIdPin );
221 Cancellation method for ID-Pin notification
223 inline void RUsbOtgDriver::CancelOtgIdPinNotification()
225 static_cast<void>(DoControl( ECancelOtgIdPinNotification ));
229 Single-purpose instant-report mechanism to return the current state
230 of the Voltage level on the Mini/Micro-AB connector.
232 This method is expected to complete immediately and return the
233 *current* state of the voltage, it will omit any intermediate
234 changes that may have occurred since it was last called.
236 @param aCurrentVbus parameter to collect the voltage state
237 @param aStatus standard request completion
239 inline void RUsbOtgDriver::QueueOtgVbusNotification(TOtgVbus& aCurrentVbus, TRequestStatus& aStatus)
241 DoRequest( EQueueOtgVbusNotification, aStatus, &aCurrentVbus );
245 Cancellation method for Vbus notification
247 inline void RUsbOtgDriver::CancelOtgVbusNotification()
249 static_cast<void>(DoControl( ECancelOtgVbusNotification ));
253 Single-purpose instant-report mechanism to return the current state
254 of the permissive/advisory that indicates 'idle' state where it is
255 deemed safe to drop VBUS.
257 This method is expected to complete immediately and return the
258 *current* state of the idleness, it will omit any intermediate
259 changes that may have occurred since it was last called.
261 @param aCurrentIdle parameter to collect the idle state
262 @param aStatus standard request completion
264 inline void RUsbOtgDriver::QueueOtgConnectionNotification(TOtgConnection& aCurrentIdle, TRequestStatus& aStatus)
266 DoRequest( EQueueOtgConnectionNotification, aStatus, &aCurrentIdle );
270 Cancellation method for Idle notification
272 inline void RUsbOtgDriver::CancelOtgConnectionNotification()
274 static_cast<void>(DoControl( ECancelOtgConnectionNotification ));
278 Single-purpose instant-report mechanism to return the current state
279 of the OTG state machine
281 This method is expected to complete immediately and return the
282 *current* state, it will omit any intermediate changes that may
283 have occurred since it was last called.
285 @param aCurrentState parameter to collect the state
286 @param aStatus standard request completion
288 inline void RUsbOtgDriver::QueueOtgStateNotification(TOtgState& aCurrentState, TRequestStatus& aStatus)
290 DoRequest( EQueueOtgStateNotification, aStatus, &aCurrentState );
294 Cancellation method for State notification
296 inline void RUsbOtgDriver::CancelOtgStateNotification()
298 static_cast<void>(DoControl( ECancelOtgStateNotification ));
302 USBMAN wants to assert bus request for 'Host' or 'Peripheral' duty
304 Default-Host: this will result in an attempt to raise Vbus
306 Default-Device: this will result in an attempt to use SRP(+HNP)
308 The bus request is asserted until BusDrop() is called.
310 @return Error code returns are related to the current OTG state context
311 at the time of calling, and not to the asynchronous result
312 (which is reported via event notification)
314 inline TInt RUsbOtgDriver::BusRequest()
316 return DoControl( EBusRequest );
320 USBMAN wants to permit use of the bus, in response to a request from
321 the other (B) end of the link to make use of it.
323 @return Error code returns are related to the current OTG state context
324 at the time of calling, and not to the asynchronous result
325 (which is reported via event notification)
327 inline TInt RUsbOtgDriver::BusRespondSrp()
329 return DoControl( EBusRespondSrp );
333 USBMAN wants to stop using the bus.
335 This function can only be called from the A-Device and will result in
336 the voltage drive being removed from the Vbus line.
338 @return Error code returns are related to the current OTG state context
339 at the time of calling, and not to the asynchronous result
340 (which is reported via event notification)
342 In particular, this function will return an error code if it
343 is called in any 'B' state
345 inline TInt RUsbOtgDriver::BusDrop()
347 return DoControl( EBusDrop );
351 USBMAN wants to clear the bus error state.
353 This function can only be called from the A-Device and will result in
354 the OTG state machine being moved out of the A_VBUS_ERR state.
356 @return Error code returns are related to the current OTG state context
357 at the time of calling, and not to the asynchronous result
358 (which is reported via event notification)
360 In particular, this function will return an error code if it
361 is called in any 'B' state
363 inline TInt RUsbOtgDriver::BusClearError()
365 return DoControl( EBusClearError );
368 #endif // !__KERNEL_MODE__