usbdrv/peripheral/public/usbcshared.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\drivers\usbcshared.h
bbdce6bffaad 201041_02
hgs
parents: 48
diff changeset
    16
* Kernel side definitions for the USB Device driver stack (PIL + LDD).
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 usbcshared.h
089413cdde3c 201028_02
hgs
parents:
diff changeset
    22
 @internalTechnology
089413cdde3c 201028_02
hgs
parents:
diff changeset
    23
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    24
089413cdde3c 201028_02
hgs
parents:
diff changeset
    25
#ifndef __USBCSHARED_H__
089413cdde3c 201028_02
hgs
parents:
diff changeset
    26
#define __USBCSHARED_H__
089413cdde3c 201028_02
hgs
parents:
diff changeset
    27
089413cdde3c 201028_02
hgs
parents:
diff changeset
    28
//#include <drivers/usbcque.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    29
#include <usb/usbcque.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    30
089413cdde3c 201028_02
hgs
parents:
diff changeset
    31
// Define here what options are required:
089413cdde3c 201028_02
hgs
parents:
diff changeset
    32
// (USB_SUPPORTS_CONTROLENDPOINTS and USB_SUPPORTS_SET_DESCRIPTOR_REQUEST
089413cdde3c 201028_02
hgs
parents:
diff changeset
    33
//  have never been tested though...)
089413cdde3c 201028_02
hgs
parents:
diff changeset
    34
//#define USB_SUPPORTS_CONTROLENDPOINTS
089413cdde3c 201028_02
hgs
parents:
diff changeset
    35
//#define USB_SUPPORTS_SET_DESCRIPTOR_REQUEST
089413cdde3c 201028_02
hgs
parents:
diff changeset
    36
089413cdde3c 201028_02
hgs
parents:
diff changeset
    37
//#include <drivers/usbcdesc.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    38
#include <usb/usbcdesc.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    39
//#include <drivers/usbotgperipheralcontrolif.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    40
#include <usb/usbotgperipheralcontrolif.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    41
089413cdde3c 201028_02
hgs
parents:
diff changeset
    42
#include <usb/usb_peripheral_shai.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    43
#include <usb/usb_charger_detection_shai.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    44
089413cdde3c 201028_02
hgs
parents:
diff changeset
    45
#include <usb/usbcontrolxferif.h>
089413cdde3c 201028_02
hgs
parents:
diff changeset
    46
089413cdde3c 201028_02
hgs
parents:
diff changeset
    47
// FIXME: Remove this typedef once PIL and LDD are ready for SHAI
089413cdde3c 201028_02
hgs
parents:
diff changeset
    48
typedef UsbShai::TUsbPeripheralEvent TUsbcDeviceEvent;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    49
typedef UsbShai::TUsbPeripheralPacketArray TUsbcPacketArray;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    50
089413cdde3c 201028_02
hgs
parents:
diff changeset
    51
// Forward declaration
089413cdde3c 201028_02
hgs
parents:
diff changeset
    52
class DControlTransferManager;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    53
class TUsbcSetup;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    54
089413cdde3c 201028_02
hgs
parents:
diff changeset
    55
// Debug Support
089413cdde3c 201028_02
hgs
parents:
diff changeset
    56
089413cdde3c 201028_02
hgs
parents:
diff changeset
    57
// Use for debugging purposes only (commented out for normal operation):
089413cdde3c 201028_02
hgs
parents:
diff changeset
    58
//#define USBC_LDD_BUFFER_TRACE
089413cdde3c 201028_02
hgs
parents:
diff changeset
    59
089413cdde3c 201028_02
hgs
parents:
diff changeset
    60
static const char KUsbPILPanicCat[] = "USB PIL FAULT"; // kernel fault category
089413cdde3c 201028_02
hgs
parents:
diff changeset
    61
_LIT(KUsbPILKillCat, "USB PIL KILL");                    // thread kill category
089413cdde3c 201028_02
hgs
parents:
diff changeset
    62
_LIT(KUsbLDDKillCat, "USB LDD KILL");                    // thread kill category
089413cdde3c 201028_02
hgs
parents:
diff changeset
    63
089413cdde3c 201028_02
hgs
parents:
diff changeset
    64
