usbdrv/peripheral/public/d32usbc.h
author hgs
Wed, 03 Nov 2010 10:49:35 +0800
changeset 63 705964cc7132
parent 59 bbdce6bffaad
permissions -rw-r--r--
201043_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
59
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     1
/*
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     3
* All rights reserved.
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     4
* This component and the accompanying materials are made available
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     6
* which accompanies this distribution, and is available
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     8
*
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
     9
* Initial Contributors:
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    10
* Nokia Corporation - initial contribution.
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    11
*
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    12
* Contributors:
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    13
*
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    14
* Description:
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    15
* e32/include/d32usbc.h
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    16
* User side class definitions for USB Device support.
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    17
*
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    18
*/
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
    19
089413cdde3c 201028_02
hgs
parents:
diff changeset
    20
/**
089413cdde3c 201028_02
hgs
parents:
diff changeset
    21
 @file d32usbc.h
089413cdde3c 201028_02
hgs
parents:
diff changeset
    22
 @publishedPartner
089413cdde3c 201028_02
hgs
parents:
diff changeset
    23
 @released
089413cdde3c 201028_02
hgs
parents:
diff changeset
    24
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    25
089413cdde3c 201028_02
hgs
parents:
diff changeset
    26
#ifndef __D32USBC_H__
089413cdde3c 201028_02
hgs
parents:
diff changeset
    27
#define __D32USBC_H__
089413cdde3c 201028_02
hgs
parents:
diff changeset
    28
089413cdde3c 201028_02
hgs
parents:
diff changeset
    29
#include <e32ver.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    30
#include <usb/usb.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    31
#include <usb/d32usbcshared.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    32
089413cdde3c 201028_02
hgs
parents:
diff changeset
    33
089413cdde3c 201028_02
hgs
parents:
diff changeset
    34
089413cdde3c 201028_02
hgs
parents:
diff changeset
    35
/** @internalComponent
089413cdde3c 201028_02
hgs
parents:
diff changeset
    36
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    37
enum TTransferType
089413cdde3c 201028_02
hgs
parents:
diff changeset
    38
	{
089413cdde3c 201028_02
hgs
parents:
diff changeset
    39
	ETransferTypeReadData,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    40
	ETransferTypeReadPacket,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    41
	ETransferTypeWrite,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    42
	ETransferTypeNone,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    43
	ETransferTypeReadOneOrMore,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    44
	ETransferTypeReadUntilShort
089413cdde3c 201028_02
hgs
parents:
diff changeset
    45
	};
089413cdde3c 201028_02
hgs
parents:
diff changeset
    46
089413cdde3c 201028_02
hgs
parents:
diff changeset
    47
089413cdde3c 201028_02
hgs
parents:
diff changeset
    48
/** Available endpoints. At most only these are available per interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    49
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    50
enum TEndpointNumber
089413cdde3c 201028_02
hgs
parents:
diff changeset
    51
	{
089413cdde3c 201028_02
hgs
parents:
diff changeset
    52
	EEndpoint0 = 0,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    53
	EEndpoint1 = 1,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    54
	EEndpoint2 = 2,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    55
	EEndpoint3 = 3,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    56
	EEndpoint4 = 4,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    57
	EEndpoint5 = 5
089413cdde3c 201028_02
hgs
parents:
diff changeset
    58
	};
089413cdde3c 201028_02
hgs
parents:
diff changeset
    59
089413cdde3c 201028_02
hgs
parents:
diff changeset
    60
089413cdde3c 201028_02
hgs
parents:
diff changeset
    61
089413cdde3c 201028_02
hgs
parents:
diff changeset
    62
089413cdde3c 201028_02
hgs
parents:
diff changeset
    63
/** Bandwidth indicators for an Interface
089413cdde3c 201028_02
hgs
parents:
diff changeset
    64
089413cdde3c 201028_02
hgs
parents:
diff changeset
    65
	@see RDevUsbcClient::SetInterface()
089413cdde3c 201028_02
hgs
parents:
diff changeset
    66
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    67
enum TUsbcBandwidthPriority
089413cdde3c 201028_02
hgs
parents:
diff changeset
    68
	{
089413cdde3c 201028_02
hgs
parents:
diff changeset
    69
	/** Economical OUT buffering. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    70
	EUsbcBandwidthOUTDefault = 0x00,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    71
	/** More memory than Default for OUT buffering. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    72
	EUsbcBandwidthOUTPlus1   = 0x01,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    73
	/** More memory than Plus1 for OUT buffering. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    74
	EUsbcBandwidthOUTPlus2   = 0x02,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    75
	/** Maximum memory for OUT buffering.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    76
		Use this value for high volume USB High-speed
089413cdde3c 201028_02
hgs
parents:
diff changeset
    77
		data transfers only, otherwise memory will be wasted.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    78
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    79
	EUsbcBandwidthOUTMaximum = 0x03,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    80
	//
089413cdde3c 201028_02
hgs
parents:
diff changeset
    81
	/** Economical IN buffering */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    82
	EUsbcBandwidthINDefault  = 0x00,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    83
	/** More memory than Default for IN buffering */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    84
	EUsbcBandwidthINPlus1    = 0x10,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    85
	/** More memory than Plus1 for IN buffering */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    86
	EUsbcBandwidthINPlus2    = 0x20,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    87
	/** Maximum memory for IN buffering.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    88
		Use this value for high volume USB High-speed
089413cdde3c 201028_02
hgs
parents:
diff changeset
    89
		data transfers only, otherwise memory will be wasted.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    90
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    91
	EUsbcBandwidthINMaximum  = 0x30
089413cdde3c 201028_02
hgs
parents:
diff changeset
    92
	};
089413cdde3c 201028_02
hgs
parents:
diff changeset
    93
089413cdde3c 201028_02
hgs
parents:
diff changeset
    94
089413cdde3c 201028_02
hgs
parents:
diff changeset
    95
089413cdde3c 201028_02
hgs
parents:
diff changeset
    96
089413cdde3c 201028_02
hgs
parents:
diff changeset
    97
089413cdde3c 201028_02
hgs
parents:
diff changeset
    98
089413cdde3c 201028_02
hgs
parents:
diff changeset
    99
089413cdde3c 201028_02
hgs
parents:
diff changeset
   100
/** Bit positions of endpoints.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   101
089413cdde3c 201028_02
hgs
parents:
diff changeset
   102
	@see RDevUsbcClient::EndpointStatusNotify()
089413cdde3c 201028_02
hgs
parents:
diff changeset
   103
	@see RDevUsbcClient::EndpointTransferCancel()
089413cdde3c 201028_02
hgs
parents:
diff changeset
   104
089413cdde3c 201028_02
hgs
parents:
diff changeset
   105
	Bit position of endpoint0.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   106
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   107
const TUint KUsbcEndpoint0Bit = 1<<EEndpoint0;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   108
/** Bit position of endpoint1.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   109
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   110
const TUint KUsbcEndpoint1Bit = 1<<EEndpoint1;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   111
/** Bit position of endpoint2.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   112
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   113
const TUint KUsbcEndpoint2Bit = 1<<EEndpoint2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   114
/** Bit position of endpoint3.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   115
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   116
const TUint KUsbcEndpoint3Bit = 1<<EEndpoint3;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   117
/** Bit position of endpoint4.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   118
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   119
const TUint KUsbcEndpoint4Bit = 1<<EEndpoint4;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   120
/** Bit position of endpoint5.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   121
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   122
const TUint KUsbcEndpoint5Bit = 1<<EEndpoint5;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   123
089413cdde3c 201028_02
hgs
parents:
diff changeset
   124
089413cdde3c 201028_02
hgs
parents:
diff changeset
   125
089413cdde3c 201028_02
hgs
parents:
diff changeset
   126
089413cdde3c 201028_02
hgs
parents:
diff changeset
   127
089413cdde3c 201028_02
hgs
parents:
diff changeset
   128
089413cdde3c 201028_02
hgs
parents:
diff changeset
   129
089413cdde3c 201028_02
hgs
parents:
diff changeset
   130
089413cdde3c 201028_02
hgs
parents:
diff changeset
   131
/** This must be filled in prior to a call to RDevUsbcClient::SetInterface().
089413cdde3c 201028_02
hgs
parents:
diff changeset
   132
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   133
class TUsbcInterfaceInfo
089413cdde3c 201028_02
hgs
parents:
diff changeset
   134
	{
089413cdde3c 201028_02
hgs
parents:
diff changeset
   135
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   136
	TUsbcInterfaceInfo(TInt aClass=0, TInt aSubClass=0, TInt aProtocol=0,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   137
					   TDesC16* aString=NULL, TUint aTotalEndpoints=0);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   138
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   139
	/** The class, subclass and protocol that this interface supports. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   140
	TUsbcClassInfo iClass;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   141
	/** The description string for the interface. Used to construct the interface string descriptor. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   142
	const TDesC16* iString;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   143
	/** Total number of endpoints being requested (0-5). Endpoint 0 should not be included in this number. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   144
	TUint iTotalEndpointsUsed;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   145
	/** Desired properties of the endpoints requested.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   146
		Do NOT include endpoint 0.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   147
		APIs use endpoint numbers that are offsets into this array.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   148
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   149
	TUsbcEndpointInfo iEndpointData[KMaxEndpointsPerClient];
089413cdde3c 201028_02
hgs
parents:
diff changeset
   150
	/** 32 flag bits used for specifying miscellaneous Interface features.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   151
		Currently defined are:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   152
		- KUsbcInterfaceInfo_NoEp0RequestsPlease = 0x00000001
089413cdde3c 201028_02
hgs
parents:
diff changeset
   153
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   154
	TUint32 iFeatureWord;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   155
	};
089413cdde3c 201028_02
hgs
parents:
diff changeset
   156
089413cdde3c 201028_02
hgs
parents:
diff changeset
   157
089413cdde3c 201028_02
hgs
parents:
diff changeset
   158
/** Package buffer for a TUsbcInterfaceInfo object.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   159
089413cdde3c 201028_02
hgs
parents:
diff changeset
   160
	@see TUsbcInterfaceInfo
089413cdde3c 201028_02
hgs
parents:
diff changeset
   161
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   162
typedef TPckgBuf<TUsbcInterfaceInfo> TUsbcInterfaceInfoBuf;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   163
089413cdde3c 201028_02
hgs
parents:
diff changeset
   164
089413cdde3c 201028_02
hgs
parents:
diff changeset
   165
/** The user side handle to the USB client driver.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   166
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   167
class RDevUsbcClient : public RBusLogicalChannel
089413cdde3c 201028_02
hgs
parents:
diff changeset
   168
	{
089413cdde3c 201028_02
hgs
parents:
diff changeset
   169
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   170
	/** @internalComponent */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   171
	enum TVer
