First public contribution.
1 // Copyright (c) 2008-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.
14 // e32\include\d32usbcsc.h
15 // User side class definitions for USB Device support.
25 #ifndef __D32USBCSC_H__
26 #define __D32USBCSC_H__
30 #include <d32usbcshared.h>
33 /** This means that SetInterface was called after RealizeInterface had been called.
34 RealizeInterface is meant to signal that all interfaces have been set.
36 const TInt KErrUsbAlreadyRealized = -6813; //Changed from -6713 for future compatibility with the d32usbcshared.h file
38 const TInt KErrAlternateSettingChanged = -6814;
41 const TUint KChunkCellSize = 1; //1 32 bit integer
42 const TInt KEpDescPacketSizeOffset = 4;
44 /** The user side enpoint number of Endpoint Zero. */
45 const TInt KEp0Number = 0;
47 /* Used in TUsbcScHdrEndpointRecord to describe the endpoint type
50 const TUint8 KUsbScHdrEpDirectionIn=1;
51 const TUint8 KUsbScHdrEpDirectionOut=2;
52 const TUint8 KUsbScHdrEpDirectionBiDir=3;
55 const TUint8 KUsbScHdrEpTypeControl = 0;
56 const TUint8 KUsbScHdrEpTypeIsochronous =1;
57 const TUint8 KUsbScHdrEpTypeBulk = 2;
58 const TUint8 KUsbScHdrEpTypeInterrupt = 3;
59 const TUint8 KUsbScHdrEpTypeUnknown = ~0;
60 /** Used in the the Shared Chunk Header, to represent an endpoint.
62 class TUsbcScHdrEndpointRecord
65 inline TUsbcScHdrEndpointRecord(TInt aBufferNo, TUint8 aType);
66 inline TUint Direction() const;
67 inline TUint Type() const;
75 // This is used to hold the geometry of the shared buffers
76 class TUsbcScBufferRecord
78 friend class DLddUsbcScChannel;
81 inline TUint Offset() const;
82 inline TUint Size() const;
84 inline void Set(TUint aOffset, TUint aEndOffset);
89 struct SUsbcScBufferHeader
91 TInt iHead; // Where the LDD will next write a transfer
92 TInt iTail; // Indicates the fist packet that user side is processing (anything prior is disposable)
93 TInt iBilTail; // This is not used by LDD at all, but just for the BIL's benifit.
97 struct SUsbcScAlternateSetting
103 /** Endpoint pair information. This can be used to control pairing of endpoint
104 for classes that require explicit pairing of endpoint, such as ADC.
106 This is currently not used.
109 class TEndpointPairInfo
112 TEndpointPairInfo(TUint8 aType=0, TUint16 aPair=0, TUint8 aSpare=0);
120 This is the buffer number reserved for use with endpoint zero with the ReadDataNotify and WriteData methods.
122 const TInt KUsbcScEndpointZero = -1;
125 This flag is reserved in TUsbcscEndpointInfo::iFlags, to indicate that the client driver's client wishes reads to operate in a coupled fashion.
126 This behaviour is not currently supported.
128 const TUint KUsbScCoupledRead = 0x1;
131 This flag, used in parameter aFlag of WriteData, is used to indicate that a ZLP should be sent.
133 const TUint KUsbcScWriteFlagsZlp = 0x0001;
136 // Bit fields used in iFlags of TUsbcScTransferHeader
138 const TUint KUsbcScShortPacket = 0x0001;
139 const TUint KUsbcScStateChange = 0x0004;
141 class TUsbcScTransferHeader
151 TUint16 iAltSettingSeq;
155 TUint i[1]; // Extends
156 TUint8 b[4]; // Extends
160 /** The desired endpoint capabilities used in RDevUsbcScClient::SetInterface().
162 This derived class has additional fields used in the shared chunk USB driver.
164 class TUsbcScEndpointInfo: public TUsbcEndpointInfo
167 TUsbcScEndpointInfo(TUint aType=KUsbEpTypeBulk, TUint aDir=KUsbEpDirOut, TInt aInterval=0, TInt aExtra=0,
168 TUint aBufferSize=0, TUint aReadSize=0);
172 /** This indicates the requested size of the endpoint buffer and must be at
173 least as large as iReadSize.
177 /** This is the amount of data that the LDD reads from the bus before it sets
178 up another read and is normally intended to read many packets.
182 /** TEndpointPairInfo represents pairing information for isochronous endpoints.
183 Should be zero in other cases. If this specifies paired endpoints then
184 iExtra (in the base class TUsbcEndpointInfo) also needs to be set to the
185 class specific size for this endpoint descriptor (This is here only for future use).
187 TEndpointPairInfo iPairing;
189 /** The necessary alignment, in bytes, that needs to be applied to the transfer start points
190 of the data. This is only observed on OUT endpoints. Zero can be specified to indicate
191 there are no class side requirements for alignment. The alignment for OUT endpoints is
192 which ever is greater of this field or the USB hardware requirements.
196 /** Flags to indicate how the endpoint should function. None currently defined,
197 but could be used to allow support for direct read.
201 /** Reserved for future use. */
202 TUint32 iReserved2[2];
205 /** This must be filled in prior to a call to RDevUsbcClient::SetInterface().
207 class TUsbcScInterfaceInfo
210 TUsbcScInterfaceInfo(TInt aClass=0, TInt aSubClass=0, TInt aProtocol=0,
211 TDesC16* aString=NULL, TUint aTotalEndpoints=0);
213 /** The class, subclass and protocol that this interface supports. */
214 TUsbcClassInfo iClass;
215 /** The description string for the interface. Used to construct the interface string descriptor. */
216 const TDesC16* iString;
217 /** Total number of endpoints being requested (0-5). Endpoint 0 should not be included in this number. */
218 TUint iTotalEndpointsUsed;
219 /** Desired properties of the endpoints requested.
220 Do NOT include endpoint 0.
221 APIs use endpoint numbers that are offsets into this array.
223 TUsbcScEndpointInfo iEndpointData[KMaxEndpointsPerClient];
224 /** 32 flag bits used for specifying miscellaneous Interface features.
225 Currently defined are:
226 - KUsbcInterfaceInfo_NoEp0RequestsPlease = 0x00000001
228 TUint32 iFeatureWord;
231 /** Package buffer for a TUsbcInterfaceInfo object.
233 @see TUsbcInterfaceInfo
235 typedef TPckgBuf<TUsbcScInterfaceInfo> TUsbcScInterfaceInfoBuf;
237 struct TUsbcScChunkHdrOffs
244 class TUsbcScChunkBuffersHeader // Not instantiable
246 friend class DLddUsbcScChannel;
247 friend class TRealizeInfo;
250 inline TUsbcScBufferRecord* Ep0Out() const;
251 inline TUsbcScBufferRecord* Ep0In() const;
252 inline TUsbcScBufferRecord* Buffers(TInt aBuffer) const;
253 inline TInt NumberOfBuffers() const;
256 TUsbcScChunkBuffersHeader();
260 TUint8 iBufferOffset[8]; // Extends
263 struct TUsbcScChunkAltSettingHeader // Not instantiable
266 TInt iNumOfAltSettings;
267 TUint iAltTableOffset[1]; // Extends
270 class TEndpointBuffer;
273 /** The user side handle to the USB client driver.
275 class RDevUsbcScClient : public RBusLogicalChannel
278 /** @internalComponent */
281 EMajorVersionNumber = 0,
282 EMinorVersionNumber = 1,
283 EBuildVersionNumber = KE32BuildVersionNumber
286 // Bit pattern. s = Request/Control. c = Cancel, m = mode bits, B = Buffer number, R = request number.
287 // scmm mmmm | mmmm mmmm | mmBB BBBB |RRRR RRRR
291 ERequestWriteData = 1,
292 ERequestReadDataNotify = 2,
293 ERequestAlternateDeviceStatusNotify = 3,
294 ERequestReEnumerate = 4,
295 ERequestEndpointStatusNotify = 5,
296 ERequestOtgFeaturesNotify = 6,
297 ERequestMaxRequests, // 7
299 ERequestCancel = 0x40000000,
301 ERequestWriteDataCancel = ERequestWriteData | ERequestCancel,
302 ERequestReadDataNotifyCancel = ERequestReadDataNotify | ERequestCancel,
303 ERequestAlternateDeviceStatusNotifyCancel = ERequestAlternateDeviceStatusNotify | ERequestCancel,
304 ERequestReEnumerateCancel = ERequestReEnumerate | ERequestCancel,
305 ERequestEndpointStatusNotifyCancel = ERequestEndpointStatusNotify | ERequestCancel,
306 ERequestOtgFeaturesNotifyCancel = ERequestOtgFeaturesNotify | ERequestCancel
311 // Changing the order of these enums will break BC.
312 EControlEndpointZeroRequestError, // 00
313 EControlEndpointCaps,
315 EControlGetAlternateSetting,
316 EControlDeviceStatus,
317 EControlEndpointStatus,
318 EControlSetInterface,
319 EControlReleaseInterface,
320 EControlSendEp0StatusPacket,
321 EControlHaltEndpoint, // 09
323 EControlClearHaltEndpoint, // 10
324 EControlSetDeviceControl,
325 EControlReleaseDeviceControl,
326 EControlEndpointZeroMaxPacketSizes,
327 EControlSetEndpointZeroMaxPacketSize,
328 EControlGetDeviceDescriptor,
329 EControlSetDeviceDescriptor,
330 EControlGetDeviceDescriptorSize,
331 EControlGetConfigurationDescriptor,
332 EControlSetConfigurationDescriptor, // 19
334 EControlGetConfigurationDescriptorSize, // 20
335 EControlGetInterfaceDescriptor,
336 EControlSetInterfaceDescriptor,
337 EControlGetInterfaceDescriptorSize,
338 EControlGetEndpointDescriptor,
339 EControlSetEndpointDescriptor,
340 EControlGetEndpointDescriptorSize,
341 EControlGetCSInterfaceDescriptor,
342 EControlSetCSInterfaceDescriptor,
343 EControlGetCSInterfaceDescriptorSize, // 29
345 EControlGetCSEndpointDescriptor, // 30
346 EControlSetCSEndpointDescriptor,
347 EControlGetCSEndpointDescriptorSize,
348 EControlSignalRemoteWakeup,
349 EControlGetStringDescriptorLangId,
350 EControlSetStringDescriptorLangId,
351 EControlGetManufacturerStringDescriptor,
352 EControlSetManufacturerStringDescriptor,
353 EControlRemoveManufacturerStringDescriptor,
354 EControlGetProductStringDescriptor, // 39
356 EControlSetProductStringDescriptor, // 40
357 EControlRemoveProductStringDescriptor,
358 EControlGetSerialNumberStringDescriptor,
359 EControlSetSerialNumberStringDescriptor,
360 EControlRemoveSerialNumberStringDescriptor,
361 EControlGetConfigurationStringDescriptor,
362 EControlSetConfigurationStringDescriptor,
363 EControlRemoveConfigurationStringDescriptor,
364 EControlDeviceDisconnectFromHost,
365 EControlDeviceConnectToHost, // 49
367 EControlDevicePowerUpUdc, // 50
368 EControlDumpRegisters,
369 EControlAllocateEndpointResource,
370 EControlDeAllocateEndpointResource,
371 EControlQueryEndpointResourceUse,
372 EControlGetEndpointZeroMaxPacketSize,
373 EControlGetDeviceQualifierDescriptor,
374 EControlSetDeviceQualifierDescriptor,
375 EControlGetOtherSpeedConfigurationDescriptor,
376 EControlSetOtherSpeedConfigurationDescriptor, // 59
378 EControlCurrentlyUsingHighSpeed, // 60
379 EControlSetStringDescriptor,
380 EControlGetStringDescriptor,
381 EControlRemoveStringDescriptor,
382 EControlSetOtgDescriptor,
383 EControlGetOtgDescriptor,
384 EControlGetOtgFeatures,
385 EControlRealizeInterface,
386 EControlStartNextInAlternateSetting
390 // const static TUint KFieldIdPos = 0;
391 const static TUint KFieldIdMask = 0xFF;
392 const static TUint KFieldBuffPos = 8;
393 const static TUint KFieldBuffMask = 0x3F;
394 const static TUint KFieldFlagsPos = 14;
395 const static TUint KFieldFlagsMask = 0xFFFF;
400 #ifndef __KERNEL_MODE__
404 @param aUnit This should be 0 (zero).
406 @return KErrNone if successful.
408 inline TInt Open(TInt aUnit);
410 inline TVersion VersionRequired() const;
412 /** Stalls ep0 to signal command fault to the host.
414 @return KErrNone if successful.
416 inline TInt EndpointZeroRequestError();
418 /** Retrieves the capabilities of all the endpoints on the device.
420 Suggested use is as follows:
423 TUsbcEndpointData data[KUsbcMaxEndpoints];
424 TPtr8 dataPtr(reinterpret_cast<TUint8*>(data), sizeof(data), sizeof(data));
425 ret = usbPort.EndpointCaps(dataPtr);
428 @param aEpCapsBuf A descriptor encapsulating an array of TUsbcEndpointData.
430 @return KErrNone if successful.
432 inline TInt EndpointCaps(TDes8& aEpCapsBuf);
434 /** Retrieves the capabilities of the USB device.
438 @param aDevCapsBuf A TUsbDeviceCaps object.
440 @return KErrNone if successful.
442 inline TInt DeviceCaps(TUsbDeviceCaps& aDevCapsBuf);
444 /** Copies the current alternate setting for this interface into aInterfaceNumber
445 For USB Interfaces whose main interface is active, this will be 0 (zero).
447 @param aInterfaceNumber Current alternate setting for this interface is copied into this.
449 @return KErrNone if successful.
451 inline TInt GetAlternateSetting(TInt& aInterfaceNumber);
453 /** Copies the current device status into aDeviceStatus.
455 @param aDeviceStatus Current device status is copied into this.
457 @return KErrNone if successful
459 inline TInt DeviceStatus(TUsbcDeviceState& aDeviceStatus);
461 /** Copies the current endpoint status into aEndpointStatus.
463 @param aEndpoint Endpoint number valid for the current alternate setting.
464 @param aEndpointStatus The current endpoint status, might be stalled, not stalled or unknown.
466 @return KErrNone if successful.
468 inline TInt EndpointStatus(TInt aEndpoint, TEndpointState& aEndpointStatus);
471 /** Requests that a zero length status packet be sent to the host in response
472 to a class or vendor specific ep0 SETUP packet.
474 @return KErrNone if successful.
476 inline TInt SendEp0StatusPacket();
478 /** Stalls endpoint aEndpoint, usually to indicate an error condition with a previous command.
479 The host will normally send a SET_FEATURE command on ep0 to acknowledge and clear the stall.
481 @return KErrNone if successful.
483 inline TInt HaltEndpoint(TInt aEndpoint);
485 /** Clears the stall condition on endpoint aEndpoint. This is inluded for symmetry and test purposes.
487 @return KErrNone if successful.
489 inline TInt ClearHaltEndpoint(TInt aEndpoint);
491 /** Requests that device control be allocated to this channel.
493 @return KErrNone if successful.
495 inline TInt SetDeviceControl();
497 /** Relinquishes device control previously allocated to this channel.
499 @return KErrNone if successful.
501 inline TInt ReleaseDeviceControl();
503 /** Returns a bitmap of available ep0 maximum packet sizes.
505 @return bitmap of available ep0 maximum packet sizes.
507 inline TUint EndpointZeroMaxPacketSizes();
509 /** Requests that a maximum packet size of aMaxPacketSize be set on ep0.
511 @param aMaxPacketSize The maximum packet size.
513 @return KErrNone if successful.
515 inline TInt SetEndpointZeroMaxPacketSize(TInt aMaxPacketSize);
517 /** Queries the current maximum packet size on ep0.
519 @return The currently set maximum packet size on ep0.
521 inline TInt GetEndpointZeroMaxPacketSize();
523 /** Copies the current device descriptor into aDeviceDescriptor.
525 @param aDeviceDescriptor Receives the current device descriptor.
527 @return KErrNone if successful.
529 inline TInt GetDeviceDescriptor(TDes8& aDeviceDescriptor);
531 /** Sets the contents of aDeviceDescriptor to be the current device descriptor.
533 @param aDeviceDescriptor Contains the device descriptor.
535 @return KErrNone if successful.
537 inline TInt SetDeviceDescriptor(const TDesC8& aDeviceDescriptor);
539 /** Gets the size of the current device descriptor. This is unlikely to be anything other than 9.
541 @param aSize Receives the size of the current device descriptor.
543 @return KErrNone if successful.
545 inline TInt GetDeviceDescriptorSize(TInt& aSize);
547 /** Copies the current configuration descriptor into aConfigurationDescriptor.
549 @param aConfigurationDescriptor Receives the current configuration descriptor.
551 @return KErrNone if successful.
553 inline TInt GetConfigurationDescriptor(TDes8& aConfigurationDescriptor);
555 /** Sets the contents of aConfigurationDescriptor to be the current configuration descriptor.
557 @param aConfigurationDescriptor Contains the configuration descriptor.
559 @return KErrNone if successful.
561 inline TInt SetConfigurationDescriptor(const TDesC8& aConfigurationDescriptor);
563 /** Gets the size of the current configuration descriptor.
565 @param aSize Receives the size of the current configuration descriptor.
567 @return KErrNone if successful.
569 inline TInt GetConfigurationDescriptorSize(TInt& aSize);
571 /** Copies the interface descriptor into aInterfaceDescriptor for the interface with alternate
572 setting aSettingNumber, 0 for the main interface.
574 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
575 @param aInterfaceDescriptor Receives the interface descriptor.
577 @return KErrNone if successful.
579 inline TInt GetInterfaceDescriptor(TInt aSettingNumber, TDes8& aInterfaceDescriptor);
581 /** Sets the interface descriptor contained in aInterfaceDescriptor for the interface with
582 alternate setting aSettingNumber, 0 for the main interface, for transmission to the host
585 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
586 @param aInterfaceDescriptor Contains the interface descriptor to be set.
588 @return KErrNone if successful.
590 inline TInt SetInterfaceDescriptor(TInt aSettingNumber, const TDesC8& aInterfaceDescriptor);
592 /** Copies the size of the interface descriptor for the interface with alternate
593 setting aSettingNumber, 0 for the main interface, into aSize.
595 @param aSettingNumber The alternate setting.
596 @param aSize receives the size of the interface descriptor.
598 @return KErrNone if successful.
600 inline TInt GetInterfaceDescriptorSize(TInt aSettingNumber, TInt& aSize);
602 /** Copies the endpoint descriptor for logical endpoint number aEndpointNumber into aEndpointDescriptor
603 for the interface with alternate setting aSettingNumber, 0 for the main interface.
605 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
606 @param aEndpointNumber The endpoint number of the endpoint.
607 @param aEndpointDescriptor Receives the endpoint descriptor.
609 @return KErrNone if successful.
611 inline TInt GetEndpointDescriptor(TInt aSettingNumber, TInt aEndpointNumber, TDes8& aEndpointDescriptor);
613 /** Sets the endpoint descriptor for logical endpoint number aEndpointNumber contained in
614 aEndpointDescriptor for the interface with alternate setting aSettingNumber, 0 for the main interface,
615 for transmission to the host during enumeration.
617 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
618 @param aEndpointNumber Valid endpoint number on this interface.
619 @param aEndpointDescriptor Contains the endpoint descriptor to be set.
621 @return KErrNone if successful.
623 inline TInt SetEndpointDescriptor(TInt aSettingNumber, TInt aEndpointNumber,
624 const TDesC8& aEndpointDescriptor);
626 /** Copies the size of the endpoint descriptor for logical endpoint number aEndpointNumber for the
627 interface with alternate setting aSettingNumber, 0 for the main interface, into aSize.
629 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
630 @param aEndpointNumber Valid endpoint number on this interface.
631 @param aSize Receives the size of the endpoint descriptor.
633 @return KErrNone if successful.
635 inline TInt GetEndpointDescriptorSize(TInt aSettingNumber, TInt aEndpointNumber, TInt& aSize);
637 /** Get OTG descriptor size
639 @param aSize TInt Reference which contains OTG descriptor size on return.
641 inline void GetOtgDescriptorSize(TInt& aSize);
643 /** Get OTG descriptor of USB on-the-go feature.
645 @param aOtgDesc User-side buffer to store copy of descriptor.
647 @return KErrNone if successful.
649 inline TInt GetOtgDescriptor(TDes8& aOtgDesc);
651 /** Set OTG descriptor by user to enable/disable USB on-the-go feature.
653 @param aOtgDesc Descriptor buffer containing OTG features.
655 @return KErrNone if successful.
657 inline TInt SetOtgDescriptor(const TDesC8& aOtgDesc);
659 /** Copies the current device_qualifier descriptor into aDescriptor.
661 @param aDescriptor Receives the current device_qualifier descriptor.
663 @return KErrNone if successful.
665 inline TInt GetDeviceQualifierDescriptor(TDes8& aDescriptor);
667 /** Sets the device_qualifier descriptor to the contents of aDescriptor.
669 @param aDescriptor Contains the new device_qualifier descriptor.
671 @return KErrNone if successful.
673 inline TInt SetDeviceQualifierDescriptor(const TDesC8& aDescriptor);
675 /** Copies the current other_speed_configuration descriptor into aDescriptor.
677 @param aDescriptor Receives the current other_speed_configuration descriptor.
679 @return KErrNone if successful.
681 inline TInt GetOtherSpeedConfigurationDescriptor(TDes8& aDescriptor);
683 /** Sets the other_speed_configuration descriptor to the contents of aDescriptor.
685 @param aDescriptor Contains the new other_speed_configuration descriptor.
687 @return KErrNone if successful.
689 inline TInt SetOtherSpeedConfigurationDescriptor(const TDesC8& aDescriptor);
691 /** Copies the class specific interface descriptor block into aInterfaceDescriptor for the interface
692 with alternate setting aSettingNumber, 0 for the main interface.
694 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
695 @param aInterfaceDescriptor Contains the interface descriptor to be set.
697 @return KErrNone if successful.
699 inline TInt GetCSInterfaceDescriptorBlock(TInt aSettingNumber, TDes8& aInterfaceDescriptor);
701 /** aSettingNumber is the alternate interface setting, 0 for the main interface, that the descriptor block
702 aDes should be attached to. aDes is a block of data containing at least one class specific descriptor
703 for transmission during enumeration after the class interface descriptor (or alternate interface
704 descriptor) has been sent, but before the endpoint descriptors belonging to this interface are sent.
705 aDes may contain as many descriptors as are necessary or only one. SetCSInterfaceDescriptorBlock()
706 should be called at any time after SetInterface() has been called to establish a main interface or an
707 alternate interface. More than one call may be made - the data blocks will be concatenated prior to
708 sending. No checking or validation of the contents of aDes will be made and it is the caller's
709 responsibility to ensure that the data supplied is correct and appropriate to the interface identified
712 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
713 @param aInterfaceDescriptor Contains the interface descriptor to be set.
715 @return KErrNone if successful.
717 inline TInt SetCSInterfaceDescriptorBlock(TInt aSettingNumber, const TDesC8& aInterfaceDescriptor);
719 /** Copies the size of the class specific interface descriptor block for the interface with alternate
720 setting aSettingNumber, 0 for the main interface, into aSize.
722 @param aSettingNumber The alternate setting number.
723 @param aSize receives the size of the interface descriptor.
725 @return KErrNone if successful.
727 inline TInt GetCSInterfaceDescriptorBlockSize(TInt aSettingNumber, TInt& aSize);
729 /** Copies the class specific endpoint descriptor for logical endpoint number aEndpointNumber
730 into aEndpointDescriptor for the interface with alternate setting aSettingNumber, 0 for the main
733 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
734 @param aEndpointNumber Valid endpoint number on this interface.
735 @param aEndpointDescriptor Receives the endpoint descriptor.
737 @return KErrNone if successful.
739 inline TInt GetCSEndpointDescriptorBlock(TInt aSettingNumber, TInt aEndpointNumber,
740 TDes8& aEndpointDescriptor);
742 /** Sets the class specific endpoint descriptor for logical endpoint number aEndpointNumber contained in
743 aEndpointDescriptor for the interface with alternate setting aSettingNumber, 0 for the main interface,
744 for transmission to the host during enumeration.
746 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
747 @param aEndpointNumber Valid endpoint number on this interface.
748 @param aEndpointDescriptor Contains the endpoint descriptor to be set.
750 @return KErrNone if successful.
752 inline TInt SetCSEndpointDescriptorBlock(TInt aSettingNumber, TInt aEndpointNumber,
753 const TDesC8& aEndpointDescriptor);
755 /** Copies the size of the class specific endpoint descriptor block for logical endpoint number
756 aEndpointNumber for the interface with alternate setting aSettingNumber, 0 for the main interface,
759 @param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
760 @param aEndpointNumber Valid endpoint number on this interface.
761 @param aSize On return, contains the size of the class specific endpoint descriptor block.
763 @return KErrNone if successful.
765 inline TInt GetCSEndpointDescriptorBlockSize(TInt aSettingNumber, TInt aEndpointNumber, TInt& aSize);
767 /** Generates a Remote Wakeup bus condition.
768 The capability of the device to generate Remote Wakeup signalling is enquired in
769 RDevUsbcClient::DeviceCaps.
771 @return KErrNone if this signalling is possible and the signal has been generated.
773 inline TInt SignalRemoteWakeup();
775 /** Simulates a physical removal of the USB cable by disabling the D+/- pull-ups.The iConnect member of
776 TUsbDeviceCapsV01, returned by RDevUsbcClient::DeviceCaps(), indicates whether this functionality is
779 @return KErrNone if successful.
781 inline TInt DeviceDisconnectFromHost();
783 /** Simulates a physical insertion of the USB cable by enabling the D+/- pull-ups.The iConnect member
784 of TUsbDeviceCapsV01, returned by RDevUsbcClient::DeviceCaps(), indicates whether this functionality
787 @return KErrNone if successful.
789 inline TInt DeviceConnectToHost();
791 /** Powers up the UDC and connects it to the bus if one or more interfaces exist.
793 @return KErrNone if UDC successfully powered up, KErrNotReady if no
794 interfaces have been registered yet, KErrHardwareNotAvailable if UDC
795 couldn't be activated.
797 inline TInt PowerUpUdc();
799 /** Enquires about the current operating speed of the UDC.
801 @return ETrue if the UDC is currently operating at High speed, EFalse otherwise.
803 inline TBool CurrentlyUsingHighSpeed();
805 /** Allocates the use of aResource to aEndpoint. It will be used from when the current bus transfer has been
808 @param aResource is typically some rationed hardware resource or possibly specifies a type of endpoint
809 behaviour. aResource is not a bitmap and TEndpointResource values should not be combined.
810 @param aEndpoint The endpoint number to which the resource is to be allocated.
812 @return KErrNone if successful, KErrInUse if the resource is already consumed and cannot be allocated,
813 KErrNotSupported if the endpoint does not support the resource requested.
815 @publishedPartner @deprecated
817 inline TInt AllocateEndpointResource(TInt aEndpoint, TUsbcEndpointResource aResource);
819 /** Deallocates the use of aResource aEndpoint or ends a specified endpoint behaviour.
821 @param aResource is typically some rationed hardware resource or possibly specifies a type of endpoint
822 behaviour. aResource is not a bitmap and TEndpointResource values should not be combined.
823 @param aEndpoint The endpoint number from which the resource is to be removed.
825 @return KErrNone if the resource has been successfully deallocated, KErrNotSupported if the endpoint
826 does not support the resource requested.
828 @publishedPartner @deprecated
830 inline TInt DeAllocateEndpointResource(TInt aEndpoint, TUsbcEndpointResource aResource);
832 /** Queries endpoint resource use.
834 @param aResource is typically some rationed hardware resource or possibly specifies a type of endpoint
835 behaviour. aResource is not a bitmap and TEndpointResource values should not be combined.
836 @param aEndpoint The endpoint number at which the resource is to be queried.
838 @return ETrue is the specified resource is in use at the endpoint and EFalse if not.
840 inline TBool QueryEndpointResourceUse(TInt aEndpoint, TUsbcEndpointResource aResource);
842 /** Request (i.e. claim for this channel) up to five endpoints and set the class type for this USB
843 interface. 'aInterfaceData' is a package buffer which describes the interface and all the endpoints
844 being requested by the driver for this interface.
846 @param aInterfaceNumber Distinguishes between alternate interfaces. If these are not be used then this
847 should always be zero. If this parameter is used, then its value must be one more than that of the
848 proceeding alternate interface.
849 @param aInterfaceData A package buffer which describes the interface and all the endpoints being
850 requested by the driver for this interface.
853 @return KErrInUse if any of the endpoints being requested have already been claimed by another channel.
854 KErrNotSupported if an endpoint with all of the specified properties is not supported on this
855 platform. KErrNoMemory if insufficient memory is available to complete the operation.
857 inline TInt SetInterface(TInt aInterfaceNumber, TUsbcScInterfaceInfoBuf& aInterfaceData);
861 This method should be called after SetInterface has been called for all possible alternative settings.
862 Calling this invalidates further calls to SetInterface. On success, a chunk handle is created and
863 passed back though aChunk. This is needed for the user side to access the shared chunk where the
864 data is stored. Note that if you are using the BIL (described later), then FinalizeInterface (...)
865 should be used instead, which will call this method.
867 @return KErrNone on successful completion, or one of the system wide error codes.
869 inline TInt RealizeInterface(RChunk& aChunk);
872 /** Release an interface previously claimed by this channel. Alternate interfaces need to be released
873 in strict descending order, starting with the last (i.e. highest numbered) one.
874 It is not necessary to release an interface that wasn't successfully requested.
876 @param aInterfaceNumber Specifies the alternate setting number 'aInterfaceNum' of the interface to be
879 @return KErrNone if successful. KErrArgument if the alternate setting doesn't exist or is released out
882 inline TInt ReleaseInterface(TInt aInterfaceNumber);
884 /** Copies the current string descriptor language ID (LANGID) code into the aLangId argument. Even though
885 the USB spec allows for the existence of a whole array of LANGID codes, we only support one.
887 @param aLangId Receives the LANGID code.
889 @return KErrNone if successful, KErrArgument if problem with argument (memory cannot be written to, etc.).
891 inline TInt GetStringDescriptorLangId(TUint16& aLangId);
893 /** Sets the string descriptor language ID (LANGID). Even though the USB spec allows for the existence of
894 a whole array of LANGID codes, we only support one.
896 @param aLangId The LANGID code to be set.
898 @return KErrNone if successful.
900 inline TInt SetStringDescriptorLangId(TUint16 aLangId);
902 /** Copies the string descriptor identified by the iManufacturer index field of the Standard Device
903 Descriptor into the aString argument.
905 @param aString Receives manufacturer string.
907 @return KErrNone if successful, KErrArgument if MaxLength of aString is too small to hold the entire
908 descriptor, KErrNotFound if the string descriptor couldn't be found.
910 inline TInt GetManufacturerStringDescriptor(TDes16& aString);
912 /** Sets the string descriptor identified by the iManufacturer index field of the Standard Device
913 Descriptor to the aString argument.
915 @param aString Contains the new manufacturer string descriptor.
917 @return KErrNone if successful, KErrNoMemory if no memory is available to store the new string from
918 aString (in which case the old string descriptor will be preserved).
920 inline TInt SetManufacturerStringDescriptor(const TDesC16& aString);
922 /** Removes (deletes) the string descriptor identified by the iManufacturer index field of the Standard
923 Device Descriptor and sets that field to zero.
925 @return KErrNone if successful, KErrNotFound if the string descriptor couldn't be found.
927 inline TInt RemoveManufacturerStringDescriptor();
929 /** Retrieves the string descriptor identified by the iProduct index field of the Standard Device
930 Descriptor into the aString argument.
932 @param aString Receives product string.
934 @return KErrNone if successful, KErrArgument if MaxLength of aString is too small to hold the entire
935 descriptor, KErrNotFound if the string descriptor couldn't be found.
937 inline TInt GetProductStringDescriptor(TDes16& aString);
939 /** Sets the string descriptor identified by the iProduct index field of the Standard Device Descriptor to
940 the aString argument.
942 @param aString Contains the new product string descriptor.
944 @return KErrNone if successful, KErrNoMemory if no memory is available to store the new string from
945 aString (in which case the old string descriptor will be preserved).
947 inline TInt SetProductStringDescriptor(const TDesC16& aString);
949 /** Removes (deletes) the string descriptor identified by the iProduct index field of the Standard Device
950 Descriptor and sets that field to zero.
952 @return KErrNone if successful, KErrNotFound if the string descriptor couldn't be found.
954 inline TInt RemoveProductStringDescriptor();
956 /** Retrieves the string descriptor identified by the iSerialNumber index field of the Standard Device
957 Descriptor into the aString argument.
959 @param aString Receives product string.
961 @return KErrNone if successful, KErrArgument if MaxLength of aString is too small to hold the entire
962 descriptor, KErrNotFound if the string descriptor couldn't be found.
964 inline TInt GetSerialNumberStringDescriptor(TDes16& aString);
966 /** Sets the string descriptor identified by the iSerialNumber index field of the Standard Device
967 Descriptor to the aString argument.
969 @param aString Contains the new serial number string descriptor.
971 @return KErrNone if successful, KErrNoMemory if no memory is available to store the new string from
972 aString (in which case the old string descriptor will be preserved).
974 inline TInt SetSerialNumberStringDescriptor(const TDesC16& aString);
976 /** Removes (deletes) the string descriptor identified by the iSerialNumber index field of the Standard
977 Device Descriptor and sets that field to zero.
979 @return KErrNone if successful, KErrNotFound if the string descriptor couldn't be found.
981 inline TInt RemoveSerialNumberStringDescriptor();
983 /** Retrieves the string descriptor identified by the iConfiguration index field of the (first) Standard
984 Configuration Descriptor into the aString argument.
986 @param aString Receives configuration string.
988 @return KErrNone if successful, KErrArgument if MaxLength of aString is too small to hold the entire
989 descriptor, KErrNotFound if the string descriptor couldn't be found.
991 inline TInt GetConfigurationStringDescriptor(TDes16& aString);
993 /** Sets the string descriptor identified by the iConfiguration index field of the Standard Configuration
994 Descriptor to the aString argument.
996 @param aString Contains the new serial number string descriptor.
998 @return KErrNone if successful, KErrNoMemory if no memory is available to store the new string from
999 aString (in which case the old string descriptor will be preserved).
1001 inline TInt SetConfigurationStringDescriptor(const TDesC16& aString);
1003 /** Removes (deletes) the string descriptor identified by the iConfiguration index field of the Standard
1004 Configuration Descriptor and sets that field to zero.
1006 @return KErrNone if successful, KErrNotFound if the string descriptor couldn't be found.
1008 inline TInt RemoveConfigurationStringDescriptor();
1010 /** Copies the string of the USB string descriptor at the specified index in the string descriptor array
1011 into the aString argument.
1013 Although this function can also be used for it, for querying most standard string descriptors
1014 there exists a set of dedicated access functions.
1016 @see RDevUsbcClient::GetStringDescriptorLangId
1017 @see RDevUsbcClient::GetManufacturerStringDescriptor
1018 @see RDevUsbcClient::GetProductStringDescriptor
1019 @see RDevUsbcClient::GetSerialNumberStringDescriptor
1020 @see RDevUsbcClient::GetConfigurationStringDescriptor
1022 @param aIndex The position of the string descriptor in the string descriptor array.
1023 @param aString The target location for the string descriptor copy.
1025 @return KErrNone if successful, KErrNotFound if no string descriptor exists at the specified index,
1026 KErrArgument if MaxLength() of aString is too small to hold the entire descriptor.
1028 inline TInt GetStringDescriptor(TUint8 aIndex, TDes16& aString);
1030 /** Sets the aString argument to be the string of a USB string descriptor at the specified index in the
1031 string descriptor array. If a string descriptor already exists at that position then its string will
1034 Care should be taken, when choosing aIndex, not to inadvertently overwrite one of the standard
1035 string descriptors. For their manipulation there exists a set of dedicated access functions.
1037 @see RDevUsbcClient::SetStringDescriptorLangId
1038 @see RDevUsbcClient::SetManufacturerStringDescriptor
1039 @see RDevUsbcClient::SetProductStringDescriptor
1040 @see RDevUsbcClient::SetSerialNumberStringDescriptor
1041 @see RDevUsbcClient::SetConfigurationStringDescriptor
1043 @param aIndex The position of the string descriptor in the string descriptor array.
1044 @param aString Contains the string descriptor to be set.
1046 @return KErrNone if successful, KErrArgument if aIndex is invalid, KErrNoMemory if no memory
1047 is available to store the new string (an existing descriptor at that index will be preserved).
1049 inline TInt SetStringDescriptor(TUint8 aIndex, const TDesC16& aString);
1051 /** Removes (deletes) the USB string descriptor at the specified index in the string descriptor array.
1052 The position in the array of other string descriptors is not affected.
1054 Care should be taken, when choosing aIndex, not to inadvertently delete a standard string descriptor
1055 (also because index references from non-string descriptors would be invalidated). For the deletion
1056 of most standard string descriptors there exists a set of dedicated functions.
1058 @see RDevUsbcClient::RemoveManufacturerStringDescriptor
1059 @see RDevUsbcClient::RemoveProductStringDescriptor
1060 @see RDevUsbcClient::RemoveSerialNumberStringDescriptor
1061 @see RDevUsbcClient::RemoveConfigurationStringDescriptor
1063 @param aIndex The position of the string descriptor in the string descriptor array.
1065 @return KErrNone if successful, KErrNotFound if no string descriptor exists at the specified index.
1067 inline TInt RemoveStringDescriptor(TUint8 aIndex);
1071 /** Requests notification for when there is data available on the buffer indicated. If the buffer
1072 already has data in it, it will return immediately, otherwise it will block until there is.
1074 If the BIL methods are being used (recommended), then this method should not be called directly,
1075 using TEndpointBuffer::GetBuffer instead.
1077 @param aBufferNumber Indicates the buffer for which the caller wishes to know about data
1078 additions. The buffer needed of any given endpoint can be found by inspecting the alternative
1079 setting table, in the chunk header. The location of the buffer can be found by looking at the
1080 buffer offset table, also in the chunk header.
1082 @param aStatus The request status where notification of completion is directed. KErrCancel is
1083 returned if the asynchronous operation was cancelled.
1085 @param aLength A preference for the quantity of data to be read. This value is only a
1086 suggestion and my be ignored. The default value of 0 indicates no preference.
1088 @return KErrNone on success, or KErrArgument if the buffer number is invalid.
1090 inline TInt ReadDataNotify(TInt aBufferNumber, TRequestStatus& aStatus, TInt aLength=0);
1093 /** Requests the LDD to write the contents of the given buffer to the USB hardware. Notification is
1094 given when this is complete. More then one write request can be queued on any one endpoint, to allow
1095 for less Hardware idling between buffers.
1097 If the BIL methods are being used (recommended), then this method should not be called directly,
1098 using TEndpointBuffer::WriteBuffer instead.
1100 @param aBufferNumber represents the buffer number of the buffer of which the caller has placed the
1101 data. As described with ReadDataNotify(...), details of the buffers can be found in the chunk header.
1103 @param aStart Represents the start offset of the data within the chunk. This start location must be
1104 aligned to a multiple of the maximum packet size for the endpoint, so that the data can be DMAed
1105 straight out of the buffer.
1107 @param aLength Represents the amount of data to be sent to the host in bytes.
1109 @param aFlags Is a bitfield, where bit 0 should be set if a ZLP is to be sent to the host after the
1110 current transaction. All other bits are reserved for future use.
1112 inline void WriteData(TInt aBufferNumber, TUint aStart, TUint aLength, TUint aFlags, TRequestStatus& aStatus);
1116 /** Cancels an outstanding read request on endpoint buffer aBufferNumber.
1118 @param aBufferNumber The endpoint buffer number whose read is to be cancelled.
1120 inline void ReadCancel(TInt aBufferNumber);
1123 /** Cancels an outstanding write request on endpoint buffer aBufferNumber.
1125 @param aBufferNumber The endpoint buffer number whose write is to be cancelled.
1127 inline void WriteCancel(TInt aBufferNumber);
1129 /** Cancels any transfer on any endpoint buffer specified in aBufferMask.
1132 // Cancel transfer requests on buffers 1, 2, 3 & 4
1133 usbPort.EndpointTransferCancel(1 | 2 | 4 | 8);
1136 @param aBufferMask bitmap of the endpoint buffer numbers.
1138 inline void EndpointTransferCancel(TUint aBufferMask);
1140 /** Register for notification when a change of the Interface alternate setting or the USB Controller's
1141 current state occurs. When the alternate setting or the Controller state changes, then the
1142 asynchronous function completes and the current alternate setting number or Controller state is
1143 written back to aValue. If the KUsbAlternateSetting bit is set then the remaining bits are the
1144 alternate setting number. Otherwise aValue is interpreted as a TUsbcDeviceState.
1146 @see TUsbcDeviceState
1148 @param aStatus The request status.
1149 @param aValue Receives the alternate setting number or Controller state.
1151 inline void AlternateDeviceStatusNotify(TRequestStatus& aStatus, TUint& aValue);
1153 /** Completes an AlternateDeviceStatusNotify request. If a request has previously been made then the
1154 status variable is updated with the current device state.
1156 inline void AlternateDeviceStatusNotifyCancel();
1158 /** If the channel has changed the grouping of endpoints between interfaces or changed the interface class
1159 type from the defaults then it is necessary to force a re-enumeration. This will typically involve the
1160 Symbian OS device initiating a disconnection and re-connection. This is an asynchronous operation
1161 which will complete when the Controller is successfully configured by the host, i.e. has achieved
1162 EUsbcDeviceStateConfigured. Since it is not known if the operation has failed, at the same time that
1163 a ReEnumerate request is made, a timer should be set up to complete after approximately 5 seconds. It
1164 can be assumed that if the operation has not completed after this time interval then it will not
1167 @param aStatus The request status.
1169 inline void ReEnumerate(TRequestStatus& aStatus);
1171 /** Cancels an outstanding ReEnumerate() request.
1173 inline void ReEnumerateCancel();
1175 /** Register for notification when a change in stall status of any of the interface's endpoints occurs,
1176 but not ep0. When a change in stall status occurs, then the asynchronous function completes and the
1177 current stall state is written back to 'aEndpointStatus' as a bit map: Only stall state changes caused
1178 by SET_FEATURE and CLEAR_FEATURE standard commands on ep0 will be notified when this function
1179 completes. After this request completes the request should be re-issued to obtain future
1182 @param aStatus The request status.
1183 @param aEndpointMask A bitmap of the endpoints' stall status. This is filled in when the call completes.
1184 bit 1 represents the interface's virtual endpoint 1, (KUsbcEndpoint1Bit)
1185 bit 2 represents the interface's virtual endpoint 2, (KUsbcEndpoint2Bit) etc.
1186 bit value 0 - not stalled,
1187 bit value 1 - stalled.
1189 inline void EndpointStatusNotify(TRequestStatus& aStatus, TUint& aEndpointMask);
1191 /** Completes an endpoint status notify request.
1193 inline void EndpointStatusNotifyCancel();
1195 /** Get current on-the-go features relating to the ability of device/host pair to
1196 perform OTG role swap.
1198 @param aFeatures On return it contains features the device currently has.
1199 bit 2 represents b_hnp_enable, (KUsbOtgAttr_B_HnpEnable)
1200 bit 3 represents a_hnp_support, (KUsbOtgAttr_A_HnpSupport)
1201 bit 4 represents a_alt_hnp_support, (KUsbOtgAttr_A_AltHnpSupport)
1202 @return KErrNone if successful, KErrNotSupported if OTG is not supported by
1203 this device, otherwise system-wide error returns.
1205 inline TInt GetOtgFeatures(TUint8& aFeatures);
1207 /** Register for notification on USB on-the-go features' change. If any OTG feature
1208 is changed, request completes and current feature value is filled in aValue.
1210 @param aStatus Request status object.
1211 @param aValue On request completion, contains current OTG feature value.
1213 inline void OtgFeaturesNotify(TRequestStatus& aStatus, TUint8& aValue);
1215 /** Cancel pending OTG feature request.
1217 inline void OtgFeaturesNotifyCancel();
1219 /** This function retrieves the alternate setting that the WriteData function can
1220 write to. After a host sets the alternate setting, writes to the IN endpoint
1221 are not permitted by the LDD until this method has been called.
1222 This function is not asynchronous nor blocking, and should not be used to
1223 detect that an alternate setting has happened.
1225 If the BIL methods are being used (recommended), then this method should not be called directly.
1227 @return The alternative setting number or KErrInUse if the current alternative
1228 setting is already in use, that is to say that the alternative setting has not changed.
1230 inline TInt StartNextInAlternateSetting();
1233 /*******************************\
1234 * Buffer Interface Layer (BIL) *
1235 \*******************************/
1237 // This following functions, as well as the ones in TEndpointBuffer (below),
1238 // can be considered the BIL.
1242 Finalize the interface, creating a chunk for use with reading/writing to endpoints.
1243 FinalizeInterface should be called after all alternate interfaces have been set up with SetInteface.
1244 Any attempt to call SetInterface after this stage will fail.
1246 @return KErrNone if operation is successfull
1247 System wide error codes if chunk creation failed
1249 IMPORT_C TInt FinalizeInterface();
1252 Finalize the interface, creating a chunk for use with reading/writing to endpoints. This
1253 version of the method provides a handle to the chunk, which is needed if the
1254 buffer is to be passed and used by other processes.
1255 FinalizeInterface should be called after all alternate interfaces have been set up with SetInteface.
1256 Any attempt to call SetInterface after this stage will fail.
1258 @param aChunk On success aChunk points to the created chunk.
1259 @return KErrNone if operation is successfull
1260 System wide error codes if chunk creation failed
1262 IMPORT_C TInt FinalizeInterface(RChunk*& aChunk);
1265 Opens an endpoint, an endpoint should be opened before any operations are attempted on it.
1267 @param aEpB On success aEpB will be filled with the relevant details for that endpoint
1268 @param aEpI endpoint number to be opened
1269 @return KErrNone if operation is successfull
1270 KErrNotFound if endpoint number is not valid for current alternate setting
1271 KErrInUse if endpoint is already opened
1272 KErrArgument if endpoint buffer argument passed is already in existence and being used
1274 IMPORT_C TInt OpenEndpoint(TEndpointBuffer & aEpB, TInt aEpI);
1277 Switches to processing from one Alternate setting to the next. All open endpoints (except EP0) must
1278 be close before this can be called.
1280 @param aFlush If ETrue, the method will purge the buffers of any data unread for the old setting.
1281 If each endpoint was not read up until KErrEof was reached, then this should be set.
1283 @return the alternate Setting if operation is successful
1284 KErrInUse if any endpoints in present alternate setting is still open (except Ep0)
1285 KErrNotReady if there is no change in alternate setting
1286 KErrInUse if StartNextInAlternateSetting detects no change in alternate setting.
1287 KErrCorrupt if the buffer structure becomes corrupt.
1289 IMPORT_C TInt StartNextOutAlternateSetting(TBool aFlush);
1292 Sets aChunk to RChunk currently in use by BIL.
1294 @param aChunk aChunk will point to RChunk currently in use by BIL
1295 @return KErrNone on success otherwise a system wide error code, if an error has occurred.
1297 IMPORT_C TInt GetDataTransferChunk(RChunk*& aChunk);
1300 /** @internalTechnology */
1301 TInt Drain(TUint aBuffer);
1302 /** @internalTechnology */
1303 TInt Peek(TUint aBuffer);
1304 /** @internalTechnology */
1305 TInt FindNextAlternateSetting();
1308 TUint8 iEndpointStatus; /** @internalTechnology Each bit corresponds to each endpoint's open/close status. */
1309 RChunk iSharedChunk; /** @internalTechnology The shared chunk in use. */
1310 TInt iAltSettingSeq; /** @internalTechnology Used to track alternate setting changes. */
1311 TInt iAlternateSetting; /** @internalTechnology The alternate setting used by OUT endpoints, which may lag that of IN endpoints. */
1312 TInt iNewAltSetting; /** @internalTechnology Used to track the next alternate setting change on OUT endpoints,
1313 during transition from one to the next. */
1314 TInt iInAltSetting; /** @internalTechnology The alternate setting used by IN endpoints, which may be ahead of OUT endpoints. */
1317 friend class TEndpointBuffer;
1318 #endif // #ifndef __KERNEL_MODE__
1321 #ifndef __KERNEL_MODE__
1325 This class forms part of the Buffer Interface Layer (BIL), which forms the
1326 user side component of the USB Shared Chunk Client. Objects of this type
1327 represent the shared chunk buffer, for a given endpoint.
1328 The method RDevUsbcScClient::OpenEndpoint() should be used to initialise
1329 objects of this type.
1331 class TEndpointBuffer
1336 This return value used by GetBuffer indicates that the item pointed to by
1337 aBuffer/aOffset represents a state change, instead of endpoint data.
1339 const static TInt KStateChange = 0x01;
1342 IMPORT_C TEndpointBuffer();
1345 Read the next block of data from the Shared chunk buffer. This method should be used if the user wishes to process one block of data at a time.
1346 This method also expires the previously read block, meaning that the memory used by the block of data may be re-used by the system, overwriting it
1348 @param aBuffer aBuffer will point to data location in shared chunk
1349 @param aSize aSize will hold the number of valid bytes that can be read
1350 @param aZLP aZLP will indicate whether its a short packet or not
1351 @param aStatus In case of no data available to be read, aStatus will be passed on to LDD, and user side should wait for
1352 asynchronous call ReadDataNotify to return
1353 @param aLength Not used at the moment
1354 @return KErrCompletion if operation is successfull and data is available in the buffer
1355 KErrNone if no data is available to be read
1356 KErrEof if alternate setting has changed
1357 KErrAccessDenied if endpoint is not opened
1358 KErrNotSupported if its an IN endpoint
1359 TEndpointBuffer::KStateChange if the returned data represents a state change (Ep0 only)
1361 IMPORT_C TInt GetBuffer(TAny*& aBuffer,TUint& aSize,TBool& aZLP,TRequestStatus& aStatus,TUint aLength=0);
1364 Read the next block of data from the Shared chunk buffer. This method should be used if the user wishes to process one block of data at a time.
1365 This method also expires the previously read block, meaning that the memory used by the block of data may be re-used by the system, overwriting it
1367 @param aOffset aOffset will point to data offset in shared chunk
1368 @param aSize aSize will hold the number of valid bytes that can be read
1369 @param aZLP aZLP will indicate whether its a short packet or not
1370 @param aStatus In case of no data available to be read, aStatus will be passed on to LDD, and user side should wait for
1371 asynchronous call ReadDataNotify to return
1372 @param aLength Not used at the moment
1373 @return KErrCompletion if operation is successfull and data is available in the buffer
1374 KErrNone if no data is available to be read
1375 KErrEof if alternate setting has changed
1376 KErrAccessDenied if endpoint is not opened
1377 KErrNotSupported if its an IN endpoint
1378 TEndpointBuffer::KStateChange if the returned data represents a state change (Ep0 only)
1380 inline TInt GetBuffer(TUint& aOffset,TUint& aSize,TBool& aZLP,TRequestStatus& aStatus,TUint aLength=0);
1383 Read the next block of data from the Shared chunk buffer. This method should be used if the user wishes to process more than one block of data
1384 simultaneously. The user must call one of the Expire() methods to free the memory used by the block of data, and make it available for new data.
1385 @param aBuffer aBuffer will point to data location in shared chunk
1386 @param aSize aSize will hold the number of valid bytes that can be read
1387 @param aZLP aZLP will indicate whether its a short packet or not
1388 @param aStatus In case of no data available to be read, aStatus will be passed on to LDD, and user side should wait for
1389 asynchronous call ReadDataNotify to return
1390 @param aLength Not used at the moment
1391 @return KErrCompletion if operation is successfull and data is available in the buffer
1392 KErrNone if no data is available to be read
1393 KErrEof if alternate setting has changed
1394 KErrAccessDenied if endpoint is not opened
1395 KErrNotSupported if its an IN endpoint
1396 TEndpointBuffer::KStateChange if the returned data represents a state change (Ep0 only)
1398 IMPORT_C TInt TakeBuffer(TAny*& aBuffer,TUint& aSize,TBool& aZLP,TRequestStatus& aStatus,TUint aLength=0);
1401 Used in conjunction with TakeBuffer method. This will make the 'oldest' block of data previously read out using the TakeBuffer method, but not
1402 already expired, to be released back to the system. This block can then be overwritten with new data, when it becomes available.
1403 @return KErrNotSupported if its an IN endpoint
1404 KErrNone if iTail is successfully bumped to the next transfer to be read
1407 IMPORT_C TInt Expire();
1410 Used in conjunction with TakeBuffer method. This function allows blocks to be expired in a different order from which the user read the data out
1411 of the buffer. Note that the system will only reuse blocks up to the point of the oldest non-expired block read. This means that the user must
1412 ensure to expire all blocks in a timely manner to prevent the system from running out of usable memory.
1413 @param aAddress aAddress is the start address of the block of data previously read by the user which can be overwritten.
1414 @return KErrNotSupported if its an IN endpoint
1415 KErrNone if iTail is successfully bumped to the next transfer to be read
1416 KErrNotFound if a 'transfer' with start address of the data block is aAddress is not found
1419 IMPORT_C TInt Expire(TAny* aAddress);
1422 Initiates write operation.
1423 @param aBuffer aBuffer will point to data in shared chunk to be written out. aBuffer should be aligned
1424 @param aSize aSize will hold the number of valid bytes to be written out
1425 @param aZLP aZLP will indicate whether a ZLP should be transmitted after writing the data out
1426 @param aStatus This is an asynchronous function and user side should wait on status to know the end of write operation
1427 @return KErrNone if a write is successfully queued
1428 KErrEof if an alternate setting change has occurred, ending this endpoint.
1429 KErrNotSupported if its an OUT endpoint
1430 KErrAccessDenied if endpoint is not opened, or if buffer is out of range
1432 IMPORT_C TInt WriteBuffer(TAny* aBuffer,TUint aSize,TBool aZLP,TRequestStatus& aStatus);
1435 Initiates write operation.
1436 @param aOffset aOffset will point to offset of data in shared chunk to be written out.
1437 @param aSize aSize will hold the number of valid bytes to be written out
1438 @param aZLP aZLP will indicate whether a ZLP should be transmitted after writing the data out
1439 @param aStatus This is an asynchronous function and user side should wait on status to know the end of write operation
1440 @return KErrNone if a write is successfully queued
1441 KErrEof if an alternate setting change has occurred, ending this endpoint.
1442 KErrNotSupported if its an OUT endpoint
1443 KErrAccessDenied if endpoint is not opened, or if buffer is out of range
1445 IMPORT_C TInt WriteBuffer(TUint aOffset,TUint aSize,TBool aZLP,TRequestStatus& aStatus);
1447 For IN endpoints, this method retrieves the geometry for the buffer, for which the
1448 caller should stay within, when using the WriteBuffer method.
1450 @param aStart A pointer, which is set to point to the start of the buffer.
1451 @param aSize An TUint for which the size (in bytes) of buffer, is written into.
1453 @returns KErrNotSupported if the object is on an open IN endpoint,
1454 otherwise it KErrNone is returned on success.
1456 IMPORT_C TInt GetInBufferRange(TAny*& aStart, TUint& aSize);
1459 For IN endpoints, this method retrieves the geometry for the buffer, for which the
1460 caller should stay within, when using the WriteBuffer method.
1462 @param aStart A TUint for which the buffer's start offset from the start of the chunk,
1464 @param aSize An TUint for which the size (in bytes) of buffer, is written into.
1466 @returns KErrNotSupported if the object is on an open IN endpoint,
1467 otherwise it KErrNone is returned on success.
1469 IMPORT_C TInt GetInBufferRange(TUint& aStart, TUint& aSize);
1472 This method closes the endpoint, after it was opened with
1473 RDevUsbcScClient::OpenEndpoint(...).
1474 No method of this object can be used after this call, until
1475 RDevUsbcScClient::OpenEndpoint(...) is called on it again.
1477 @return KErrNone on success, otherwise KErrNotFound, if the current object is not open.
1479 IMPORT_C TInt Close();
1481 IMPORT_C void Dump();
1484 Used to retrieve the endpoint number for which this object was open on.
1486 @returns the endpoint number opened by this object.
1488 inline TInt GetEndpointNumber();
1491 /** @internalTechnology */
1492 void Construct(RDevUsbcScClient* aClient, TUint8* aBaseAddr, const TUsbcScHdrEndpointRecord* aEpType,
1493 TInt aEndpointNumber, SUsbcScBufferHeader* aEndpointHdr=NULL);
1496 enum TDir {EValid = KErrNone, ENotValid = KErrNotSupported, EEOF = KErrEof};
1497 TDir iInState; /** @internalTechnology describes state of endpoint, KErrNone if IN endpoint and ready to use, KErrNotSupportd if not an IN endpoint, KErrEof on alternate setting change */
1498 TDir iOutState; /** @internalTechnology describes state of endpoint, KErrNone if OUT endpoint and ready to use, KErrNotSupportd if not an OUT endpoint, KErrEoF on alternate setting change */
1499 TInt iEndpointNumber; /** @internalTechnology associated endpoint number */
1500 TInt iBufferNum; /** @internalTechnology buffer number within shared chunk */
1501 RDevUsbcScClient *iClient; /** @internalTechnology Parent RDevUsbcScClient object */
1502 TUint iBaseAddr; /** @internalTechnology The address of the beginning of the Ldd's chunk */
1504 SUsbcScBufferHeader* iEndpointHdr; /** @internalTechnology Pointer to the buffer Header for OUT/BI endpoints */
1505 TUint8* iBufferStartAddr; /** @internalTechnology IN/BI endpoint buffer start address within shared chunk */
1506 TUint iSize; /** @internalTechnology IN/BI endpoint buffer size within shared chunk */
1507 friend class RDevUsbcScClient;
1511 This class can be used to retrieve the geometry of the structures
1512 within a shared chunk, as used by RDevUsbcScClient.
1514 @see RDevUsbcScClient
1517 class TUsbcScChunkHeader
1521 The constructor for the TUsbcScChunkHeader class takes a RChunk object,
1522 containing USBcSc data structures, and initialises itself, so that
1523 GetNumberOfEndpoints & GetBuffer can be used to interpret the chunk structures.
1525 @param An RChunk object, which represents an shared chunk, containing the
1526 USBcSc data structures to be retrieved.
1528 IMPORT_C TUsbcScChunkHeader(RChunk aChunk);
1530 Retrieves the available information in the chunk, about the given endpoint,
1531 on the given alternate setting. The returned TUsbcScBufferRecord,
1532 represents the buffer geometry, used for for the endpoint, while
1533 the filled in TUsbcScHdrEndpointRecord represents additional endpoint
1536 @param aAltSetting The alternate setting, for which the provided endpoint number, is a member of.
1537 @param aEndpoint The endpoint, who's buffer geometry is required.
1538 @param aEndpointInf The provided record is filled in with details of the endpoint, who's number was given.
1540 IMPORT_C TUsbcScBufferRecord* GetBuffer(TInt aAltSetting, TInt aEndpoint, TUsbcScHdrEndpointRecord*& aEndpointInf);
1542 Retrieves the number of endpoints found in a given alternate setting.
1543 @param aAltSetting The alternate setting number, for which the number of endpoints contained within, is needed.
1545 IMPORT_C TInt GetNumberOfEndpoints(TInt aAltSetting);
1548 TUsbcScChunkBuffersHeader* iBuffers; /** A pointer to the TUsbcScChunkBuffersHeader object, within the chunk header */
1549 TUsbcScChunkAltSettingHeader* iAltSettings; /** A pointer to the TUsbcScChunkAltSettingHeader object, within the chunk header */
1556 #include <d32usbcsc.inl>
1558 #endif // __D32USBCSC_H__