/** Error code for stalled endpoint.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    65
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    66
const TInt KErrEndpointStall = KErrLocked;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    67
089413cdde3c 201028_02
hgs
parents:
diff changeset
    68
/** Error code for Ep0 write prematurely ended by a host OUT token.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    69
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    70
const TInt KErrPrematureEnd = KErrDiskFull;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    71
089413cdde3c 201028_02
hgs
parents:
diff changeset
    72
/** The following constants control the buffer arrangement for OUT transfers (IN transfers have only 1
089413cdde3c 201028_02
hgs
parents:
diff changeset
    73
    buffer). The total size of buffering for an OUT endpoint will be number of buffers * buffersize,
089413cdde3c 201028_02
hgs
parents:
diff changeset
    74
    so that, for example, a Bulk OUT endpoint will have KUsbcDmaBufNumBulk * KUsbcDmaBufSzBulk bytes of
089413cdde3c 201028_02
hgs
parents:
diff changeset
    75
    buffering.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    76
    These buffers will be physically contiguous, so that DMA may be used.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    77
    The number of buffers MUST be >=2 - otherwise the buffering scheme won't work.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    78
    The buffer sizes should be an exact fraction of 4kB and the number of buffers such that the
089413cdde3c 201028_02
hgs
parents:
diff changeset
    79
    buffersize * number of buffers is an exact multiple of 4kB, otherwise memory will be wasted.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    80
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    81
/** Size of a Control ep buffer.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    82
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    83
const TInt KUsbcDmaBufSzControl = 1024;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    84
089413cdde3c 201028_02
hgs
parents:
diff changeset
    85
/** Size of a Bulk ep buffer.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    86
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    87
const TInt KUsbcDmaBufSzBulk = 4096;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    88
089413cdde3c 201028_02
hgs
parents:
diff changeset
    89
/** Size of an Interrupt ep buffer.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    90
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    91
const TInt KUsbcDmaBufSzInterrupt = 4096;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    92
089413cdde3c 201028_02
hgs
parents:
diff changeset
    93
/** Size of an Isochronous ep buffer.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    94
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    95
const TInt KUsbcDmaBufSzIsochronous = 4096;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    96
089413cdde3c 201028_02
hgs
parents:
diff changeset
    97
/** Number of buffers for Control OUT endpoints.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    98
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    99
const TInt KUsbcDmaBufNumControl = 2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   100
089413cdde3c 201028_02
hgs
parents:
diff changeset
   101
/** Number of buffers for Isochronous OUT endpoints.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   102
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   103
const TInt KUsbcDmaBufNumIsochronous = 2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   104
089413cdde3c 201028_02
hgs
parents:
diff changeset
   105
/** Number of buffers for Bulk OUT endpoints.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   106
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   107
const TInt KUsbcDmaBufNumBulk = 2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   108
089413cdde3c 201028_02
hgs
parents:
diff changeset
   109
/** Number of buffers for Interrupt OUT endpoints.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   110
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   111
const TInt KUsbcDmaBufNumInterrupt = 2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   112
089413cdde3c 201028_02
hgs
parents:
diff changeset
   113
/** Maximum buffer number.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   114
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   115
const TInt KUsbcDmaBufNumMax = MAX4(KUsbcDmaBufNumControl, KUsbcDmaBufNumIsochronous,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   116
                                    KUsbcDmaBufNumBulk, KUsbcDmaBufNumInterrupt);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   117
089413cdde3c 201028_02
hgs
parents:
diff changeset
   118
/** Maximum number of recorded packets possible.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   119
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   120
const TUint KUsbcDmaBufMaxPkts = 2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   121
089413cdde3c 201028_02
hgs
parents:
diff changeset
   122
/** Number of arrays.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   123
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   124
const TInt KUsbcDmaBufNumArrays = 2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   125
089413cdde3c 201028_02
hgs
parents:
diff changeset
   126
/** Max size that Ep0 packets might have.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   127
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   128
const TInt KUsbcBufSzControl = 64;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   129
089413cdde3c 201028_02
hgs
parents:
diff changeset
   130
/** The Ep0 RX data collection buffer area.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   131
    (Arbitrary size, judged to be sufficient for SET_DESCRIPTOR requests)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   132
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   133
const TInt KUsbcBufSz_Ep0Rx = 1024;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   134
089413cdde3c 201028_02
hgs
parents:
diff changeset
   135
/** The Ep0 TX buffer area.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   136
    (Size sufficient to hold as much data as can be requested via GET_DESCRIPTOR)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   137
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   138
const TInt KUsbcBufSz_Ep0Tx = 1024 * 64; 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   139
089413cdde3c 201028_02
hgs
parents:
diff changeset
   140
089413cdde3c 201028_02
hgs
parents:
diff changeset
   141
/** The USB version the stack is compliant with: 2.0 (BCD).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   142
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   143
const TUint16 KUsbcUsbVersion = 0x0200;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   144
089413cdde3c 201028_02
hgs
parents:
diff changeset
   145
/** Maximum number of endpoints an interface (i.e. LDD) may have.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   146
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   147
const TInt KUsbcMaxEpNumber = 5;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   148
089413cdde3c 201028_02
hgs
parents:
diff changeset
   149
/** Status FIFO depth; enough for 2 complete configs.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   150
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   151
const TInt KUsbDeviceStatusQueueDepth = 15;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   152
089413cdde3c 201028_02
hgs
parents:
diff changeset
   153
/** = 'no status info'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   154
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   155
const TUint32 KUsbDeviceStatusNull = 0xffffffffu;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   156
089413cdde3c 201028_02
hgs
parents:
diff changeset
   157
/** = 'no buffer available'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   158
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   159
const TInt KUsbcInvalidBufferIndex = -1;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   160
089413cdde3c 201028_02
hgs
parents:
diff changeset
   161
/** = 'no packet available'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   162
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   163
const TUint KUsbcInvalidPacketIndex = (TUint)(-1);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   164
089413cdde3c 201028_02
hgs
parents:
diff changeset
   165
/** = 'no drainable buffers'.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   166
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   167
const TInt KUsbcInvalidDrainQueueIndex = -1;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   168
089413cdde3c 201028_02
hgs
parents:
diff changeset
   169
/** Number of possible bandwidth priorities.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   170
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   171
const TInt KUsbcDmaBufMaxPriorities = 4;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   172
089413cdde3c 201028_02
hgs
parents:
diff changeset
   173
// The following buffer sizes are used within the LDD for the different
089413cdde3c 201028_02
hgs
parents:
diff changeset
   174
// user-selectable endpoint bandwidth priorities
089413cdde3c 201028_02
hgs
parents:
diff changeset
   175
// (EUsbcBandwidthOUTDefault/Plus1/Plus2/Maximum + the same for 'IN').
089413cdde3c 201028_02
hgs
parents:
diff changeset
   176
// These values, in particular those for the Maximum setting, were obtained
089413cdde3c 201028_02
hgs
parents:
diff changeset
   177
// empirically.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   178
089413cdde3c 201028_02
hgs
parents:
diff changeset
   179
/** Bulk IN buffer sizes for different priorities (4K, 16K, 64K, 512K).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   180
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   181
const TInt KUsbcDmaBufSizesBulkIN[KUsbcDmaBufMaxPriorities] =
089413cdde3c 201028_02
hgs
parents:
diff changeset
   182
    {KUsbcDmaBufSzBulk, 0x4000, 0x10000, 0x80000};
089413cdde3c 201028_02
hgs
parents:
diff changeset
   183
089413cdde3c 201028_02
hgs
parents:
diff changeset
   184
/** Bulk OUT buffer sizes for different priorities (4K, 16K, 64K, 512K).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   185
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   186
const TInt KUsbcDmaBufSizesBulkOUT[KUsbcDmaBufMaxPriorities] =
089413cdde3c 201028_02
hgs
parents:
diff changeset
   187
    {KUsbcDmaBufSzBulk, 0x4000, 0x10000, 0x80000};
089413cdde3c 201028_02
hgs
parents:
diff changeset
   188
089413cdde3c 201028_02
hgs
parents:
diff changeset
   189
/** Number of UDCs supported in the system.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   190
    (Support for more than one UDC is preliminary.)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   191
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   192
const TInt KUsbcMaxUdcs = 2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   193
089413cdde3c 201028_02
hgs
parents:
diff changeset
   194
/** Number of endpoints a USB device can have.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   195
    (30 regular endpoints + 2 x Ep0)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   196
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   197
const TInt KUsbcEpArraySize = KUsbcMaxEndpoints + 2;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   198
089413cdde3c 201028_02
hgs
parents:
diff changeset
   199
/** Number of notification requests of the same kind that can be registered at
089413cdde3c 201028_02
hgs
parents:
diff changeset
   200
    a time. As normally not more than one request per kind per LDD is
089413cdde3c 201028_02
hgs
parents:
diff changeset
   201
    permitted, this number is roughly equivalent to the maximum number of LDDs
089413cdde3c 201028_02
hgs
parents:
diff changeset
   202
    that can be operating at the same time.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   203
    This constant is used by the PIL while maintaining its request lists
089413cdde3c 201028_02
hgs
parents:
diff changeset
   204
    (iClientCallbacks, iStatusCallbacks, iEpStatusCallbacks, iOtgCallbacks) to
089413cdde3c 201028_02
hgs
parents:
diff changeset
   205
    ensure that the lists are of a finite length and thus the list traverse
089413cdde3c 201028_02
hgs
parents:
diff changeset
   206
    time is bounded.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   207
    This value is chosen with the maximum number of USB interfaces (not
089413cdde3c 201028_02
hgs
parents:
diff changeset
   208
    settings) allowed by the spec for a single device in mind.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   209
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   210
const TInt KUsbcMaxListLength = 256;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   211
089413cdde3c 201028_02
hgs
parents:
diff changeset
   212
/**
089413cdde3c 201028_02
hgs
parents:
diff changeset
   213
 * device event FIFO depth, there are 5 different event define currently,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   214
 * 10 should be enough
089413cdde3c 201028_02
hgs
parents:
diff changeset
   215
 */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   216
const TInt KUsbDeviceEventQueueDepth = 10;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   217
089413cdde3c 201028_02
hgs
parents:
diff changeset
   218