089413cdde3c 201028_02
hgs
parents:
diff changeset
   172
		{
089413cdde3c 201028_02
hgs
parents:
diff changeset
   173
		EMajorVersionNumber = 0,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   174
		EMinorVersionNumber = 1,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   175
		EBuildVersionNumber = KE32BuildVersionNumber
089413cdde3c 201028_02
hgs
parents:
diff changeset
   176
		};
089413cdde3c 201028_02
hgs
parents:
diff changeset
   177
089413cdde3c 201028_02
hgs
parents:
diff changeset
   178
	enum TRequest
089413cdde3c 201028_02
hgs
parents:
diff changeset
   179
		{
089413cdde3c 201028_02
hgs
parents:
diff changeset
   180
		// Positive requests.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   181
		ERequestEp0 = 0x0,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   182
		ERequestEp1 = EEndpoint1,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   183
		ERequestEp2 = EEndpoint2,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   184
		ERequestEp3 = EEndpoint3,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   185
		ERequestEp4 = EEndpoint4,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   186
		ERequestEp5 = EEndpoint5,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   187
		ERequestUnused = 6,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   188
		ERequestAlternateDeviceStatusNotify = 7,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   189
		ERequestReEnumerate = 8,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   190
		ERequestEndpointStatusNotify = 9,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   191
		// The cancel TRequest's are interpreted as bitmaps. As they're not mixed
089413cdde3c 201028_02
hgs
parents:
diff changeset
   192
		// with the previous ones, it doesn't matter if they have the same absolute
089413cdde3c 201028_02
hgs
parents:
diff changeset
   193
		// value as those.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   194
		ERequestEp0Cancel = 1<<ERequestEp0,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   195
		ERequestEp1Cancel = 1<<ERequestEp1,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   196
		ERequestEp2Cancel = 1<<ERequestEp2,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   197
		ERequestEp3Cancel = 1<<ERequestEp3,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   198
		ERequestEp4Cancel = 1<<ERequestEp4,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   199
		ERequestEp5Cancel = 1<<ERequestEp5,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   200
		ERequestUnusedCancel = 1<<ERequestUnused,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   201
        ERequestAllCancel = (ERequestEp0Cancel | ERequestEp1Cancel |
089413cdde3c 201028_02
hgs
parents:
diff changeset
   202
							 ERequestEp2Cancel | ERequestEp3Cancel |
089413cdde3c 201028_02
hgs
parents:
diff changeset
   203
							 ERequestEp4Cancel | ERequestEp5Cancel |
089413cdde3c 201028_02
hgs
parents:
diff changeset
   204
							 ERequestUnusedCancel),
089413cdde3c 201028_02
hgs
parents:
diff changeset
   205
		ERequestAlternateDeviceStatusNotifyCancel = 1<<ERequestAlternateDeviceStatusNotify,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   206
		ERequestReEnumerateCancel = 1<<ERequestReEnumerate,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   207
		ERequestEndpointStatusNotifyCancel = 1<<ERequestEndpointStatusNotify,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   208
        ERequestOtgFeaturesNotify = 10,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   209
        ERequestOtgFeaturesNotifyCancel = 1<<ERequestOtgFeaturesNotify,
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   210
        ERequestChargingPortTypeNotify = 11,
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   211
        ERequestChargingPortTypeNotifyCancel = 1<<ERequestChargingPortTypeNotify
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
   212
		};
089413cdde3c 201028_02
hgs
parents:
diff changeset
   213
089413cdde3c 201028_02
hgs
parents:
diff changeset
   214
	enum TControl
089413cdde3c 201028_02
hgs
parents:
diff changeset
   215
		{
089413cdde3c 201028_02
hgs
parents:
diff changeset
   216
		// Changing the order of these enums will break BC.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   217
		EControlEndpointZeroRequestError,					// 0
089413cdde3c 201028_02
hgs
parents:
diff changeset
   218
		EControlEndpointCaps,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   219
		EControlDeviceCaps,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   220
		EControlGetAlternateSetting,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   221
		EControlDeviceStatus,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   222
		EControlEndpointStatus,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   223
		EControlSetInterface,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   224
		EControlReleaseInterface,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   225
		EControlQueryReceiveBuffer,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   226
		EControlSendEp0StatusPacket,						// 9
089413cdde3c 201028_02
hgs
parents:
diff changeset
   227
		//
089413cdde3c 201028_02
hgs
parents:
diff changeset
   228
		EControlHaltEndpoint,								// 10
089413cdde3c 201028_02
hgs
parents:
diff changeset
   229
		EControlClearHaltEndpoint,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   230
		EControlSetDeviceControl,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   231
		EControlReleaseDeviceControl,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   232
		EControlEndpointZeroMaxPacketSizes,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   233
		EControlSetEndpointZeroMaxPacketSize,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   234
		EControlGetDeviceDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   235
		EControlSetDeviceDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   236
		EControlGetDeviceDescriptorSize,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   237
		EControlGetConfigurationDescriptor,					// 19
089413cdde3c 201028_02
hgs
parents:
diff changeset
   238
		//
089413cdde3c 201028_02
hgs
parents:
diff changeset
   239
		EControlSetConfigurationDescriptor,					// 20
089413cdde3c 201028_02
hgs
parents:
diff changeset
   240
		EControlGetConfigurationDescriptorSize,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   241
		EControlGetInterfaceDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   242
		EControlSetInterfaceDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   243
		EControlGetInterfaceDescriptorSize,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   244
		EControlGetEndpointDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   245
		EControlSetEndpointDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   246
		EControlGetEndpointDescriptorSize,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   247
		EControlGetCSInterfaceDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   248
		EControlSetCSInterfaceDescriptor,					// 29
089413cdde3c 201028_02
hgs
parents:
diff changeset
   249
		//
089413cdde3c 201028_02
hgs
parents:
diff changeset
   250
		EControlGetCSInterfaceDescriptorSize,				// 30
089413cdde3c 201028_02
hgs
parents:
diff changeset
   251
		EControlGetCSEndpointDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   252
		EControlSetCSEndpointDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   253
		EControlGetCSEndpointDescriptorSize,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   254
		EControlSignalRemoteWakeup,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   255
		EControlGetStringDescriptorLangId,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   256
		EControlSetStringDescriptorLangId,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   257
		EControlGetManufacturerStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   258
		EControlSetManufacturerStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   259
		EControlRemoveManufacturerStringDescriptor,			// 39
089413cdde3c 201028_02
hgs
parents:
diff changeset
   260
		//
089413cdde3c 201028_02
hgs
parents:
diff changeset
   261
		EControlGetProductStringDescriptor,					// 40
089413cdde3c 201028_02
hgs
parents:
diff changeset
   262
		EControlSetProductStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   263
		EControlRemoveProductStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   264
		EControlGetSerialNumberStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   265
		EControlSetSerialNumberStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   266
		EControlRemoveSerialNumberStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   267
		EControlGetConfigurationStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   268
		EControlSetConfigurationStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   269
		EControlRemoveConfigurationStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   270
		EControlDeviceDisconnectFromHost,					// 49
089413cdde3c 201028_02
hgs
parents:
diff changeset
   271
		//
089413cdde3c 201028_02
hgs
parents:
diff changeset
   272
		EControlDeviceConnectToHost,						// 50
089413cdde3c 201028_02
hgs
parents:
diff changeset
   273
		EControlDevicePowerUpUdc,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   274
		EControlDumpRegisters,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   275
		EControlSetInterface1,								// (not used)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   276
		EControlAllocateEndpointResource,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   277
		EControlDeAllocateEndpointResource,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   278
		EControlQueryEndpointResourceUse,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   279
		EControlGetEndpointZeroMaxPacketSize,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   280
		EControlGetDeviceQualifierDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   281
		EControlSetDeviceQualifierDescriptor,				// 59
089413cdde3c 201028_02
hgs
parents:
diff changeset
   282
		//
089413cdde3c 201028_02
hgs
parents:
diff changeset
   283
		EControlGetOtherSpeedConfigurationDescriptor,		// 60
089413cdde3c 201028_02
hgs
parents:
diff changeset
   284
		EControlSetOtherSpeedConfigurationDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   285
		EControlCurrentlyUsingHighSpeed,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   286
		EControlSetStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   287
		EControlGetStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   288
		EControlRemoveStringDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   289
        EControlSetOtgDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   290
        EControlGetOtgDescriptor,
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   291
        EControlGetOtgFeatures,
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   292
        EControlGetChargerDetectorCaps
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
   293
		};
089413cdde3c 201028_02
hgs
parents:
diff changeset
   294
089413cdde3c 201028_02
hgs
parents:
diff changeset
   295
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   296
089413cdde3c 201028_02
hgs
parents:
diff changeset
   297
#ifndef __KERNEL_MODE__
089413cdde3c 201028_02
hgs
parents:
diff changeset
   298