/** USB LDD client callback.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   219
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   220
class TUsbcClientCallback
089413cdde3c 201028_02
hgs
parents:
diff changeset
   221
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   222
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   223
    inline TUsbcClientCallback(DBase* aOwner, TDfcFn aCallback, TInt aPriority);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   224
    inline DBase* Owner() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   225
    inline TInt DoCallback();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   226
    inline void Cancel();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   227
    inline void SetDfcQ(TDfcQue* aDfcQ);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   228
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   229
    /** Used by the PIL to queue callback objects into a TSglQue. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   230
    TSglQueLink iLink;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   231
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   232
    DBase* iOwner;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   233
    TDfc iDfc;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   234
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   235
089413cdde3c 201028_02
hgs
parents:
diff changeset
   236
089413cdde3c 201028_02
hgs
parents:
diff changeset
   237
/** The endpoint halt/clear_halt status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   238
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   239
class TUsbcEndpointStatusCallback
089413cdde3c 201028_02
hgs
parents:
diff changeset
   240
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   241
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   242
    inline TUsbcEndpointStatusCallback(DBase* aOwner, TDfcFn aCallback, TInt aPriority);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   243
    inline void SetState(TUint aState);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   244
    inline TUint State() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   245
    inline DBase* Owner() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   246
    inline TInt DoCallback();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   247
    inline void Cancel();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   248
    inline void SetDfcQ(TDfcQue* aDfcQ);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   249
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   250
    /** Used by the PIL to queue callback objects into a TSglQue. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   251
    TSglQueLink iLink;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   252
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   253
    DBase* iOwner;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   254
    TDfc iDfc;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   255
    TUint iState;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   256
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   257
089413cdde3c 201028_02
hgs
parents:
diff changeset
   258
089413cdde3c 201028_02
hgs
parents:
diff changeset
   259
/** Maximum number of device status requests that can be queued at a time.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   260
    The value chosen is thought to be sufficient in all situations.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   261
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   262
const TInt KUsbcDeviceStateRequests = 8;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   263
089413cdde3c 201028_02
hgs
parents:
diff changeset
   264
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   265
/** The USB device status.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   266
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   267
class TUsbcStatusCallback
089413cdde3c 201028_02
hgs
parents:
diff changeset
   268
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   269
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   270
    inline TUsbcStatusCallback(DBase* aOwner, TDfcFn aCallback, TInt aPriority);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   271
    inline void SetState(UsbShai::TUsbPeripheralState aState);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   272
    inline UsbShai::TUsbPeripheralState State(TInt aIndex) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   273
    inline void ResetState();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   274
    inline DBase* Owner() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   275
    inline TInt DoCallback();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   276
    inline void Cancel();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   277
    inline void SetDfcQ(TDfcQue* aDfcQ);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   278
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   279
    /** Used by the PIL to queue callback objects into a TSglQue. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   280
    TSglQueLink iLink;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   281
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   282
    DBase* iOwner;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   283
    TDfc iDfc;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   284
    UsbShai::TUsbPeripheralState iState[KUsbcDeviceStateRequests];
089413cdde3c 201028_02
hgs
parents:
diff changeset
   285
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   286
089413cdde3c 201028_02
hgs
parents:
diff changeset
   287
089413cdde3c 201028_02
hgs
parents:
diff changeset
   288
/** A USB transfer request.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   289
089413cdde3c 201028_02
hgs
parents:
diff changeset
   290
    @publishedPartner
089413cdde3c 201028_02
hgs
parents:
diff changeset
   291
    @released
089413cdde3c 201028_02
hgs
parents:
diff changeset
   292
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   293
class TUsbcRequestCallback : public UsbShai::TUsbPeripheralRequest
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
    /** @internalTechnology */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   297
    inline TUsbcRequestCallback(const DBase* aOwner, TInt aEndpointNum, TDfcFn aDfcFunc,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   298
                         TAny* aEndpoint, TDfcQue* aDfcQ, TInt aPriority);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   299
    /** @internalTechnology    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   300
    inline ~TUsbcRequestCallback();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   301
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   302
    IMPORT_C void SetRxBufferInfo(TUint8* aBufferStart,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   303
                                      TUintPtr aBufferAddr,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   304
                                      TUint32* aPacketIndex,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   305
                                      TUint32* aPacketSize, 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   306
                                      TInt aLength);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   307
                                    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   308
    IMPORT_C void SetTxBufferInfo(TUint8* aBufferStart, 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   309
                                      TUintPtr aBufferAddr,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   310
                                      TInt aLength);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   311
                                        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   312
    /** @internalTechnology    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   313
    inline void SetTransferDirection(UsbShai::TTransferDirection aTransferDir);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   314
    /** @internalTechnology    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   315
    inline const DBase* Owner() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   316
    /** @internalTechnology    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   317
    inline TInt DoCallback();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   318
    /** @internalTechnology    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   319
    inline void Cancel();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   320
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   321
    /** Used by the PIL to queue callback objects into a TSglQue.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   322
        @internalTechnology
089413cdde3c 201028_02
hgs
parents:
diff changeset
   323
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   324
    TSglQueLink iLink;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   325
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   326
    /** The endpoint number. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   327
    const TInt iEndpointNum;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   328
089413cdde3c 201028_02
hgs
parents:
diff changeset
   329
    /** Indicates the LDD client for this transfer. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   330
    const DBase* const iOwner;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   331
    /** DFC, used by PIL to call back the LDD when transfer completes to the LDD. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   332
    TDfc iDfc;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   333
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   334
089413cdde3c 201028_02
hgs
parents:
diff changeset
   335
/** USB On-The-Go feature change callback.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   336
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   337
class TUsbcOtgFeatureCallback
089413cdde3c 201028_02
hgs
parents:
diff changeset
   338
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   339
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   340
    inline TUsbcOtgFeatureCallback(DBase* aOwner, TDfcFn aCallback, TInt aPriority);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   341
    inline void SetFeatures(TUint8 aFeatures);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   342
    inline TUint8 Features() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   343
    inline DBase* Owner() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   344
    inline TInt DoCallback();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   345
    inline void Cancel();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   346
    inline void SetDfcQ(TDfcQue* aDfcQ);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   347
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   348
    /** Used by the PIL to queue callback objects into a TSglQue. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   349
    TSglQueLink iLink;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   350
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   351
    DBase* iOwner;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   352
    TDfc iDfc;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   353
    TUint8 iValue;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   354
    };
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   355
/** USB Charger Type change callback.
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   356
*/
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   357
class TUsbcChargerTypeCallback
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   358
    {
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   359
public:
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   360
    inline TUsbcChargerTypeCallback (DBase* aOwner, TDfcFn aCallback, TInt aPriority);
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   361
    inline void SetChargerType(TUint aType);
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   362
    inline TUint ChargerType () const;
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   363
	inline void SetPendingNotify(TBool aPendingNotify);
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   364
	inline TBool PendingNotify () const;
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   365
    inline DBase* Owner() const;
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   366
    inline TInt DoCallback();
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   367
    inline void Cancel();
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   368
    inline void SetDfcQ(TDfcQue* aDfcQ);
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   369
public:
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   370
    /** Used by the PIL to queue callback objects into a TSglQue. */
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   371
    TSglQueLink iLink;
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   372
private:
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   373
    DBase* iOwner;
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   374
    TDfc iDfc;
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   375
    TUint iChargerType;
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   376
	TBool iPendingNotify;
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   377
    };
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
   378
089413cdde3c 201028_02
hgs
parents:
diff changeset
   379
//
089413cdde3c 201028_02
hgs
parents:
diff changeset
   380
//########################### Physical Device Driver (PIL + PSL) ######################
089413cdde3c 201028_02
hgs
parents:
diff changeset
   381
//
089413cdde3c 201028_02
hgs
parents:
diff changeset
   382
089413cdde3c 201028_02
hgs
parents:
diff changeset
   383
class TUsbcLogicalEndpoint;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   384
089413cdde3c 201028_02
hgs
parents:
diff changeset
   385
/** This models a physical (real) endpoint of the UDC.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   386
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   387
class TUsbcPhysicalEndpoint
089413cdde3c 201028_02
hgs
parents:
diff changeset
   388
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   389
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   390
    TUsbcPhysicalEndpoint();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   391
    ~TUsbcPhysicalEndpoint();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   392
    TBool EndpointSuitable(const TUsbcEndpointInfo* aEpInfo, TInt aIfcNumber) const; // Check Todo, SC will pass pointer to derived class
089413cdde3c 201028_02
hgs
parents:
diff changeset
   393
    TInt TypeAvailable(TUint aType) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   394
    TInt DirAvailable(TUint aDir) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   395
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   396
    /** This endpoint's capabilities. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   397
    UsbShai::TUsbPeripheralEndpointCaps iCaps;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   398
    /** USB address: 0x00, 0x80, 0x01, 0x81, etc. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   399
    TUint8 iEndpointAddr;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   400
    /** Pointer to interface # this endpoint has been assigned to. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   401
    const TUint8* iIfcNumber;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   402
    /** Pointer to corresponding logical endpoint or NULL. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   403
    const TUsbcLogicalEndpoint* iLEndpoint;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   404
    /** Only used when searching for available endpoints. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   405
    TBool iSettingReserve;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   406
    /** True if endpoint is halted (i.e. issues STALL handshakes), false otherwise. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   407
    TBool iHalt;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   408
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   409
089413cdde3c 201028_02
hgs
parents:
diff changeset
   410
089413cdde3c 201028_02
hgs
parents:
diff changeset
   411
class DUsbClientController;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   412
class TUsbcInterface;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   413
089413cdde3c 201028_02
hgs
parents:
diff changeset
   414
/** This is a 'logical' endpoint, as used by our device configuration model.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   415
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   416
class TUsbcLogicalEndpoint
089413cdde3c 201028_02
hgs
parents:
diff changeset
   417
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   418
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   419
    TUsbcLogicalEndpoint(DUsbClientController* aController, TUint aEndpointNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   420
                         const TUsbcEndpointInfo& aEpInfo, TUsbcInterface* aInterface,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   421
                         TUsbcPhysicalEndpoint* aPEndpoint);        // Check Todo, SC will pass pointer to derived class
089413cdde3c 201028_02
hgs
parents:
diff changeset
   422
    ~TUsbcLogicalEndpoint();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   423
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   424
    /** Pointer to controller object. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   425
    DUsbClientController* iController;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   426
    /** The virtual (logical) endpoint number. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   427
    const TInt iLEndpointNum;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   428
    /** This endpoint's info structure. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   429
    TUsbcEndpointInfo iInfo;                                        // Check Todo, SC will pass pointer to derived class
089413cdde3c 201028_02
hgs
parents:
diff changeset
   430
    /** Stores the endpoint size to be used for FS. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   431
    TInt iEpSize_Fs;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   432
    /** Stores the endpoint size to be used for HS. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   433
    TInt iEpSize_Hs;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   434
    /** 'Back' pointer. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   435
    const TUsbcInterface* iInterface;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   436
    /** Pointer to corresponding physical endpoint, never NULL. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   437
    TUsbcPhysicalEndpoint* const iPEndpoint;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   438
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   439
089413cdde3c 201028_02
hgs
parents:
diff changeset
   440
089413cdde3c 201028_02
hgs
parents:
diff changeset
   441
class TUsbcInterfaceSet;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   442
089413cdde3c 201028_02
hgs
parents:
diff changeset
   443
/** This is an 'alternate setting' of an interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   444
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   445
class TUsbcInterface
089413cdde3c 201028_02
hgs
parents:
diff changeset
   446
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   447
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   448
    TUsbcInterface(TUsbcInterfaceSet* aIfcSet, TUint8 aSetting, TBool aNoEp0Requests);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   449
    ~TUsbcInterface();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   450
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   451
    /** Array of endpoints making up (belonging to) this setting. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   452
    RPointerArray<TUsbcLogicalEndpoint> iEndpoints;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   453
    /** 'Back' pointer. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   454
    TUsbcInterfaceSet* const iInterfaceSet;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   455
    /** bAlternateSetting (zero-based). */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   456
    const TUint8 iSettingCode;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   457
    /** KUsbcInterfaceInfo_NoEp0RequestsPlease: stall non-std Setup requests. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   458
    const TBool iNoEp0Requests;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   459
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   460
089413cdde3c 201028_02
hgs
parents:
diff changeset
   461
089413cdde3c 201028_02
hgs
parents:
diff changeset
   462
/** This is an 'interface' (owning 1 or more alternate settings).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   463
089413cdde3c 201028_02
hgs
parents:
diff changeset
   464
    @see TUsbcInterface
089413cdde3c 201028_02
hgs
parents:
diff changeset
   465
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   466
class TUsbcInterfaceSet
089413cdde3c 201028_02
hgs
parents:
diff changeset
   467
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   468
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   469
    TUsbcInterfaceSet(const DBase* aClientId, TUint8 aIfcNum);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   470
    ~TUsbcInterfaceSet();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   471
    inline const TUsbcInterface* CurrentInterface() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   472
    inline TUsbcInterface* CurrentInterface();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   473
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   474
    /** Array of alternate settings provided by (belonging to) this interface. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   475
    RPointerArray<TUsbcInterface> iInterfaces;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   476
    /** Pointer to the LDD which created and owns this interface. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   477
    const DBase* const iClientId;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   478
    /** bInterfaceNumber (zero-based). */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   479
    TUint8 iInterfaceNumber;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   480
    /** bAlternateSetting (zero-based). */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   481
    TUint8 iCurrentInterface;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   482
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   483
089413cdde3c 201028_02
hgs
parents:
diff changeset
   484
089413cdde3c 201028_02
hgs
parents:
diff changeset
   485
/** This is a 'configuration' of the USB device.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   486
    Currently we support only one configuration.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   487
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   488
class TUsbcConfiguration
089413cdde3c 201028_02
hgs
parents:
diff changeset
   489
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   490
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   491
    TUsbcConfiguration(TUint8 aConfigVal);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   492
    ~TUsbcConfiguration();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   493
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   494
    /** Array of interfaces making up (belonging to) this configuration. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   495
    RPointerArray<TUsbcInterfaceSet> iInterfaceSets;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   496
    /** bConfigurationValue (one-based). */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   497
    const TUint8 iConfigValue;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   498
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   499
089413cdde3c 201028_02
hgs
parents:
diff changeset
   500
089413cdde3c 201028_02
hgs
parents:
diff changeset
   501
/** The USB controller's power handler class.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   502
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   503
NONSHARABLE_CLASS(DUsbcPowerHandler) : public DPowerHandler
089413cdde3c 201028_02
hgs
parents:
diff changeset
   504
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   505
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   506
    void PowerUp();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   507
    void PowerDown(TPowerState);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   508
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   509
    DUsbcPowerHandler(DUsbClientController* aController);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   510
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   511
    DUsbClientController* iController;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   512
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   513
089413cdde3c 201028_02
hgs
parents:
diff changeset
   514
089413cdde3c 201028_02
hgs
parents:
diff changeset
   515
/*
089413cdde3c 201028_02
hgs
parents:
diff changeset
   516
This is the EndpointInfo class used by the usb shared chunk client driver. 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   517
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   518
089413cdde3c 201028_02
hgs
parents:
diff changeset
   519
class TUsbcScEndpointInfo;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   520
089413cdde3c 201028_02
hgs
parents:
diff changeset
   521
089413cdde3c 201028_02
hgs
parents:
diff changeset
   522
/**
089413cdde3c 201028_02
hgs
parents:
diff changeset
   523
Used to represent an array of (or inheriting from) TUsbcEndpointInfo objects.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   524
089413cdde3c 201028_02
hgs
parents:
diff changeset
   525
@see DUsbClientController::SetInterface
089413cdde3c 201028_02
hgs
parents:
diff changeset
   526
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   527
089413cdde3c 201028_02
hgs
parents:
diff changeset
   528
class TUsbcEndpointInfoArray
089413cdde3c 201028_02
hgs
parents:
diff changeset
   529
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   530
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   531
    typedef enum {EUsbcEndpointInfo, EUsbcScEndpointInfo} TArrayType;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   532
089413cdde3c 201028_02
hgs
parents:
diff changeset
   533
    TUsbcEndpointInfoArray(const TUsbcEndpointInfo* aData, TInt aDataSize=0);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   534
    TUsbcEndpointInfoArray(const TUsbcScEndpointInfo* aData, TInt aDataSize=0);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   535
    inline TUsbcEndpointInfo& operator[](TInt aIndex) const; 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   536
089413cdde3c 201028_02
hgs
parents:
diff changeset
   537
    TArrayType iType;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   538
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   539
    TUint8* iData;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   540
    TInt iDataSize;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   541
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   542
089413cdde3c 201028_02
hgs
parents:
diff changeset
   543
class TUsbPeriDeviceEventQueue
089413cdde3c 201028_02
hgs
parents:
diff changeset
   544
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   545
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   546
    TUsbPeriDeviceEventQueue();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   547
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   548
    void FifoAdd(TUsbcDeviceEvent aDeviceStatus);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   549
    TUsbcDeviceEvent FifoGet();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   550
089413cdde3c 201028_02
hgs
parents:
diff changeset
   551
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   552
    TUsbcDeviceEvent iDeviceEventQueue[KUsbDeviceEventQueueDepth];
089413cdde3c 201028_02
hgs
parents:
diff changeset
   553
    TInt iDeviceQueueHead;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   554
    TInt iDeviceQueueTail;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   555
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   556
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   557
class TUsbcRequestCallback; // todo?? required only for class below
089413cdde3c 201028_02
hgs
parents:
diff changeset
   558
089413cdde3c 201028_02
hgs
parents:
diff changeset
   559
/** The USB Device software controller class.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   560
089413cdde3c 201028_02
hgs
parents:
diff changeset
   561
    Implements the platform-independent layer (PIL), and defines the interface to the
089413cdde3c 201028_02
hgs
parents:
diff changeset
   562
    platform-specific layer PSL).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   563
089413cdde3c 201028_02
hgs
parents:
diff changeset
   564
    The implementation of the platform-specific layer interfaces with the hardware.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   565
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
   566
NONSHARABLE_CLASS(DUsbClientController) : public DBase, 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   567
                                          public MUsbOtgPeripheralControlIf,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   568
                                          public UsbShai::MUsbPeripheralPilCallbackIf, 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   569
                                          public MControlTransferIf, 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   570
                                          public UsbShai::MChargerDetectorObserverIf
089413cdde3c 201028_02
hgs
parents:
diff changeset
   571
    {   
089413cdde3c 201028_02
hgs
parents:
diff changeset
   572
    friend class UsbShai::UsbPeripheralPil;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   573
    friend class TUsbHostWrapperEntry;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   574
    friend class DUsbcPowerHandler;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   575
    friend TUsbcLogicalEndpoint::~TUsbcLogicalEndpoint();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   576
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   577
    // --- Platform Independent Layer (PIL) ---
089413cdde3c 201028_02
hgs
parents:
diff changeset
   578
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   579
089413cdde3c 201028_02
hgs
parents:
diff changeset
   580
089413cdde3c 201028_02
hgs
parents:
diff changeset
   581
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   582
    /**
089413cdde3c 201028_02
hgs
parents:
diff changeset
   583
     * Two-phase constructor used by the friend classes that receive
089413cdde3c 201028_02
hgs
parents:
diff changeset
   584
     * the registration calls for peripheral controllers.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   585
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
   586
     * @param aPeripheralControllerIf Reference to the Peripheral
089413cdde3c 201028_02
hgs
parents:
diff changeset
   587
     *   Controller interface implemented by the registering PSL.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   588
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
   589
     * @param aProperties Reference to an object describing the
089413cdde3c 201028_02
hgs
parents:
diff changeset
   590
     *   static properties of the Peripheral Controller. The PIL
089413cdde3c 201028_02
hgs
parents:
diff changeset
   591
     *   layer requires that the supplied reference remains valid
089413cdde3c 201028_02
hgs
parents:
diff changeset
   592
     *   indefinitely, as a Peripheral Controller cannot unregister.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   593
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
   594
     * @param aIsOtgPort ETrue if this Peripheral Controller is part
089413cdde3c 201028_02
hgs
parents:
diff changeset
   595
     *   of an OTG port. EFalse otherwise.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   596
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
   597
     * @return Pointer to a new instance or NULL if failed
089413cdde3c 201028_02
hgs
parents:
diff changeset
   598
     */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   599
    IMPORT_C static DUsbClientController* Create(UsbShai::MPeripheralControllerIf& aPeripheralControllerIf, 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   600
                                                 const UsbShai::TPeripheralControllerProperties& aProperties,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   601
                                                 TBool aIsOtgPort);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   602
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   603
089413cdde3c 201028_02
hgs
parents:
diff changeset
   604
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   605
089413cdde3c 201028_02
hgs
parents:
diff changeset
   606
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   607
    // --- The following functions constitute the PIL interface to the LDD ---