089413cdde3c 201028_02
hgs
parents:
diff changeset
   299
	/** Opens a channel.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   300
089413cdde3c 201028_02
hgs
parents:
diff changeset
   301
		@param aUnit This should be 0 (zero).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   302
089413cdde3c 201028_02
hgs
parents:
diff changeset
   303
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   304
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   305
	inline TInt Open(TInt aUnit);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   306
089413cdde3c 201028_02
hgs
parents:
diff changeset
   307
	inline TVersion VersionRequired() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   308
089413cdde3c 201028_02
hgs
parents:
diff changeset
   309
	/** Stalls ep0 to signal command fault to the host.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   310
089413cdde3c 201028_02
hgs
parents:
diff changeset
   311
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   312
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   313
	inline TInt EndpointZeroRequestError();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   314
089413cdde3c 201028_02
hgs
parents:
diff changeset
   315
	/** Retrieves the capabilities of all the endpoints on the device.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   316
089413cdde3c 201028_02
hgs
parents:
diff changeset
   317
		Suggested use is as follows:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   318
089413cdde3c 201028_02
hgs
parents:
diff changeset
   319
		@code
089413cdde3c 201028_02
hgs
parents:
diff changeset
   320
		TUsbcEndpointData data[KUsbcMaxEndpoints];
089413cdde3c 201028_02
hgs
parents:
diff changeset
   321
		TPtr8 dataPtr(reinterpret_cast<TUint8*>(data), sizeof(data), sizeof(data));
089413cdde3c 201028_02
hgs
parents:
diff changeset
   322
		ret = usbPort.EndpointCaps(dataPtr);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   323
		@endcode
089413cdde3c 201028_02
hgs
parents:
diff changeset
   324
089413cdde3c 201028_02
hgs
parents:
diff changeset
   325
		@param aEpCapsBuf a descriptor encapsulating an array of TUsbcEndpointData.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   326
089413cdde3c 201028_02
hgs
parents:
diff changeset
   327
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   328
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   329
	inline TInt EndpointCaps(TDes8& aEpCapsBuf);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   330
089413cdde3c 201028_02
hgs
parents:
diff changeset
   331
	/** Retrieves the capabilities of the USB device.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   332
089413cdde3c 201028_02
hgs
parents:
diff changeset
   333
		@see TUsbDeviceCaps
089413cdde3c 201028_02
hgs
parents:
diff changeset
   334
089413cdde3c 201028_02
hgs
parents:
diff changeset
   335
		@param aDevCapsBuf a TUsbDeviceCaps object.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   336
089413cdde3c 201028_02
hgs
parents:
diff changeset
   337
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   338
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   339
	inline TInt DeviceCaps(TUsbDeviceCaps& aDevCapsBuf);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   340
089413cdde3c 201028_02
hgs
parents:
diff changeset
   341
	/** Copies the current alternate setting for this interface into aInterfaceNumber
089413cdde3c 201028_02
hgs
parents:
diff changeset
   342
		For USB Interfaces whose main interface is active, this will be 0 (zero).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   343
089413cdde3c 201028_02
hgs
parents:
diff changeset
   344
		@param aInterfaceNumber current alternate setting for this interface is copied into this.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   345
089413cdde3c 201028_02
hgs
parents:
diff changeset
   346
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   347
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   348
	inline TInt GetAlternateSetting(TInt& aInterfaceNumber);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   349
089413cdde3c 201028_02
hgs
parents:
diff changeset
   350
	/** Copies the current device status into aDeviceStatus.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   351
089413cdde3c 201028_02
hgs
parents:
diff changeset
   352
		@param aDeviceStatus current device status is copied into this.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   353
089413cdde3c 201028_02
hgs
parents:
diff changeset
   354
		@return KErrNone if successful
089413cdde3c 201028_02
hgs
parents:
diff changeset
   355
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   356
	inline TInt DeviceStatus(TUsbcDeviceState& aDeviceStatus);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   357
089413cdde3c 201028_02
hgs
parents:
diff changeset
   358
	/** Copies the current endpoint status into aEndpointStatus.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   359
089413cdde3c 201028_02
hgs
parents:
diff changeset
   360
		@param aEndpoint endpoint number valid for the current alternate setting.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   361
		@param aEndpointStatus the current endpoint status, might be stalled, not stalled or unknown.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   362
089413cdde3c 201028_02
hgs
parents:
diff changeset
   363
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   364
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   365
	inline TInt EndpointStatus(TEndpointNumber aEndpoint, TEndpointState& aEndpointStatus);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   366
089413cdde3c 201028_02
hgs
parents:
diff changeset
   367
	/** Copies the number of bytes available in the aEndpoint read buffer into aNumberOfBytes.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   368
089413cdde3c 201028_02
hgs
parents:
diff changeset
   369
		@param aEndpoint endpoint number valid for the current alternate setting.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   370
		@param aNumberOfBytes number of bytes available in the aEndpoint read buffer.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   371
089413cdde3c 201028_02
hgs
parents:
diff changeset
   372
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   373
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   374
	inline TInt QueryReceiveBuffer(TEndpointNumber aEndpoint, TInt& aNumberOfBytes);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   375
089413cdde3c 201028_02
hgs
parents:
diff changeset
   376
	/** Requests that a zero length status packet be sent to the host in response
089413cdde3c 201028_02
hgs
parents:
diff changeset
   377
		to a class or vendor specific ep0 SETUP packet.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   378
089413cdde3c 201028_02
hgs
parents:
diff changeset
   379
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   380
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   381
	inline TInt SendEp0StatusPacket();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   382
089413cdde3c 201028_02
hgs
parents:
diff changeset
   383
	/** Stalls endpoint aEndpoint, usually to indicate an error condition with a previous command.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   384
		The host will normally send a SET_FEATURE command on ep0 to acknowledge and clear the stall.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   385
089413cdde3c 201028_02
hgs
parents:
diff changeset
   386
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   387
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   388
	inline TInt HaltEndpoint(TEndpointNumber aEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   389
089413cdde3c 201028_02
hgs
parents:
diff changeset
   390
	/** Clears the stall condition on endpoint aEndpoint. This is inluded for symmetry and test purposes.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   391
089413cdde3c 201028_02
hgs
parents:
diff changeset
   392
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   393
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   394
	inline TInt ClearHaltEndpoint(TEndpointNumber aEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   395
089413cdde3c 201028_02
hgs
parents:
diff changeset
   396
	/** Requests that device control be allocated to this channel.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   397
089413cdde3c 201028_02
hgs
parents:
diff changeset
   398
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   399
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   400
	inline TInt SetDeviceControl();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   401
089413cdde3c 201028_02
hgs
parents:
diff changeset
   402
	/** Relinquishes device control previously allocated to this channel.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   403
089413cdde3c 201028_02
hgs
parents:
diff changeset
   404
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   405
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   406
	inline TInt ReleaseDeviceControl();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   407
089413cdde3c 201028_02
hgs
parents:
diff changeset
   408
	/** Returns a bitmap of available ep0 maximum packet sizes.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   409
089413cdde3c 201028_02
hgs
parents:
diff changeset
   410
		@return bitmap of available ep0 maximum packet sizes.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   411
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   412
	inline TUint EndpointZeroMaxPacketSizes();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   413
089413cdde3c 201028_02
hgs
parents:
diff changeset
   414
	/** Requests that a maximum packet size of aMaxPacketSize be set on ep0.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   415
089413cdde3c 201028_02
hgs
parents:
diff changeset
   416
		@param aMaxPacketSize The maximum packet size.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   417
089413cdde3c 201028_02
hgs
parents:
diff changeset
   418
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   419
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   420
	inline TInt SetEndpointZeroMaxPacketSize(TInt aMaxPacketSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   421
089413cdde3c 201028_02
hgs
parents:
diff changeset
   422
	/** Queries the current maximum packet size on ep0.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   423
089413cdde3c 201028_02
hgs
parents:
diff changeset
   424
		@return The currently set maximum packet size on ep0.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   425
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   426
	inline TInt GetEndpointZeroMaxPacketSize();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   427
089413cdde3c 201028_02
hgs
parents:
diff changeset
   428
	/** Copies the current device descriptor into aDeviceDescriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   429
089413cdde3c 201028_02
hgs
parents:
diff changeset
   430
		@param aDeviceDescriptor Receives the current device descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   431
089413cdde3c 201028_02
hgs
parents:
diff changeset
   432
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   433
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   434
	inline TInt GetDeviceDescriptor(TDes8& aDeviceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   435
089413cdde3c 201028_02
hgs
parents:
diff changeset
   436
	/** Sets the contents of aDeviceDescriptor to be the current device descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   437
089413cdde3c 201028_02
hgs
parents:
diff changeset
   438
		@param aDeviceDescriptor contains the device descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   439
089413cdde3c 201028_02
hgs
parents:
diff changeset
   440
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   441
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   442
	inline TInt SetDeviceDescriptor(const TDesC8& aDeviceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   443
089413cdde3c 201028_02
hgs
parents:
diff changeset
   444
	/** Gets the size of the current device descriptor. This is unlikely to be anything other than 9.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   445
089413cdde3c 201028_02
hgs
parents:
diff changeset
   446
		@param aSize receives the size of the current device descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   447
089413cdde3c 201028_02
hgs
parents:
diff changeset
   448
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   449
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   450
	inline TInt GetDeviceDescriptorSize(TInt& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   451
089413cdde3c 201028_02
hgs
parents:
diff changeset
   452
	/** Copies the current configuration descriptor into aConfigurationDescriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   453
089413cdde3c 201028_02
hgs
parents:
diff changeset
   454
		@param aConfigurationDescriptor Receives the current configuration descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   455
089413cdde3c 201028_02
hgs
parents:
diff changeset
   456
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   457
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   458
	inline TInt GetConfigurationDescriptor(TDes8& aConfigurationDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   459
089413cdde3c 201028_02
hgs
parents:
diff changeset
   460
	/** Sets the contents of aConfigurationDescriptor to be the current configuration descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   461
089413cdde3c 201028_02
hgs
parents:
diff changeset
   462
		@param aConfigurationDescriptor contains the configuration descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   463
089413cdde3c 201028_02
hgs
parents:
diff changeset
   464
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   465
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   466
	inline TInt SetConfigurationDescriptor(const TDesC8& aConfigurationDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   467
089413cdde3c 201028_02
hgs
parents:
diff changeset
   468
	/** Gets the size of the current configuration descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   469
089413cdde3c 201028_02
hgs
parents:
diff changeset
   470
		@param aSize receives the size of the current configuration descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   471
089413cdde3c 201028_02
hgs
parents:
diff changeset
   472
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   473
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   474
	inline TInt GetConfigurationDescriptorSize(TInt& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   475
089413cdde3c 201028_02
hgs
parents:
diff changeset
   476
	/** Copies the interface descriptor into aInterfaceDescriptor for the interface with alternate
089413cdde3c 201028_02
hgs
parents:
diff changeset
   477
		setting aSettingNumber, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   478
089413cdde3c 201028_02
hgs
parents:
diff changeset
   479
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   480
		@param aInterfaceDescriptor Receives the interface descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   481
089413cdde3c 201028_02
hgs
parents:
diff changeset
   482
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   483
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   484
	inline TInt GetInterfaceDescriptor(TInt aSettingNumber, TDes8& aInterfaceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   485
089413cdde3c 201028_02
hgs
parents:
diff changeset
   486
	/** Sets the interface descriptor contained in aInterfaceDescriptor for the interface with
089413cdde3c 201028_02
hgs
parents:
diff changeset
   487
		alternate setting aSettingNumber, 0 for the main interface, for transmission to the host
089413cdde3c 201028_02
hgs
parents:
diff changeset
   488
		during enumeration.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   489
089413cdde3c 201028_02
hgs
parents:
diff changeset
   490
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   491
		@param aInterfaceDescriptor Contains the interface descriptor to be set.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   492
089413cdde3c 201028_02
hgs
parents:
diff changeset
   493
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   494
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   495
	inline TInt SetInterfaceDescriptor(TInt aSettingNumber, const TDesC8& aInterfaceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   496
089413cdde3c 201028_02
hgs
parents:
diff changeset
   497
	/** Copies the size of the interface descriptor for the interface with alternate
089413cdde3c 201028_02
hgs
parents:
diff changeset
   498
		setting aSettingNumber, 0 for the main interface, into aSize.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   499
089413cdde3c 201028_02
hgs
parents:
diff changeset
   500
		@param aSettingNumber The alternate setting.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   501
		@param aSize receives the size of the interface descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   502
089413cdde3c 201028_02
hgs
parents:
diff changeset
   503
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   504
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   505
	inline TInt GetInterfaceDescriptorSize(TInt aSettingNumber, TInt& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   506
089413cdde3c 201028_02
hgs
parents:
diff changeset
   507
	/** Copies the endpoint descriptor for logical endpoint number aEndpointNumber into aEndpointDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   508
		for the interface with alternate setting aSettingNumber, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   509
089413cdde3c 201028_02
hgs
parents:
diff changeset
   510
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   511
		@param aEndpointNumber.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   512
		@param aEndpointDescriptor Receives the endpoint descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   513
089413cdde3c 201028_02
hgs
parents:
diff changeset
   514
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   515
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   516
	inline TInt GetEndpointDescriptor(TInt aSettingNumber, TInt aEndpointNumber, TDes8& aEndpointDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   517
089413cdde3c 201028_02
hgs
parents:
diff changeset
   518
	/** Sets the endpoint descriptor for logical endpoint number aEndpointNumber contained in
089413cdde3c 201028_02
hgs
parents:
diff changeset
   519
		aEndpointDescriptor for the interface with alternate setting aSettingNumber, 0 for the main interface,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   520
		for transmission to the host during enumeration.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   521
089413cdde3c 201028_02
hgs
parents:
diff changeset
   522
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   523
		@param aEndpointNumber Valid endpoint number on this interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   524
		@param aEndpointDescriptor Contains the endpoint descriptor to be set.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   525
089413cdde3c 201028_02
hgs
parents:
diff changeset
   526
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   527
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   528
	inline TInt SetEndpointDescriptor(TInt aSettingNumber, TInt aEndpointNumber,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   529
									  const TDesC8& aEndpointDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   530
089413cdde3c 201028_02
hgs
parents:
diff changeset
   531
	/** Copies the size of the endpoint descriptor for logical endpoint number aEndpointNumber for the
089413cdde3c 201028_02
hgs
parents:
diff changeset
   532
		interface with alternate setting aSettingNumber, 0 for the main interface, into aSize.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   533
089413cdde3c 201028_02
hgs
parents:
diff changeset
   534
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   535
		@param aEndpointNumber Valid endpoint number on this interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   536
		@param aSize receives the size of the endpoint descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   537
089413cdde3c 201028_02
hgs
parents:
diff changeset
   538
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   539
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   540
	inline TInt GetEndpointDescriptorSize(TInt aSettingNumber, TInt aEndpointNumber, TInt& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   541
089413cdde3c 201028_02
hgs
parents:
diff changeset
   542
    /** Get OTG descriptor size
089413cdde3c 201028_02
hgs
parents:
diff changeset
   543
089413cdde3c 201028_02
hgs
parents:
diff changeset
   544
		@param aSize TInt reference which contains OTG descriptor size on return
089413cdde3c 201028_02
hgs
parents:
diff changeset
   545
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   546
    inline void GetOtgDescriptorSize(TInt& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   547
089413cdde3c 201028_02
hgs
parents:
diff changeset
   548
    /** Get OTG descriptor of USB on-the-go feature
089413cdde3c 201028_02
hgs
parents:
diff changeset
   549
089413cdde3c 201028_02
hgs
parents:
diff changeset
   550
		@param aOtgDesc User-side buffer to store copy of descriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   551
089413cdde3c 201028_02
hgs
parents:
diff changeset
   552
		@return KErrNone if successful
089413cdde3c 201028_02
hgs
parents:
diff changeset
   553
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   554
    inline TInt GetOtgDescriptor(TDes8& aOtgDesc);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   555
089413cdde3c 201028_02
hgs
parents:
diff changeset
   556
    /** Set OTG descriptor by user to enable/disable USB on-the-go feature
089413cdde3c 201028_02
hgs
parents:
diff changeset
   557
089413cdde3c 201028_02
hgs
parents:
diff changeset
   558
		@param aOtgDesc Descriptor buffer containing OTG features
089413cdde3c 201028_02
hgs
parents:
diff changeset
   559
089413cdde3c 201028_02
hgs
parents:
diff changeset
   560
		@return KErrNone if successful
089413cdde3c 201028_02
hgs
parents:
diff changeset
   561
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   562
    inline TInt SetOtgDescriptor(const TDesC8& aOtgDesc);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   563
089413cdde3c 201028_02
hgs
parents:
diff changeset
   564
	/** Copies the current device_qualifier descriptor into aDescriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   565
089413cdde3c 201028_02
hgs
parents:
diff changeset
   566
		@param aDescriptor Receives the current device_qualifier descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   567
089413cdde3c 201028_02
hgs
parents:
diff changeset
   568
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   569
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   570
	inline TInt GetDeviceQualifierDescriptor(TDes8& aDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   571
089413cdde3c 201028_02
hgs
parents:
diff changeset
   572
	/** Sets the device_qualifier descriptor to the contents of aDescriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   573
089413cdde3c 201028_02
hgs
parents:
diff changeset
   574
		@param aDescriptor contains the new device_qualifier descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   575
089413cdde3c 201028_02
hgs
parents:
diff changeset
   576
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   577
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   578
	inline TInt SetDeviceQualifierDescriptor(const TDesC8& aDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   579
089413cdde3c 201028_02
hgs
parents:
diff changeset
   580
	/** Copies the current other_speed_configuration descriptor into aDescriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   581
089413cdde3c 201028_02
hgs
parents:
diff changeset
   582
		@param aDescriptor Receives the current other_speed_configuration descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   583
089413cdde3c 201028_02
hgs
parents:
diff changeset
   584
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   585
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   586
	inline TInt GetOtherSpeedConfigurationDescriptor(TDes8& aDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   587
089413cdde3c 201028_02
hgs
parents:
diff changeset
   588
	/** Sets the other_speed_configuration descriptor to the contents of aDescriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   589
089413cdde3c 201028_02
hgs
parents:
diff changeset
   590
		@param aDescriptor contains the new other_speed_configuration descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   591
089413cdde3c 201028_02
hgs
parents:
diff changeset
   592
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   593
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   594
	inline TInt SetOtherSpeedConfigurationDescriptor(const TDesC8& aDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   595
089413cdde3c 201028_02
hgs
parents:
diff changeset
   596
	/** Copies the class specific interface descriptor block into aInterfaceDescriptor for the interface
089413cdde3c 201028_02
hgs
parents:
diff changeset
   597
		with alternate setting aSettingNumber, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   598
089413cdde3c 201028_02
hgs
parents:
diff changeset
   599
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   600
		@param aInterfaceDescriptor Contains the interface descriptor to be set.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   601
089413cdde3c 201028_02
hgs
parents:
diff changeset
   602
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   603
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   604
	inline TInt GetCSInterfaceDescriptorBlock(TInt aSettingNumber, TDes8& aInterfaceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   605
089413cdde3c 201028_02
hgs
parents:
diff changeset
   606
	/** aSettingNumber is the alternate interface setting, 0 for the main interface, that the descriptor block
089413cdde3c 201028_02
hgs
parents:
diff changeset
   607
		aDes should be attached to. aDes is a block of data containing at least one class specific descriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   608
		for transmission during enumeration after the class interface descriptor (or alternate interface
089413cdde3c 201028_02
hgs
parents:
diff changeset
   609
		descriptor) has been sent, but before the endpoint descriptors belonging to this interface are sent.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   610
		aDes may contain as many descriptors as are necessary or only 1. SetCSInterfaceDescriptorBlock()
089413cdde3c 201028_02
hgs
parents:
diff changeset
   611
		should be called at any time after SetInterface() has been called to establish a main interface or an
089413cdde3c 201028_02
hgs
parents:
diff changeset
   612
		alternate interface. More than one call may be made - the data blocks will be concatenated prior to
089413cdde3c 201028_02
hgs
parents:
diff changeset
   613
		sending. No checking or validation of the contents of aDes will be made and it is the caller's
089413cdde3c 201028_02
hgs
parents:
diff changeset
   614
		responsibility to ensure that the data supplied is correct and appropriate to the interface identified
089413cdde3c 201028_02
hgs
parents:
diff changeset
   615
		by aSettingNumber.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   616
089413cdde3c 201028_02
hgs
parents:
diff changeset
   617
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   618
		@param aInterfaceDescriptor Contains the interface descriptor to be set.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   619
089413cdde3c 201028_02
hgs
parents:
diff changeset
   620
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   621
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   622
	inline TInt SetCSInterfaceDescriptorBlock(TInt aSettingNumber, const TDesC8& aInterfaceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   623
089413cdde3c 201028_02
hgs
parents:
diff changeset
   624
	/** Copies the size of the class specific interface descriptor block for the interface with alternate
089413cdde3c 201028_02
hgs
parents:
diff changeset
   625
		setting aSettingNumber, 0 for the main interface, into aSize.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   626
089413cdde3c 201028_02
hgs
parents:
diff changeset
   627
		@param aSettingNumber The alternate setting number.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   628
		@param aSize receives the size of the interface descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   629
089413cdde3c 201028_02
hgs
parents:
diff changeset
   630
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   631
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   632
	inline TInt GetCSInterfaceDescriptorBlockSize(TInt aSettingNumber, TInt& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   633
089413cdde3c 201028_02
hgs
parents:
diff changeset
   634
	/** Copies the class specific endpoint descriptor for logical endpoint number aEndpointNumber
089413cdde3c 201028_02
hgs
parents:
diff changeset
   635
		into aEndpointDescriptor for the interface with alternate setting aSettingNumber, 0 for the main
089413cdde3c 201028_02
hgs
parents:
diff changeset
   636
		interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   637
089413cdde3c 201028_02
hgs
parents:
diff changeset
   638
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   639
		@param aEndpointNumber Valid endpoint number on this interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   640
		@param aEndpointDescriptor Receives the endpoint descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   641
089413cdde3c 201028_02
hgs
parents:
diff changeset
   642
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   643
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   644
	inline TInt GetCSEndpointDescriptorBlock(TInt aSettingNumber, TInt aEndpointNumber,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   645
											 TDes8& aEndpointDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   646
089413cdde3c 201028_02
hgs
parents:
diff changeset
   647
	/** Sets the class specific endpoint descriptor for logical endpoint number aEndpointNumber contained in
089413cdde3c 201028_02
hgs
parents:
diff changeset
   648
		aEndpointDescriptor for the interface with alternate setting aSettingNumber, 0 for the main interface,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   649
		for transmission to the host during enumeration.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   650
089413cdde3c 201028_02
hgs
parents:
diff changeset
   651
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   652
		@param aEndpointNumber Valid endpoint number on this interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   653
		@param aEndpointDescriptor Contains the endpoint descriptor to be set.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   654
089413cdde3c 201028_02
hgs
parents:
diff changeset
   655
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   656
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   657
	inline TInt SetCSEndpointDescriptorBlock(TInt aSettingNumber, TInt aEndpointNumber,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   658
											 const TDesC8& aEndpointDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   659
089413cdde3c 201028_02
hgs
parents:
diff changeset
   660
	/** Copies the size of the class specific endpoint descriptor block for logical endpoint number
089413cdde3c 201028_02
hgs
parents:
diff changeset
   661
		aEndpointNumber for the interface with alternate setting aSettingNumber, 0 for the main interface,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   662
		into aSize.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   663
089413cdde3c 201028_02
hgs
parents:
diff changeset
   664
		@param aSettingNumber Alternate setting number on the interface, 0 for the main interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   665
		@param aEndpointNumber Valid endpoint number on this interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   666
		@param aSize On return, contains the size of the class specific endpoint descriptor block.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   667
089413cdde3c 201028_02
hgs
parents:
diff changeset
   668
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   669
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   670
	inline TInt GetCSEndpointDescriptorBlockSize(TInt aSettingNumber, TInt aEndpointNumber, TInt& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   671
089413cdde3c 201028_02
hgs
parents:
diff changeset
   672
	/** Generates a Remote Wakeup bus condition
089413cdde3c 201028_02
hgs
parents:
diff changeset
   673
		The capability of the device to generate Remote Wakeup signalling is enquired in
089413cdde3c 201028_02
hgs
parents:
diff changeset
   674
		RDevUsbcClient::DeviceCaps.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   675
089413cdde3c 201028_02
hgs
parents:
diff changeset
   676
		@return KErrNone if this signalling is possible and the signal has been generated.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   677
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   678
	inline TInt SignalRemoteWakeup();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   679
089413cdde3c 201028_02
hgs
parents:
diff changeset
   680
	/** Simulates a physical removal of the USB cable by disabling the D+/- pull-ups.The iConnect member of
089413cdde3c 201028_02
hgs
parents:
diff changeset
   681
		TUsbDeviceCapsV01, returned by RDevUsbcClient::DeviceCaps(), indicates whether this functionality is
089413cdde3c 201028_02
hgs
parents:
diff changeset
   682
		supported.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   683
089413cdde3c 201028_02
hgs
parents:
diff changeset
   684
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   685
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   686
	inline TInt DeviceDisconnectFromHost();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   687
089413cdde3c 201028_02
hgs
parents:
diff changeset
   688
	/** Simulates a physical insertion of the USB cable by enabling the D+/- pull-ups.The iConnect member
089413cdde3c 201028_02
hgs
parents:
diff changeset
   689
		of TUsbDeviceCapsV01, returned by RDevUsbcClient::DeviceCaps(),  indicates whether this functionality
089413cdde3c 201028_02
hgs
parents:
diff changeset
   690
		is supported.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   691
089413cdde3c 201028_02
hgs
parents:
diff changeset
   692
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   693
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   694
	inline TInt DeviceConnectToHost();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   695
089413cdde3c 201028_02
hgs
parents:
diff changeset
   696
	/** Powers up the UDC and connects it to the bus if one or more interfaces exist.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   697
089413cdde3c 201028_02
hgs
parents:
diff changeset
   698
		@return KErrNone if UDC successfully powered up, KErrNotReady if no
089413cdde3c 201028_02
hgs
parents:
diff changeset
   699
		interfaces have been registered yet, KErrHardwareNotAvailable if UDC
089413cdde3c 201028_02
hgs
parents:
diff changeset
   700
		couldn't be activated.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   701
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   702
	inline TInt PowerUpUdc();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   703
089413cdde3c 201028_02
hgs
parents:
diff changeset
   704
	/** Enquires about the current operating speed of the UDC.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   705
089413cdde3c 201028_02
hgs
parents:
diff changeset
   706
		@return ETrue if the UDC is currently operating at High speed, EFalse otherwise.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   707
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   708
	inline TBool CurrentlyUsingHighSpeed();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   709
089413cdde3c 201028_02
hgs
parents:
diff changeset
   710
	/** Allocates the use of aResource to aEndpoint. it will be used from when the current bus transfer	has been
089413cdde3c 201028_02
hgs
parents:
diff changeset
   711
		completed.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   712
089413cdde3c 201028_02
hgs
parents:
diff changeset
   713
		@param aResource is typically some rationed hardware resource or possibly specifies a type of endpoint
089413cdde3c 201028_02
hgs
parents:
diff changeset
   714
		behaviour. aResource is not a bitmap and TEndpointResource values should not be combined.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   715
		@param aEndpoint The endpoint number to which the resource is to be allocated.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   716
089413cdde3c 201028_02
hgs
parents:
diff changeset
   717
		@return KErrNone if successful, KErrInUse if the resource is already consumed and cannot be allocated,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   718
		KErrNotSupported if the endpoint does not support the resource requested.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   719
089413cdde3c 201028_02
hgs
parents:
diff changeset
   720
		@publishedPartner @deprecated
089413cdde3c 201028_02
hgs
parents:
diff changeset
   721
089413cdde3c 201028_02
hgs
parents:
diff changeset
   722
		@see TUsbcEndpointInfo
089413cdde3c 201028_02
hgs
parents:
diff changeset
   723
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   724
	inline TInt AllocateEndpointResource(TInt aEndpoint, TUsbcEndpointResource aResource);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   725
089413cdde3c 201028_02
hgs
parents:
diff changeset
   726
	/** Deallocates the use of aResource aEndpoint or ends a specified endpoint behaviour.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   727
089413cdde3c 201028_02
hgs
parents:
diff changeset
   728
		@param aResource is typically some rationed hardware resource or possibly specifies a type of endpoint
089413cdde3c 201028_02
hgs
parents:
diff changeset
   729
		behaviour. aResource is not a bitmap and TEndpointResource values should not be combined.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   730
		@param aEndpoint The endpoint number from which the resource is to be removed.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   731
089413cdde3c 201028_02
hgs
parents:
diff changeset
   732
		@return KErrNone if the resource has been successfully deallocated, KErrNotSupported if the endpoint
089413cdde3c 201028_02
hgs
parents:
diff changeset
   733
		does not support the resource requested.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   734
089413cdde3c 201028_02
hgs
parents:
diff changeset
   735
		@publishedPartner @deprecated
089413cdde3c 201028_02
hgs
parents:
diff changeset
   736
089413cdde3c 201028_02
hgs
parents:
diff changeset
   737
		@see TUsbcEndpointInfo
089413cdde3c 201028_02
hgs
parents:
diff changeset
   738
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   739
	inline TInt DeAllocateEndpointResource(TInt aEndpoint, TUsbcEndpointResource aResource);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   740
089413cdde3c 201028_02
hgs
parents:
diff changeset
   741
	/** Queries endpoint resource use.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   742
089413cdde3c 201028_02
hgs
parents:
diff changeset
   743
		@param aResource is typically some rationed hardware resource or possibly specifies a type of endpoint
089413cdde3c 201028_02
hgs
parents:
diff changeset
   744
		behaviour. aResource is not a bitmap and TEndpointResource values should not be combined.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   745
		@param aEndpoint The endpoint number at which the resource is to be queried.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   746
089413cdde3c 201028_02
hgs
parents:
diff changeset
   747
		@return ETrue is the specified resource is in use at the endpoint and EFalse if not.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   748
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   749
	inline TBool QueryEndpointResourceUse(TInt aEndpoint, TUsbcEndpointResource aResource);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   750
089413cdde3c 201028_02
hgs
parents:
diff changeset
   751
	/** Request (i.e. claim for this channel) up to five endpoints and set the class type for this USB
089413cdde3c 201028_02
hgs
parents:
diff changeset
   752
		interface. 'aInterfaceData' is a package buffer which describes the interface and all the endpoints
089413cdde3c 201028_02
hgs
parents:
diff changeset
   753
		being requested by the driver for this interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   754
089413cdde3c 201028_02
hgs
parents:
diff changeset
   755
		@param aInterfaceNumber Distinguishes between alternate interfaces. If these are not be used then this
089413cdde3c 201028_02
hgs
parents:
diff changeset
   756
		should always be zero. If this parameter is used, then its value must be one more than that of the
089413cdde3c 201028_02
hgs
parents:
diff changeset
   757
		proceeding alternate interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   758
		@param aInterfaceData a package buffer which describes the interface and all the endpoints being
089413cdde3c 201028_02
hgs
parents:
diff changeset
   759
		requested by the driver for this interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   760
		@param aBandwidthPriority is a bitmap combining the required IN and OUT priorities. Values are in the
089413cdde3c 201028_02
hgs
parents:
diff changeset
   761
		range [0,3] from the lowest priority bandwidth, 0, to the highest 3 and are separately specified for
089413cdde3c 201028_02
hgs
parents:
diff changeset
   762
		IN and OUT endpoints. Interfaces requiring higher bandwidth are allocated significantly more buffering
089413cdde3c 201028_02
hgs
parents:
diff changeset
   763
		than low bandwidth interfaces. Interfaces should not be given a higher bandwidth priority than they
089413cdde3c 201028_02
hgs
parents:
diff changeset
   764
		require.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   765
089413cdde3c 201028_02
hgs
parents:
diff changeset
   766
		@return KErrInUse if any of the endpoints being requested have already been claimed by another channel
089413cdde3c 201028_02
hgs
parents:
diff changeset
   767
		KErrNotSupported if an endpoint with all of the specified properties is not supported on this
089413cdde3c 201028_02
hgs
parents:
diff changeset
   768
		platform. KErrNoMemory if insufficient memory is available to complete the operation.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   769
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   770
	inline TInt SetInterface(TInt aInterfaceNumber, TUsbcInterfaceInfoBuf& aInterfaceData,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   771
							 TUint32 aBandwidthPriority =
089413cdde3c 201028_02
hgs
parents:
diff changeset
   772
							 (EUsbcBandwidthOUTDefault | EUsbcBandwidthINDefault));
089413cdde3c 201028_02
hgs
parents:
diff changeset
   773
089413cdde3c 201028_02
hgs
parents:
diff changeset
   774
	/** Release an interface previously claimed by this channel. Alternate interfaces need to be released
089413cdde3c 201028_02
hgs
parents:
diff changeset
   775
		in strict descending order, starting with the last (i.e. highest numbered) one.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   776
		It is not necessary to release an interface that wasn't successfully requested.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   777
089413cdde3c 201028_02
hgs
parents:
diff changeset
   778
		@param aInterfaceNumber Specifies the alternate setting number 'aInterfaceNum' of the interface to be
089413cdde3c 201028_02
hgs
parents:
diff changeset
   779
		released.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   780
089413cdde3c 201028_02
hgs
parents:
diff changeset
   781
		@return KErrNone if successful. KErrArgument if the alternate setting doesn't exist or is released out
089413cdde3c 201028_02
hgs
parents:
diff changeset
   782
		of order.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   783
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   784
	inline TInt ReleaseInterface(TInt aInterfaceNumber);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   785
089413cdde3c 201028_02
hgs
parents:
diff changeset
   786
	/** Copies the current string descriptor language ID (LANGID) code into the aLangId argument. Even though
089413cdde3c 201028_02
hgs
parents:
diff changeset
   787
		the USB spec allows for the existence of a whole array of LANGID codes, we only support one.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   788
089413cdde3c 201028_02
hgs
parents:
diff changeset
   789
		@param aLangId receives the LANGID code.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   790
089413cdde3c 201028_02
hgs
parents:
diff changeset
   791
		@return KErrNone if successful, KErrArgument if problem with argument (memory cannot be written to, etc.).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   792
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   793
	inline TInt GetStringDescriptorLangId(TUint16& aLangId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   794
089413cdde3c 201028_02
hgs
parents:
diff changeset
   795
	/** Sets the string descriptor language ID (LANGID). Even though the USB spec allows for the existence of
089413cdde3c 201028_02
hgs
parents:
diff changeset
   796
		a whole array of LANGID codes, we only support one.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   797
089413cdde3c 201028_02
hgs
parents:
diff changeset
   798
		@param aLangId the LANGID code to be set.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   799
089413cdde3c 201028_02
hgs
parents:
diff changeset
   800
		@return KErrNone if successful.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   801
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   802
	inline TInt SetStringDescriptorLangId(TUint16 aLangId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   803
089413cdde3c 201028_02
hgs
parents:
diff changeset
   804
	/** Copies the string descriptor identified by the iManufacturer index field of the Standard Device
089413cdde3c 201028_02
hgs
parents:
diff changeset
   805
		Descriptor into the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   806
089413cdde3c 201028_02
hgs
parents:
diff changeset
   807
		@param aString receives manufacturer string.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   808
089413cdde3c 201028_02
hgs
parents:
diff changeset
   809
		@return KErrNone if successful, KErrArgument if MaxLength of aString is too small to hold the entire
089413cdde3c 201028_02
hgs
parents:
diff changeset
   810
		descriptor, KErrNotFound if the string descriptor couldn't be found.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   811
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   812
	inline TInt GetManufacturerStringDescriptor(TDes16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   813
089413cdde3c 201028_02
hgs
parents:
diff changeset
   814
	/** Sets the string descriptor identified by the iManufacturer index field of the Standard Device
089413cdde3c 201028_02
hgs
parents:
diff changeset
   815
		Descriptor to the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   816
089413cdde3c 201028_02
hgs
parents:
diff changeset
   817
		@param aString Contains the new manufacturer string descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   818
089413cdde3c 201028_02
hgs
parents:
diff changeset
   819
		@return KErrNone if successful, KErrNoMemory if no memory is available to store the new string from
089413cdde3c 201028_02
hgs
parents:
diff changeset
   820
		aString (in which case the old string descriptor will be preserved).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   821
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   822
	inline TInt SetManufacturerStringDescriptor(const TDesC16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   823
089413cdde3c 201028_02
hgs
parents:
diff changeset
   824
	/** Removes (deletes) the string descriptor identified by the iManufacturer index field of the Standard
089413cdde3c 201028_02
hgs
parents:
diff changeset
   825
		Device Descriptor and sets that field to zero.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   826
089413cdde3c 201028_02
hgs
parents:
diff changeset
   827
		@return KErrNone if successful, KErrNotFound if the string descriptor couldn't be found.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   828
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   829
	inline TInt RemoveManufacturerStringDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   830
089413cdde3c 201028_02
hgs
parents:
diff changeset
   831
	/** Retrieves the string descriptor identified by the iProduct index field of the Standard Device
089413cdde3c 201028_02
hgs
parents:
diff changeset
   832
		Descriptor into the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   833
089413cdde3c 201028_02
hgs
parents:
diff changeset
   834
		@param aString receives product string.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   835
089413cdde3c 201028_02
hgs
parents:
diff changeset
   836
		@return KErrNone if successful, KErrArgument if MaxLength of aString is too small to hold the entire
089413cdde3c 201028_02
hgs
parents:
diff changeset
   837
		descriptor, KErrNotFound if the string descriptor couldn't be found.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   838
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   839
	inline TInt GetProductStringDescriptor(TDes16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   840
089413cdde3c 201028_02
hgs
parents:
diff changeset
   841
	/** Sets the string descriptor identified by the iProduct index field of the Standard Device Descriptor to
089413cdde3c 201028_02
hgs
parents:
diff changeset
   842
		the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   843
089413cdde3c 201028_02
hgs
parents:
diff changeset
   844
		@param aString Contains the new product string descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   845
089413cdde3c 201028_02
hgs
parents:
diff changeset
   846
		@return KErrNone if successful, KErrNoMemory if no memory is available to store the new string from
089413cdde3c 201028_02
hgs
parents:
diff changeset
   847
		aString (in which case the old string descriptor will be preserved).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   848
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   849
	inline TInt SetProductStringDescriptor(const TDesC16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   850
089413cdde3c 201028_02
hgs
parents:
diff changeset
   851
	/** Removes (deletes) the string descriptor identified by the iProduct index field of the Standard Device
089413cdde3c 201028_02
hgs
parents:
diff changeset
   852
		Descriptor and sets that field to zero.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   853
089413cdde3c 201028_02
hgs
parents:
diff changeset
   854
		@return KErrNone if successful, KErrNotFound if the string descriptor couldn't be found.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   855
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   856
	inline TInt RemoveProductStringDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   857
089413cdde3c 201028_02
hgs
parents:
diff changeset
   858
	/** Retrieves the string descriptor identified by the iSerialNumber index field of the Standard Device
089413cdde3c 201028_02
hgs
parents:
diff changeset
   859
		Descriptor into the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   860
089413cdde3c 201028_02
hgs
parents:
diff changeset
   861
		@param aString receives product string.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   862
089413cdde3c 201028_02
hgs
parents:
diff changeset
   863
		@return KErrNone if successful, KErrArgument if MaxLength of aString is too small to hold the entire
089413cdde3c 201028_02
hgs
parents:
diff changeset
   864
		descriptor, KErrNotFound if the string descriptor couldn't be found.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   865
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   866
	inline TInt GetSerialNumberStringDescriptor(TDes16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   867
089413cdde3c 201028_02
hgs
parents:
diff changeset
   868
	/** Sets the string descriptor identified by the iSerialNumber index field of the Standard Device
089413cdde3c 201028_02
hgs
parents:
diff changeset
   869
		Descriptor to the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   870
089413cdde3c 201028_02
hgs
parents:
diff changeset
   871
		@param aString Contains the new serial number string descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   872
089413cdde3c 201028_02
hgs
parents:
diff changeset
   873
		@return KErrNone if successful, KErrNoMemory if no memory is available to store the new string from
089413cdde3c 201028_02
hgs
parents:
diff changeset
   874
		aString (in which case the old string descriptor will be preserved).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   875
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   876
	inline TInt SetSerialNumberStringDescriptor(const TDesC16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   877
089413cdde3c 201028_02
hgs
parents:
diff changeset
   878
	/** Removes (deletes) the string descriptor identified by the iSerialNumber index field of the Standard
089413cdde3c 201028_02
hgs
parents:
diff changeset
   879
		Device Descriptor and sets that field to zero.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   880
089413cdde3c 201028_02
hgs
parents:
diff changeset
   881
		@return KErrNone if successful, KErrNotFound if the string descriptor couldn't be found.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   882
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   883
	inline TInt RemoveSerialNumberStringDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   884
089413cdde3c 201028_02
hgs
parents:
diff changeset
   885
	/** Retrieves the string descriptor identified by the iConfiguration index field of the (first) Standard
089413cdde3c 201028_02
hgs
parents:
diff changeset
   886
		Configuration Descriptor into the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   887
089413cdde3c 201028_02
hgs
parents:
diff changeset
   888
		@param aString receives configuration string.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   889
089413cdde3c 201028_02
hgs
parents:
diff changeset
   890
		@return KErrNone if successful, KErrArgument if MaxLength of aString is too small to hold the entire
089413cdde3c 201028_02
hgs
parents:
diff changeset
   891
		descriptor, KErrNotFound if the string descriptor couldn't be found.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   892
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   893
	inline TInt GetConfigurationStringDescriptor(TDes16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   894
089413cdde3c 201028_02
hgs
parents:
diff changeset
   895
	/** Sets the string descriptor identified by the iConfiguration index field of the Standard Configuration
089413cdde3c 201028_02
hgs
parents:
diff changeset
   896
		Descriptor to the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   897
089413cdde3c 201028_02
hgs
parents:
diff changeset
   898
		@param aString Contains the new serial number string descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   899
089413cdde3c 201028_02
hgs
parents:
diff changeset
   900
		@return KErrNone if successful, KErrNoMemory if no memory is available to store the new string from
089413cdde3c 201028_02
hgs
parents:
diff changeset
   901
		aString (in which case the old string descriptor will be preserved).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   902
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   903
	inline TInt SetConfigurationStringDescriptor(const TDesC16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   904
089413cdde3c 201028_02
hgs
parents:
diff changeset
   905
	/** Removes (deletes) the string descriptor identified by the iConfiguration index field of the Standard
089413cdde3c 201028_02
hgs
parents:
diff changeset
   906
		Configuration Descriptor and sets that field to zero.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   907
089413cdde3c 201028_02
hgs
parents:
diff changeset
   908
		@return KErrNone if successful, KErrNotFound if the string descriptor couldn't be found.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   909
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   910
	inline TInt RemoveConfigurationStringDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   911
089413cdde3c 201028_02
hgs
parents:
diff changeset
   912
	/** Copies the string of the USB string descriptor at the specified index in the string descriptor array
089413cdde3c 201028_02
hgs
parents:
diff changeset
   913
		into the aString argument.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   914
089413cdde3c 201028_02
hgs
parents:
diff changeset
   915
		Although this function can also be used for it, for querying most standard string descriptors
089413cdde3c 201028_02
hgs
parents:
diff changeset
   916
		there exists a set of dedicated access functions.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   917
089413cdde3c 201028_02
hgs
parents:
diff changeset
   918
		@see RDevUsbcClient::GetStringDescriptorLangId
089413cdde3c 201028_02
hgs
parents:
diff changeset
   919
		@see RDevUsbcClient::GetManufacturerStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   920
		@see RDevUsbcClient::GetProductStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   921
		@see RDevUsbcClient::GetSerialNumberStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   922
		@see RDevUsbcClient::GetConfigurationStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   923
089413cdde3c 201028_02
hgs
parents:
diff changeset
   924
		@param aIndex The position of the string descriptor in the string descriptor array.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   925
		@param aString The target location for the string descriptor copy.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   926
089413cdde3c 201028_02
hgs
parents:
diff changeset
   927
		@return KErrNone if successful, KErrNotFound if no string descriptor exists at the specified index,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   928
		KErrArgument if MaxLength() of aString is too small to hold the entire descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   929
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   930
	inline TInt GetStringDescriptor(TUint8 aIndex, TDes16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   931
089413cdde3c 201028_02
hgs
parents:
diff changeset
   932
	/** Sets the aString argument to be the string of a USB string descriptor at the specified index in the
089413cdde3c 201028_02
hgs
parents:
diff changeset
   933
		string descriptor array. If a string descriptor already exists at that position then its string will
089413cdde3c 201028_02
hgs
parents:
diff changeset
   934
		be replaced.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   935
089413cdde3c 201028_02
hgs
parents:
diff changeset
   936
		Care should be taken, when choosing aIndex, not to inadvertently overwrite one of the standard
089413cdde3c 201028_02
hgs
parents:
diff changeset
   937
		string descriptors.	For their manipulation there exists a set of dedicated access functions.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   938
089413cdde3c 201028_02
hgs
parents:
diff changeset
   939
		@see RDevUsbcClient::SetStringDescriptorLangId
089413cdde3c 201028_02
hgs
parents:
diff changeset
   940
		@see RDevUsbcClient::SetManufacturerStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   941
		@see RDevUsbcClient::SetProductStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   942
		@see RDevUsbcClient::SetSerialNumberStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   943
		@see RDevUsbcClient::SetConfigurationStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   944
089413cdde3c 201028_02
hgs
parents:
diff changeset
   945
		@param aIndex The position of the string descriptor in the string descriptor array.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   946
		@param aString Contains the string descriptor to be set.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   947
089413cdde3c 201028_02
hgs
parents:
diff changeset
   948
		@return KErrNone if successful, KErrArgument if aIndex is invalid, KErrNoMemory if no memory
089413cdde3c 201028_02
hgs
parents:
diff changeset
   949
		is available to store the new string (an existing descriptor at that index will be preserved).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   950
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   951
	inline TInt SetStringDescriptor(TUint8 aIndex, const TDesC16& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   952
089413cdde3c 201028_02
hgs
parents:
diff changeset
   953
	/** Removes (deletes) the USB string descriptor at the specified index in the string descriptor array.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   954
		The position in the array of other string descriptors is not affected.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   955
089413cdde3c 201028_02
hgs
parents:
diff changeset
   956
		Care should be taken, when choosing aIndex, not to inadvertently delete a standard string descriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   957
		(also because index references from non-string descriptors would be invalidated). For the deletion
089413cdde3c 201028_02
hgs
parents:
diff changeset
   958
		of most standard string descriptors there exists a set of dedicated functions.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   959
089413cdde3c 201028_02
hgs
parents:
diff changeset
   960
		@see RDevUsbcClient::RemoveManufacturerStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   961
		@see RDevUsbcClient::RemoveProductStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   962
		@see RDevUsbcClient::RemoveSerialNumberStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   963
		@see RDevUsbcClient::RemoveConfigurationStringDescriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   964
089413cdde3c 201028_02
hgs
parents:
diff changeset
   965
		@param aIndex The position of the string descriptor in the string descriptor array.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   966
089413cdde3c 201028_02
hgs
parents:
diff changeset
   967
		@return KErrNone if successful, KErrNotFound if no string descriptor exists at the specified index.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   968
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   969
	inline TInt RemoveStringDescriptor(TUint8 aIndex);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   970
089413cdde3c 201028_02
hgs
parents:
diff changeset
   971
	/** Asynchronously read data from endpoint 'aEndpoint' into the descriptor 'aDes'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   972
		Request completes when the specified number of bytes is received, length taken from max. length of
089413cdde3c 201028_02
hgs
parents:
diff changeset
   973
		descriptor.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   974
089413cdde3c 201028_02
hgs
parents:
diff changeset
   975
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   976
		@param aEndpoint The endpoint number to read from.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   977
		@param aDes	Descriptor to receive the data.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   978
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   979
	inline void Read(TRequestStatus& aStatus, TEndpointNumber aEndpoint, TDes8& aDes);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   980
089413cdde3c 201028_02
hgs
parents:
diff changeset
   981
	/** Asynchronously read data from endpoint 'aEndpoint' into the descriptor 'aDes'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   982
		Request completes when the specified number of bytes is received.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   983
089413cdde3c 201028_02
hgs
parents:
diff changeset
   984
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   985
		@param aEndpoint The endpoint number to read from.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   986
		@param aDes	Descriptor to receive the data.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   987
		@param aLen The number of bytes to read.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   988
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   989
	inline void Read(TRequestStatus& aStatus, TEndpointNumber aEndpoint, TDes8& aDes, TInt aLen);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   990
089413cdde3c 201028_02
hgs
parents:
diff changeset
   991
	/** Asynchronously read an entire packet of data from endpoint 'aEndpoint' into the descriptor 'aDes'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   992
		If a packet has previously been partly read. then only the remainder of the packet will be returned.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   993
		The request should be for the maximum packet size of the endpoint. If less data is requested, then
089413cdde3c 201028_02
hgs
parents:
diff changeset
   994
		after this read completes the remainder of the data in the packet will be discarded and the next read
089413cdde3c 201028_02
hgs
parents:
diff changeset
   995
		will start from the next available packet.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   996
		Request completes when either a complete packet is received or the length of the packet currently
089413cdde3c 201028_02
hgs
parents:
diff changeset
   997
		being received exceeds 'aMaxLen'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   998
089413cdde3c 201028_02
hgs
parents:
diff changeset
   999
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1000
		@param aEndpoint The endpoint number to read from.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1001
		@param aDes	Descriptor to receive the data.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1002
		@param aMaxLen .
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1003
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1004
	inline void ReadPacket(TRequestStatus& aStatus, TEndpointNumber aEndpoint, TDes8& aDes, TInt aMaxLen);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1005
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1006
	/** Asynchronously read data from endpoint 'aEndpoint' into the descriptor 'aDes'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1007
		Request completes when the specified number of bytes is received (in first version,
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1008
		length taken from max. length of descriptor).
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1009
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1010
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1011
		@param aEndpoint The endpoint number to read from.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1012
		@param aDes	Descriptor to receive the data.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1013
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1014
	inline void ReadUntilShort(TRequestStatus& aStatus, TEndpointNumber aEndpoint, TDes8& aDes);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1015
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1016
	/** Asynchronously read data from endpoint 'aEndpoint' into the descriptor 'aDes'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1017
		Request completes when the specified number of bytes is received (in first version,
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1018
		length taken from max. length of descriptor).
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1019
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1020
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1021
		@param aEndpoint The endpoint number to read from.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1022
		@param aDes	Descriptor to receive the data.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1023
		@param aLen The number of bytes to receive.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1024
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1025
	inline void ReadUntilShort(TRequestStatus& aStatus, TEndpointNumber aEndpoint, TDes8& aDes, TInt aLen);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1026
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1027
	/** Asynchronously read data from endpoint 'aEndpoint' into the descriptor 'aDes'. The request completes
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1028
		when the specified number of bytes is received, length taken from max. length of descriptor or a
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1029
		packet whose size is smaller than the endpoint's maximum packet size is received.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1030
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1031
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1032
		@param aEndpoint The endpoint number to read from.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1033
		@param aDes	Descriptor to receive the data.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1034
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1035
	inline void ReadOneOrMore(TRequestStatus& aStatus, TEndpointNumber aEndpoint, TDes8& aDes);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1036
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1037
	/** Asynchronously read data from endpoint 'aEndpoint' into the descriptor 'aDes'. The request completes
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1038
		when the specified number of bytes is received, or a packet whose size is smaller than the endpoint's
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1039
		maximum packet size is received.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1040
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1041
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1042
		@param aEndpoint The endpoint number to read from.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1043
		@param aDes	Descriptor to receive the data.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1044
		@param aLen The number of bytes to receive.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1045
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1046
	inline void ReadOneOrMore(TRequestStatus& aStatus, TEndpointNumber aEndpoint, TDes8& aDes, TInt aLen);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1047
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1048
	/** Cancels an outstanding read request. The request will complete with whatever data is available.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1049
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1050
	inline void ReadCancel(TEndpointNumber aEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1051
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1052
	/** Asynchronously write 'aLen' bytes of data to endpoint 'aEndpoint' from descriptor 'aDes'. 'aZlpRequired'
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1053
		(optional) signals that ZLP termination may be required.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1054
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1055
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1056
		@param aEndpoint The endpoint number to write to.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1057
		@param aDes	Descriptor to provide the data.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1058
		@param aLen The number of bytes of data to be written.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1059
		@param aZlpRequired True, if ZLP termination is required; false, otherwise.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1060
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1061
	inline void Write(TRequestStatus& aStatus, TEndpointNumber aEndpoint, const TDesC8& aDes, TInt aLen,
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1062
					  TBool aZlpRequired=EFalse);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1063
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1064
	/** Cancels an outstanding write request on endpoint aEndpoint.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1065
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1066
		@param aEndpoint The endpoint number whose write is to be cancelled.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1067
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1068
	inline void WriteCancel(TEndpointNumber aEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1069
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1070
	/** Cancels any transfer on any endpoint specified in aEndpointMask.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1071
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1072
		@code
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1073
		// Cancel transfer requests on endpoints 1, 2 & 3
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1074
		usbPort.EndpointTransferCancel(KUsbcEndpoint1Bit | KUsbcEndpoint2Bit | KUsbcEndpoint3Bit);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1075
		@endcode
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1076
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1077
		@param aEndpointMask bitmap of the endpoints.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1078
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1079
	inline void EndpointTransferCancel(TUint aEndpointMask);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1080
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1081
	/**	Register for notification when a change of the Interface alternate setting or the USB Controller's
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1082
		current state occurs. When the alternate setting or the Controller state changes, then the
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1083
		asynchronous function completes and the current alternate setting number or Controller state is
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1084
		written back to aValue. If the KUsbAlternateSetting bit is set then the remaining bits are the
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1085
		alternate setting number. Otherwise aValue is interpreted as a TUsbcDeviceState.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1086
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1087
		@see TUsbcDeviceState
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1088
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1089
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1090
		@param aValue Receives the alternate setting number or Controller state.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1091
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1092
	inline void AlternateDeviceStatusNotify(TRequestStatus& aStatus, TUint& aValue);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1093
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1094
	/** Completes an AlternateDeviceStatusNotify request. If a request has previously been made then the
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1095
		status variable is updated with the current device state.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1096
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1097
	inline void AlternateDeviceStatusNotifyCancel();
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1098
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1099
	/** If the channel has changed the grouping of endpoints between interfaces or changed the interface class
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1100
		type from the defaults then it is necessary to force a re-enumeration. This will typically involve the
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1101
		Symbian OS device initiating a disconnection and re-connection. This is an asynchronous operation
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1102
		which will complete when the Controller is successfully configured by the host, i.e. has achieved
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1103
		UsbShai::EUsbPeripheralStateConfigured.  Since it is not known if the operation has failed, at the same time that
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1104
		a ReEnumerate request is made, a timer should be set up to complete after approximately 5 seconds. It
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1105
		can be assumed that if the operation has not completed after this time interval then it will not
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1106
		complete.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1107
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1108
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1109
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1110
	inline void ReEnumerate(TRequestStatus& aStatus);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1111
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1112
	/** Cancels an outstanding ReEnumerate() request.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1113
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1114
	inline void ReEnumerateCancel();
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1115
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1116
	/**	Register for notification when a change in stall status of any of the interface's endpoints occurs,
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1117
		but not ep0. When a change in stall status occurs, then the asynchronous function completes and the
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1118
		current stall state is written back to 'aEndpointStatus' as a bit map: Only stall state changes caused
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1119
		by SET_FEATURE and CLEAR_FEATURE standard commands on ep0 will be notified when this function
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1120
		completes. After this request completes the request should be re-issued to obtain future
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1121
		notifications.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1122
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1123
		@param aStatus The request status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1124
		@param aEndpointMask a bitmap of the endpoints stall status. This is filled in when the call completes
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1125
		bit 1 represents the interface's virtual endpoint 1, (KUsbcEndpoint1Bit)
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1126
		bit 2 represents the interface's virtual endpoint 2, (KUsbcEndpoint2Bit) etc.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1127
		bit value 0 - not stalled,
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1128
		bit value 1 - stalled.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1129
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1130
	inline void EndpointStatusNotify(TRequestStatus& aStatus, TUint& aEndpointMask);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1131
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1132
	/** Completes an endpoint status notify request.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1133
	*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1134
 	inline void EndpointStatusNotifyCancel();
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1135
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1136
    /** Get current on-the-go features relating to the ability of device/host pair to
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1137
        perform OTG role swap.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1138
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1139
        @param aFeatures On return it contanis features the device currently has
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1140
                bit 2 represents b_hnp_enable,       (KUsbOtgAttr_B_HnpEnable)
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1141
                bit 3 represents a_hnp_support,      (KUsbOtgAttr_A_HnpSupport)
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1142
                bit 4 represents a_alt_hnp_support,  (KUsbOtgAttr_A_AltHnpSupport)
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1143
        @return KErrNone if successful, KErrNotSupported if OTG is not supported by
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1144
                this device, otherwise system-wide error returns
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1145
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1146
    inline TInt GetOtgFeatures(TUint8& aFeatures);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1147
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1148
    /** Register for notification on USB on-the-go features' change. If any OTG feature
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1149
        is changed, request completes and current feature value is filled in aValue.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1150
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1151
        @param aStatus Request status object
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1152
        @param aValue On request completion, it contains current OTG feature value
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1153
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1154
    inline void OtgFeaturesNotify(TRequestStatus& aStatus, TUint8& aValue);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1155
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1156
    /** Cancel pending OTG feature request.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1157
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1158
    inline void OtgFeaturesNotifyCancel();
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1159
    /** Register for notification on USB charger type' change. If any usb charger
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1160
        is detected, request completes and current charger type value is filled in aValue.
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1161
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1162
        @param aStatus Request status object
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1163
        @param aValue On request completion, it contains current charger type value
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1164
    */
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1165
    inline void ChargingPortTypeNotify(TRequestStatus& aStatus, TUint& aValue);
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1166
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1167
    /** Cancel pending Charger Type request.
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1168
    */
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1169
    inline void ChargingPortTypeNotifyCancel();   
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1170
	inline TInt ChargerDetectorCaps(TUsbcChargerDetectorProperties& aProperties);
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1171
#endif // #ifndef __KERNEL_MODE__
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1172
	};
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1173
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1174
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1175
#include <usb/d32usbc.inl>
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1176
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1177
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1178
#endif // __D32USBC_H__