089413cdde3c 201028_02
hgs
parents:
diff changeset
   608
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   609
    virtual ~DUsbClientController();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   610
    IMPORT_C void DisableClientStack();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   611
    IMPORT_C void EnableClientStack();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   612
    IMPORT_C TBool IsActive();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   613
    IMPORT_C TInt RegisterClientCallback(TUsbcClientCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   614
    IMPORT_C static DUsbClientController* UsbcControllerPointer(TInt aUdc=0);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   615
    IMPORT_C void EndpointCaps(const DBase* aClientId, TDes8 &aCapsBuf) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   616
    IMPORT_C void DeviceCaps(const DBase* aClientId, TDes8 &aCapsBuf) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   617
    IMPORT_C TInt SetInterface(const DBase* aClientId, DThread* aThread, TInt aInterfaceNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   618
                               TUsbcClassInfo& aClass, TDesC8* aString, TInt aTotalEndpointsUsed,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   619
                               const TUsbcEndpointInfo aEndpointData[], TInt (*aRealEpNumbers)[6],
089413cdde3c 201028_02
hgs
parents:
diff changeset
   620
                               TUint32 aFeatureWord);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   621
    IMPORT_C TInt SetInterface(const DBase* aClientId, DThread* aThread,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   622
                                                 TInt aInterfaceNum, TUsbcClassInfo& aClass,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   623
                                                 TDesC8* aString, TInt aTotalEndpointsUsed,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   624
                                                 const TUsbcEndpointInfoArray aEndpointData,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   625
                                                 TInt aRealEpNumbers[], TUint32 aFeatureWord);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   626
    IMPORT_C TInt ReleaseInterface(const DBase* aClientId, TInt aInterfaceNum);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   627
    IMPORT_C TInt ReEnumerate();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   628
    IMPORT_C TInt PowerUpUdc();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   629
    IMPORT_C TInt UsbConnect();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   630
    IMPORT_C TInt UsbDisconnect();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   631
    IMPORT_C TInt RegisterForStatusChange(TUsbcStatusCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   632
    IMPORT_C TInt DeRegisterForStatusChange(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   633
    IMPORT_C TInt RegisterForEndpointStatusChange(TUsbcEndpointStatusCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   634
    IMPORT_C TInt DeRegisterForEndpointStatusChange(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   635
    IMPORT_C TInt GetInterfaceNumber(const DBase* aClientId, TInt& aInterfaceNum) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   636
    IMPORT_C TInt DeRegisterClient(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   637
    IMPORT_C TInt Ep0PacketSize() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   638
    IMPORT_C TInt Ep0Stall(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   639
    IMPORT_C void SendEp0StatusPacket(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   640
    IMPORT_C UsbShai::TUsbPeripheralState GetDeviceStatus() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   641
    IMPORT_C TEndpointState GetEndpointStatus(const DBase* aClientId, TInt aEndpointNum) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   642
    IMPORT_C TInt SetupReadBuffer(TUsbcRequestCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   643
    IMPORT_C TInt SetupWriteBuffer(TUsbcRequestCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   644
    IMPORT_C void CancelReadBuffer(const DBase* aClientId, TInt aRealEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   645
    IMPORT_C void CancelWriteBuffer(const DBase* aClientId, TInt aRealEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   646
    IMPORT_C TInt HaltEndpoint(const DBase* aClientId, TInt aEndpointNum);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   647
    IMPORT_C TInt ClearHaltEndpoint(const DBase* aClientId, TInt aEndpointNum);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   648
    IMPORT_C TInt SetDeviceControl(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   649
    IMPORT_C TInt ReleaseDeviceControl(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   650
    IMPORT_C TUint EndpointZeroMaxPacketSizes() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   651
    IMPORT_C TInt SetEndpointZeroMaxPacketSize(TInt aMaxPacketSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   652
    IMPORT_C TInt GetDeviceDescriptor(DThread* aThread, TDes8& aDeviceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   653
    IMPORT_C TInt SetDeviceDescriptor(DThread* aThread, const TDes8& aDeviceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   654
    IMPORT_C TInt GetDeviceDescriptorSize(DThread* aThread, TDes8& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   655
    IMPORT_C TInt GetConfigurationDescriptor(DThread* aThread, TDes8& aConfigurationDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   656
    IMPORT_C TInt SetConfigurationDescriptor(DThread* aThread, const TDes8& aConfigurationDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   657
    IMPORT_C TInt GetConfigurationDescriptorSize(DThread* aThread, TDes8& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   658
    IMPORT_C TInt SetOtgDescriptor(DThread* aThread, const TDesC8& aOtgDesc);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   659
    IMPORT_C TInt GetOtgDescriptor(DThread* aThread, TDes8& aOtgDesc) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   660
    IMPORT_C TInt GetOtgFeatures(DThread* aThread, TDes8& aFeatures) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   661
    IMPORT_C TInt GetCurrentOtgFeatures(TUint8& aFeatures) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   662
    IMPORT_C TInt RegisterForOtgFeatureChange(TUsbcOtgFeatureCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   663
    IMPORT_C TInt DeRegisterForOtgFeatureChange(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   664
    IMPORT_C TInt GetInterfaceDescriptor(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   665
                                         TDes8& aInterfaceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   666
    IMPORT_C TInt SetInterfaceDescriptor(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   667
                                         const TDes8& aInterfaceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   668
    IMPORT_C TInt GetInterfaceDescriptorSize(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   669
                                             TDes8& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   670
    IMPORT_C TInt GetEndpointDescriptor(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   671
                                        TInt aEndpointNum, TDes8& aEndpointDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   672
    IMPORT_C TInt SetEndpointDescriptor(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   673
                                        TInt aEndpointNum, const TDes8& aEndpointDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   674
    IMPORT_C TInt GetEndpointDescriptorSize(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   675
                                            TInt aEndpointNum, TDes8& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   676
    IMPORT_C TInt GetDeviceQualifierDescriptor(DThread* aThread, TDes8& aDeviceQualifierDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   677
    IMPORT_C TInt SetDeviceQualifierDescriptor(DThread* aThread, const TDes8& aDeviceQualifierDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   678
    IMPORT_C TInt GetOtherSpeedConfigurationDescriptor(DThread* aThread, TDes8& aConfigurationDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   679
    IMPORT_C TInt SetOtherSpeedConfigurationDescriptor(DThread* aThread, const TDes8& aConfigurationDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   680
    IMPORT_C TInt GetCSInterfaceDescriptorBlock(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   681
                                                TDes8& aInterfaceDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   682
    IMPORT_C TInt SetCSInterfaceDescriptorBlock(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   683
                                                const TDes8& aInterfaceDescriptor, TInt aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   684
    IMPORT_C TInt GetCSInterfaceDescriptorBlockSize(DThread* aThread, const DBase* aClientId,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   685
                                                    TInt aSettingNum, TDes8& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   686
    IMPORT_C TInt GetCSEndpointDescriptorBlock(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   687
                                               TInt aEndpointNum, TDes8& aEndpointDescriptor);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   688
    IMPORT_C TInt SetCSEndpointDescriptorBlock(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   689
                                               TInt aEndpointNum, const TDes8& aEndpointDescriptor,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   690
                                               TInt aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   691
    IMPORT_C TInt GetCSEndpointDescriptorBlockSize(DThread* aThread, const DBase* aClientId, TInt aSettingNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   692
                                                   TInt aEndpointNum, TDes8& aSize);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   693
    IMPORT_C TInt GetStringDescriptorLangId(DThread* aThread, TDes8& aLangId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   694
    IMPORT_C TInt SetStringDescriptorLangId(TUint16 aLangId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   695
    IMPORT_C TInt GetManufacturerStringDescriptor(DThread* aThread, TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   696
    IMPORT_C TInt SetManufacturerStringDescriptor(DThread* aThread, const TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   697
    IMPORT_C TInt RemoveManufacturerStringDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   698
    IMPORT_C TInt GetProductStringDescriptor(DThread* aThread, TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   699
    IMPORT_C TInt SetProductStringDescriptor(DThread* aThread, const TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   700
    IMPORT_C TInt RemoveProductStringDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   701
    IMPORT_C TInt GetSerialNumberStringDescriptor(DThread* aThread, TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   702
    IMPORT_C TInt SetSerialNumberStringDescriptor(DThread* aThread, const TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   703
    IMPORT_C TInt RemoveSerialNumberStringDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   704
    IMPORT_C TInt GetConfigurationStringDescriptor(DThread* aThread, TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   705
    IMPORT_C TInt SetConfigurationStringDescriptor(DThread* aThread, const TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   706
    IMPORT_C TInt RemoveConfigurationStringDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   707
    IMPORT_C TInt GetStringDescriptor(DThread* aThread, TUint8 aIndex, TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   708
    IMPORT_C TInt SetStringDescriptor(DThread* aThread, TUint8 aIndex, const TDes8& aString);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   709
    IMPORT_C TInt RemoveStringDescriptor(TUint8 aIndex);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   710
    IMPORT_C TBool QueryEndpointResource(const DBase* aClientId, TInt aEndpointNum,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   711
                                         TUsbcEndpointResource aResource);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   712
    IMPORT_C TInt EndpointPacketSize(const DBase* aClientId, TInt aEndpointNum);
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   713
    IMPORT_C TInt RegisterChargingPortTypeNotify(TUsbcChargerTypeCallback& aCallback);
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   714
    IMPORT_C TInt DeRegisterChargingPortTypeNotify(const DBase* aClientId);
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   715
	IMPORT_C void ChargerDetectorCaps(UsbShai::TChargerDetectorProperties& aProperties);
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
   716
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   717
    // Called by LDD
089413cdde3c 201028_02
hgs
parents:
diff changeset
   718
    IMPORT_C TDfcQue*  DfcQ(TInt aIndex);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   719
    IMPORT_C void DumpRegisters();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   720
    IMPORT_C TInt SignalRemoteWakeup();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   721
    IMPORT_C TBool CurrentlyUsingHighSpeed();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   722
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   723
    TInt RegisterUdc(TInt aUdc);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   724
089413cdde3c 201028_02
hgs
parents:
diff changeset
   725
protected:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   726
089413cdde3c 201028_02
hgs
parents:
diff changeset
   727
    // From base class MUsbPeripheralPilCallbackIf
089413cdde3c 201028_02
hgs
parents:
diff changeset
   728
    void EnablePeripheralStack();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   729
    void DisablePeripheralStack();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   730
    void SetOtgObserver(MUsbOtgPeripheralObserverIf* aObserver);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   731
089413cdde3c 201028_02
hgs
parents:
diff changeset
   732
    // Function derived from MUsbPeripheralPilCallbackIf
089413cdde3c 201028_02
hgs
parents:
diff changeset
   733
    UsbShai::TControlStage EnquireEp0NextStage(const TUint8* aSetupBuf) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   734
    TInt Ep0RequestComplete(TInt aRealEndpoint, TInt aCount, TInt aError,UsbShai::TControlPacketType aPktType);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   735
    void EndpointRequestComplete(UsbShai::TUsbPeripheralRequest* aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   736
    TInt DeviceEventNotification(TUsbcDeviceEvent aEvent);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   737
    void MoveToAddressState();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   738
    TInt ProcessSetConfiguration(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   739
    void HandleHnpRequest(TInt aHnpState);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   740
    void GetEp0RxBufferInfo(TUint8*& aBuffer, TInt& aBufferLen); 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   741
    void SetRmWakeupStatusEnabled(TBool aRmEnabled);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   742
    UsbShai::TUsbPeripheralState DeviceStatus() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   743
    TBool Ep0ReceivedNonStdRequest();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   744
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   745
    // Functions derived from MControlTransferIf
089413cdde3c 201028_02
hgs
parents:
diff changeset
   746
    // PSL -> PIL
089413cdde3c 201028_02
hgs
parents:
diff changeset
   747
    void ProcessDataInPacket(TInt aCount,TInt aErrCode);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   748
    void ProcessStatusInPacket(TInt aErrCode);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   749
    void ProcessDataOutPacket(TInt aCount,TInt aErrCode);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   750
    void ProcessStatusOutPacket(TInt aErrCode);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   751
    void ProcessSetupPacket(TInt aCount,TInt aErrCode);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   752
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   753
    // Request from PIL -> PSL
089413cdde3c 201028_02
hgs
parents:
diff changeset
   754
    TInt ProcessSetupEndpointZeroRead();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   755
    TInt ProcessSetupEndpointZeroWrite(const TUint8* aBuffer, TInt aLength, TBool aZlpReqd=EFalse);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   756
    TInt ProcessSendEp0ZeroByteStatusPacket();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   757
    TInt ProcessStallEndpoint(TInt aRealEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   758
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   759
    // Flow control PIL <--> PSL
089413cdde3c 201028_02
hgs
parents:
diff changeset
   760
    void ProcessEp0SetupPacketProceed();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   761
    void ProcessEp0DataPacketProceed();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   762
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   763
    // Functions from MChargerDetectorObserverIf
089413cdde3c 201028_02
hgs
parents:
diff changeset
   764
    void NotifyPortType(UsbShai::TPortType aPortType);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   765
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   766
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   767
    // --- Functions and data members provided by PIL, called by PSL ---
089413cdde3c 201028_02
hgs
parents:
diff changeset
   768
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   769
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   770
    struct TUsbPeripheralDescriptorPool
089413cdde3c 201028_02
hgs
parents:
diff changeset
   771
        {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   772
        TUsbcDeviceDescriptor* iDeviceDesc;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   773
        TUsbcConfigDescriptor* iConfigDesc;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   774
        TUsbcLangIdDescriptor* iLangId;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   775
        TUsbcStringDescriptor* iManufacturer;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   776
        TUsbcStringDescriptor* iProduct;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   777
        TUsbcStringDescriptor* iSerialNum;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   778
        TUsbcStringDescriptor* iConfig;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   779
        TUsbcOtgDescriptor* iOtgDesc;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   780
        };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   781
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   782
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   783
    // Internal functions that used in Construct only
089413cdde3c 201028_02
hgs
parents:
diff changeset
   784
    // This function will new a set of descriptors
089413cdde3c 201028_02
hgs
parents:
diff changeset
   785
    TBool CreateDescriptors(TUsbPeripheralDescriptorPool& aOutput);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   786
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   787
    TBool Initialise(TUsbPeripheralDescriptorPool& aDescPool,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   788
                     const UsbShai::TUsbPeripheralEndpointCaps* aEndpointCaps,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   789
                     TInt aTotalEndpoint);                    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   790
089413cdde3c 201028_02
hgs
parents:
diff changeset
   791
    DUsbClientController(UsbShai::MPeripheralControllerIf&               aPeripheralControllerIf, 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   792
                         const UsbShai::TPeripheralControllerProperties& aProperties,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   793
                         TBool                                  aIsOtgPort);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   794
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   795
    TInt Construct();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   796
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   797
    void ProcessStandardRequest(TInt aCount,const TUsbcSetup& aPacket);    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   798
    void ProcessNonStandardRequest(TInt aCount,const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   799
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   800
    const DBase* FindNonStandardRequestClient(TUint8 aPacketTypeDestination,const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   801
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   802
    TInt SetupEp0StateMachine();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   803
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   804
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   805
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   806
    /** This info can be used by the PSL before sending ZLPs.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   807
089413cdde3c 201028_02
hgs
parents:
diff changeset
   808
        @publishedPartner @released
089413cdde3c 201028_02
hgs
parents:
diff changeset
   809
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   810
    TBool iEp0ReceivedNonStdRequest;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   811
089413cdde3c 201028_02
hgs
parents:
diff changeset
   812
    /** True if RMW is currently enabled (set by either PIL or PSL).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   813
089413cdde3c 201028_02
hgs
parents:
diff changeset
   814
        @publishedPartner @released
089413cdde3c 201028_02
hgs
parents:
diff changeset
   815
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   816
    TBool iRmWakeupStatus_Enabled;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   817
089413cdde3c 201028_02
hgs
parents:
diff changeset
   818
    /** Ep0 incoming (rx) data is placed here (one packet).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   819
089413cdde3c 201028_02
hgs
parents:
diff changeset
   820
        @publishedPartner @released
089413cdde3c 201028_02
hgs
parents:
diff changeset
   821
    */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   822
    TUint8 iEp0_RxBuf[KUsbcBufSzControl];
089413cdde3c 201028_02
hgs
parents:
diff changeset
   823
089413cdde3c 201028_02
hgs
parents:
diff changeset
   824
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   825
089413cdde3c 201028_02
hgs
parents:
diff changeset
   826
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   827
    // --- Private member functions (used by PIL) ---
089413cdde3c 201028_02
hgs
parents:
diff changeset
   828
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   829
    TInt DeRegisterClientCallback(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   830
    TBool CheckEpAvailability(TInt aEndpointsUsed, const TUsbcEndpointInfoArray& aEndpointData, TInt aIfcNumber)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   831
        const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   832
    TUsbcInterface* CreateInterface(const DBase* aClientId, TInt aIfc, TUint32 aFeatureWord);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   833
    TInt CreateEndpoints(TUsbcInterface* aIfc, TInt aEndpointsUsed, const TUsbcEndpointInfoArray& aEndpointData,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   834
                         TInt *aRealEpNumbers);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   835
    TInt SetupIfcDescriptor(TUsbcInterface* aIfc, TUsbcClassInfo& aClass, DThread* aThread, TDesC8* aString,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   836
                            const TUsbcEndpointInfoArray& aEndpointData);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   837
    TInt ClientId2InterfaceNumber(const DBase* aClientId) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   838
    TUsbcInterfaceSet* ClientId2InterfacePointer(const DBase* aClientId) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   839
    const DBase* InterfaceNumber2ClientId(TInt aIfcSet) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   840
    TUsbcInterfaceSet* InterfaceNumber2InterfacePointer(TInt aIfcSet) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   841
    inline const DBase* PEndpoint2ClientId(TInt aRealEndpoint) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   842
    inline TInt PEndpoint2LEndpoint(TInt aRealEndpoint) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   843
    TInt ActivateHardwareController();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   844
    void DeActivateHardwareController();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   845
    void DeleteInterfaceSet(TInt aIfcSet);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   846
    void DeleteInterface(TInt aIfcSet, TInt aIfc);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   847
    void CancelTransferRequests(TInt aRealEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   848
    void DeleteRequestCallback(const DBase* aClientId, TInt aEndpointNum, UsbShai::TTransferDirection aTransferDir);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   849
    void DeleteRequestCallbacks(const DBase* aClientId);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   850
    void StatusNotify(UsbShai::TUsbPeripheralState aState, const DBase* aClientId=NULL);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   851
    void EpStatusNotify(TInt aRealEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   852
    void OtgFeaturesNotify();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   853
    void RunClientCallbacks();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   854
    void ProcessDataTransferDone(TUsbcRequestCallback& aRcb);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   855
    void NextDeviceState(UsbShai::TUsbPeripheralState aNextState);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   856
    TInt ProcessSuspendEvent();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   857
    TInt ProcessSuspendEventProceed();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   858
    TInt ProcessResumeEvent();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   859
    TInt ProcessResetEvent(TBool aPslUpcall=ETrue);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   860
    TInt ProcessVbusRisenEvent();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   861
    TInt ProcessVbusFallenEvent();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   862
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   863
    void ProcessGetDeviceStatus(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   864
    void ProcessGetInterfaceStatus(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   865
    void ProcessGetEndpointStatus(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   866
    void ProcessSetClearDevFeature(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   867
    void ProcessSetClearIfcFeature(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   868
    void ProcessSetClearEpFeature(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   869
    void ProcessSetAddress(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   870
    void ProcessGetDescriptor(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   871
    void ProcessSetDescriptor(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   872
    void ProcessGetConfiguration(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   873
    void ProcessGetInterface(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   874
    void ProcessSetInterface(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   875
    void ProcessSynchFrame(const TUsbcSetup& aPacket);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   876
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   877
    void ProceedSetDescriptor();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   878
    void ProcessDeviceEventNotification(TUsbcDeviceEvent aEvent);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   879
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   880
    void SetClearHaltFeature(TInt aRealEndpoint, TUint8 aRequest);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   881
    TInt ClearHaltFeature(TInt aRealEndpoint);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   882
    void ChangeConfiguration(TUint16 aValue);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   883
    void InterfaceSetup(TUsbcInterface* aIfc);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   884
    void InterfaceSetTeardown(TUsbcInterfaceSet* aIfc);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   885
    void ChangeInterface(TUsbcInterface* aIfc);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   886
    TInt DoForEveryEndpointInUse(TInt (DUsbClientController::*aFunction)(TInt), TInt& aCount);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   887
    void EnterFullSpeed();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   888
    void EnterHighSpeed();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   889
    TInt EvaluateOtgConnectFlags();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   890
    inline const TUsbcConfiguration* CurrentConfig() const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   891
    inline TUsbcConfiguration* CurrentConfig();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   892
    inline TBool InterfaceExists(TInt aNumber) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   893
    inline TBool EndpointExists(TUint aAddress) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   894
    void Buffer2Setup(const TAny* aBuf, TUsbcSetup& aSetup) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   895
    inline TUint EpIdx2Addr(TUint aRealEndpoint) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   896
    inline TUint EpAddr2Idx(TUint aAddress) const;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   897
    inline void SetEp0DataOutVars(const DBase* aClientId = NULL);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   898
    inline void ResetEp0DataOutVars();
089413cdde3c 201028_02
hgs
parents:
diff changeset
   899
    inline TBool IsInTheStatusList(const TUsbcStatusCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   900
    inline TBool IsInTheEpStatusList(const TUsbcEndpointStatusCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   901
    inline TBool IsInTheOtgFeatureList(const TUsbcOtgFeatureCallback& aCallback);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   902
    inline TBool IsInTheRequestList(const TUsbcRequestCallback& aCallback);
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   903
    inline TBool IsInTheChargerTypeList(const TUsbcChargerTypeCallback& aCallback);
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
   904
    static void ReconnectTimerCallback(TAny* aPtr);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   905
    static void CableStatusTimerCallback(TAny* aPtr);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   906
    static void PowerUpDfc(TAny* aPtr);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   907
    static void PowerDownDfc(TAny* aPtr);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   908
    static void DeviceEventNotifyDfc(TAny* aPtr);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   909
    static void ThreadContextFinderDfc(TAny* aPtr);
089413cdde3c 201028_02
hgs
parents:
diff changeset
   910
089413cdde3c 201028_02
hgs
parents:
diff changeset
   911
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   912
089413cdde3c 201028_02
hgs
parents:
diff changeset
   913
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   914
    // --- Private data members ---
089413cdde3c 201028_02
hgs
parents:
diff changeset
   915
    //
089413cdde3c 201028_02
hgs
parents:
diff changeset
   916
089413cdde3c 201028_02
hgs
parents:
diff changeset
   917
    static DUsbClientController* UsbClientController[KUsbcMaxUdcs];
089413cdde3c 201028_02
hgs
parents:
diff changeset
   918
089413cdde3c 201028_02
hgs
parents:
diff changeset
   919
    TInt iDeviceTotalEndpoints;                                 // number of endpoints reported by PSL
089413cdde3c 201028_02
hgs
parents:
diff changeset
   920
    TInt iDeviceUsableEndpoints;                                // number of endpoints reported to LDD
089413cdde3c 201028_02
hgs
parents:
diff changeset
   921
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   922
    UsbShai::TUsbPeripheralState iDeviceState;                              // states as of USB spec chapter 9.1
089413cdde3c 201028_02
hgs
parents:
diff changeset
   923
    UsbShai::TUsbPeripheralState iDeviceStateB4Suspend;                     // state before entering suspend state
089413cdde3c 201028_02
hgs
parents:
diff changeset
   924
089413cdde3c 201028_02
hgs
parents:
diff changeset
   925
    TBool iSelfPowered;                                         // true if device is capable of beeing self-powered
089413cdde3c 201028_02
hgs
parents:
diff changeset
   926
    TBool iRemoteWakeup;                                        // true if device is capable of signalling rmwakeup
089413cdde3c 201028_02
hgs
parents:
diff changeset
   927
    TBool iHardwareActivated;                                   // true if controller silicon is in operating state
089413cdde3c 201028_02
hgs
parents:
diff changeset
   928
    TBool iOtgSupport;                                          // true if OTG is supported by this device
089413cdde3c 201028_02
hgs
parents:
diff changeset
   929
    TUint8 iOtgFuncMap;                                         // bitmap indicating OTG extension features
089413cdde3c 201028_02
hgs
parents:
diff changeset
   930
    TBool iHighSpeed;                                           // true if currently operating at high-speed
089413cdde3c 201028_02
hgs
parents:
diff changeset
   931
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   932
    TInt iEp0MaxPacketSize;                                     // currently configured max packet size for Ep0    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   933
    const DBase* iEp0ClientId;                                  // see comment at the begin of ps_usbc.cpp
089413cdde3c 201028_02
hgs
parents:
diff changeset
   934
    TUint16 iEp0DataReceived;                                   // indicates how many bytes have already been received
089413cdde3c 201028_02
hgs
parents:
diff changeset
   935
    TBool iEp0WritePending;                                     // true if a write on ep0 has been set up
089413cdde3c 201028_02
hgs
parents:
diff changeset
   936
    TBool iEp0ClientDataTransmitting;                           // true if ep0's in DATA_IN on behalf of a client
089413cdde3c 201028_02
hgs
parents:
diff changeset
   937
    const DBase* iEp0DeviceControl;                             // Device Ep0 requests are delivered to this LDD
089413cdde3c 201028_02
hgs
parents:
diff changeset
   938
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   939
    TUsbcDescriptorPool iDescriptors;                           // the descriptors as of USB spec chapter 9.5
089413cdde3c 201028_02
hgs
parents:
diff changeset
   940
    TUint8 iCurrentConfig;                                      // bConfigurationValue of current Config (1-based!)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   941
    RPointerArray<TUsbcConfiguration> iConfigs;                 // the root of the modelled USB device
089413cdde3c 201028_02
hgs
parents:
diff changeset
   942
    TUsbcPhysicalEndpoint iRealEndpoints[KUsbcEpArraySize];     // array will be filled once at startup
089413cdde3c 201028_02
hgs
parents:
diff changeset
   943
    TUint8 iEp0_TxBuf[KUsbcBufSz_Ep0Tx];                        // ep0 outgoing (tx) data is placed here
089413cdde3c 201028_02
hgs
parents:
diff changeset
   944
#ifdef USB_SUPPORTS_SET_DESCRIPTOR_REQUEST
089413cdde3c 201028_02
hgs
parents:
diff changeset
   945
    TUint8 iEp0_RxCollectionBuf[KUsbcBufSz_Ep0Rx];              // used for (optional) SET_DESCRIPTOR request
089413cdde3c 201028_02
hgs
parents:
diff changeset
   946
#endif
089413cdde3c 201028_02
hgs
parents:
diff changeset
   947
    TInt iEp0_RxExtraCount;                                     // number of bytes received but not yet delivered
089413cdde3c 201028_02
hgs
parents:
diff changeset
   948
    TBool iEp0_RxExtraData;                                     // true if iEp0_RxExtraCount is valid
089413cdde3c 201028_02
hgs
parents:
diff changeset
   949
    TInt iEp0_TxNonStdCount;                                    // number of bytes requested by non-std Ep0 request
089413cdde3c 201028_02
hgs
parents:
diff changeset
   950
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   951
    TUsbcRequestCallback* iRequestCallbacks[KUsbcEpArraySize];  // xfer requests; indexed by real ep number
089413cdde3c 201028_02
hgs
parents:
diff changeset
   952
    TSglQue<TUsbcRequestCallback> iEp0ReadRequestCallbacks;     // list of ep0 read requests
089413cdde3c 201028_02
hgs
parents:
diff changeset
   953
    TSglQue<TUsbcClientCallback> iClientCallbacks;              // registered LDD clients and their callback functions
089413cdde3c 201028_02
hgs
parents:
diff changeset
   954
    TSglQue<TUsbcStatusCallback> iStatusCallbacks;              // list of device state notification requests
089413cdde3c 201028_02
hgs
parents:
diff changeset
   955
    TSglQue<TUsbcEndpointStatusCallback> iEpStatusCallbacks;    // list of endpoint state notification requests
089413cdde3c 201028_02
hgs
parents:
diff changeset
   956
    TSglQue<TUsbcOtgFeatureCallback> iOtgCallbacks;             // list of OTG feature change requests
089413cdde3c 201028_02
hgs
parents:
diff changeset
   957
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   958
    NTimer iReconnectTimer;                                     // implements USB re-enumeration delay
089413cdde3c 201028_02
hgs
parents:
diff changeset
   959
    NTimer iCableStatusTimer;                                   // implements USB cable status detection delay
089413cdde3c 201028_02
hgs
parents:
diff changeset
   960
    DUsbcPowerHandler* iPowerHandler;                           // pointer to USB power handler object
089413cdde3c 201028_02
hgs
parents:
diff changeset
   961
    TSpinLock iUsbLock;                                         // implement SMP for USB PDD and LDD
089413cdde3c 201028_02
hgs
parents:
diff changeset
   962
    NFastMutex iMutex;                                          // To pretect interface set with NFastMutex
089413cdde3c 201028_02
hgs
parents:
diff changeset
   963
    UsbShai::MPeripheralControllerIf& iController;              // PSL code
089413cdde3c 201028_02
hgs
parents:
diff changeset
   964
    
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
   965
    const UsbShai::TPeripheralControllerProperties iControllerProperties;   // Static configuration from PSL
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
   966
    TBool iIsOtgPort;                                               // Is this instance a driver for otg port,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   967
                                                                    // Set at construction time.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   968
089413cdde3c 201028_02
hgs
parents:
diff changeset
   969
    /**
089413cdde3c 201028_02
hgs
parents:
diff changeset
   970
     * Pointer to the currently set OTG Observer, if any. Not owned.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   971
     */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   972
	MUsbOtgPeripheralObserverIf* iOtgObserver;  // Otg interface which is used to listen event from DeviceEventNotification
089413cdde3c 201028_02
hgs
parents:
diff changeset
   973
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   974
    DControlTransferManager* iConTransferMgr;    // Usb Control transfer manager, responsible for chaptor9
089413cdde3c 201028_02
hgs
parents:
diff changeset
   975
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   976
    TInt iLastError;                            // Used by chaptor9 sm. No else.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   977
    TBool iSetupPacketPending;                  // Indicate whether the no-req-callback data is a setup packet
089413cdde3c 201028_02
hgs
parents:
diff changeset
   978
                                                            
089413cdde3c 201028_02
hgs
parents:
diff changeset
   979
    TUsbPeriDeviceEventQueue iDevEventQueue;    // PSL can call DeviceEventNotification(...) at any context, 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   980
                                                // but for PIL, we want to serialize the execution of each event
089413cdde3c 201028_02
hgs
parents:
diff changeset
   981
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   982
    // The thread context for the DfcQ pass by PSL to us.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   983
    NThread* iCommonDfcQThread;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   984
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   985
protected:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   986
    TDfc iPowerUpDfc;                         // queued by power handler upon power-up
089413cdde3c 201028_02
hgs
parents:
diff changeset
   987
    TDfc iPowerDownDfc;                       // queued by power handler upon power-down
089413cdde3c 201028_02
hgs
parents:
diff changeset
   988
    TDfc iDeviceEventNotifyDfc;               // queued by device event notification
089413cdde3c 201028_02
hgs
parents:
diff changeset
   989
    TDfc iThreadContextFinder;                // this is used to find which thread does the DfcQ passed by PSL
089413cdde3c 201028_02
hgs
parents:
diff changeset
   990
                                              // is runing.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   991
089413cdde3c 201028_02
hgs
parents:
diff changeset
   992
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   993
    TBool iStandby;                           // toggled by power handler as appropriate
089413cdde3c 201028_02
hgs
parents:
diff changeset
   994
    TBool iStackIsActive;                     // client stack's function is usable
089413cdde3c 201028_02
hgs
parents:
diff changeset
   995
    TBool iClientSupportReady;                // user-side USB Client support is loaded & active
089413cdde3c 201028_02
hgs
parents:
diff changeset
   996
    TBool iUsbResetDeferred;                  // set when user-side wasn't ready yet
089413cdde3c 201028_02
hgs
parents:
diff changeset
   997
089413cdde3c 201028_02
hgs
parents:
diff changeset
   998
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   999
    // FIXME: These used to be filled by the OTG component Dummy DCD
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1000
    // so that the PIL layer can call it to enable and disable the D+
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1001
    // pull-up. This mechanism is no longer used
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1002
    TInt (*iEnablePullUpOnDPlus)(TAny* aOtgContext);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1003
    TInt (*iDisablePullUpOnDPlus)(TAny* aOtgContext);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1004
    TAny* iOtgContext;
48
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1005
private:	
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1006
    TSglQue<TUsbcChargerTypeCallback> iChargerTypeCallbacks;  // list of USB charger type notification requests
21625e5de155 201035_01
hgs
parents: 33
diff changeset
  1007
    TUint iCurrentChargerType;
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1008
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1009
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1010
/** Simple queue of status changes to be recorded.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1011
    Items are fetched by userside when able.
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1012
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1013
class TUsbcDeviceStatusQueue
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1014
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1015
public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1016
    TUsbcDeviceStatusQueue();
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1017
    void AddStatusToQueue(TUint32 aDeviceStatus);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1018
    TInt GetDeviceQueuedStatus(TUint32& aDeviceStatus);
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1019
    void FlushQueue();
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1020
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1021
private:
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1022
    TUint32 iDeviceStatusQueue[KUsbDeviceStatusQueueDepth];
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1023
    TInt iStatusQueueHead;
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1024
    };
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1025
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1026
#include <usb/usbcshared.inl>
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1027
089413cdde3c 201028_02
hgs
parents:
diff changeset
  1028
#endif    // __USBCSHARED_H__