usb_plat/usb_shai_api/inc/usb_peripheral_shai_shared.h
author hgs
Fri, 23 Jul 2010 15:54:47 +0800
changeset 33 089413cdde3c
child 48 21625e5de155
permissions -rw-r--r--
201028_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
089413cdde3c 201028_02
hgs
parents:
diff changeset
     1
/*
089413cdde3c 201028_02
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
089413cdde3c 201028_02
hgs
parents:
diff changeset
     3
* All rights reserved.
089413cdde3c 201028_02
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
089413cdde3c 201028_02
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
089413cdde3c 201028_02
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
089413cdde3c 201028_02
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
089413cdde3c 201028_02
hgs
parents:
diff changeset
     8
*
089413cdde3c 201028_02
hgs
parents:
diff changeset
     9
* Initial Contributors:
089413cdde3c 201028_02
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    11
*
089413cdde3c 201028_02
hgs
parents:
diff changeset
    12
* Contributors:
089413cdde3c 201028_02
hgs
parents:
diff changeset
    13
*
089413cdde3c 201028_02
hgs
parents:
diff changeset
    14
* Description: 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    15
*
089413cdde3c 201028_02
hgs
parents:
diff changeset
    16
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    17
089413cdde3c 201028_02
hgs
parents:
diff changeset
    18
/** @file
089413cdde3c 201028_02
hgs
parents:
diff changeset
    19
089413cdde3c 201028_02
hgs
parents:
diff changeset
    20
    @brief USB Peripheral SHAI header shared part.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    21
089413cdde3c 201028_02
hgs
parents:
diff changeset
    22
    Some Non-kernel USB code will also use structure defined in this
089413cdde3c 201028_02
hgs
parents:
diff changeset
    23
    header.  Since usb_peripheral_shai.h always need to include
089413cdde3c 201028_02
hgs
parents:
diff changeset
    24
    <kern_priv.h> which is not visible to non-kernel layers, a
089413cdde3c 201028_02
hgs
parents:
diff changeset
    25
    separated header is needed.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    26
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
    27
    This header is the one that defined all common structures used by
089413cdde3c 201028_02
hgs
parents:
diff changeset
    28
    kernel & non-kernel layers software.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    29
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
    30
    Peripheral SHAI header always include this header automatically.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    31
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
    32
    @publishedDeviceAbstraction
089413cdde3c 201028_02
hgs
parents:
diff changeset
    33
*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    34
089413cdde3c 201028_02
hgs
parents:
diff changeset
    35
#ifndef USB_PERIPHERAL_SHAI_SHARED_H
089413cdde3c 201028_02
hgs
parents:
diff changeset
    36
#define USB_PERIPHERAL_SHAI_SHARED_H
089413cdde3c 201028_02
hgs
parents:
diff changeset
    37
089413cdde3c 201028_02
hgs
parents:
diff changeset
    38
// The namespace is documented in file usb_common_shai.h, so it is not
089413cdde3c 201028_02
hgs
parents:
diff changeset
    39
// repeated here
089413cdde3c 201028_02
hgs
parents:
diff changeset
    40
namespace UsbShai
089413cdde3c 201028_02
hgs
parents:
diff changeset
    41
    {
089413cdde3c 201028_02
hgs
parents:
diff changeset
    42
    /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    43
     * Bitmaps for TUsbPeripheralEndpointCaps.iSupportedTypesAndDir.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    44
     * Endpoint supports Control transfer type.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    45
     */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    46
    const TUint KUsbEpTypeControl     = 0x00000001;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    47
    const TUint KUsbEpTypeIsochronous = 0x00000002;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    48
    const TUint KUsbEpTypeBulk        = 0x00000004;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    49
    const TUint KUsbEpTypeInterrupt   = 0x00000008;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    50
089413cdde3c 201028_02
hgs
parents:
diff changeset
    51
    /** Endpoint supports IN transfers. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    52
    const TUint KUsbEpDirIn           = 0x80000000;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    53
    /** Endpoint supports OUT transfers. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    54
    const TUint KUsbEpDirOut          = 0x40000000;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    55
    /** Endpoint supports bidirectional (Control) transfers only.*/
089413cdde3c 201028_02
hgs
parents:
diff changeset
    56
    const TUint KUsbEpDirBidirect     = 0x20000000;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    57
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
    58
    /**
089413cdde3c 201028_02
hgs
parents:
diff changeset
    59
     * Indicates that whether DMA is preferred to be applied for this endpoint.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    60
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
    61
     * Upper application will declare whether DMA is expected to be used for
089413cdde3c 201028_02
hgs
parents:
diff changeset
    62
     * this endpoint if there is one available (PSL knows about it) when setup
089413cdde3c 201028_02
hgs
parents:
diff changeset
    63
     * an interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    64
     * 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    65
     * PSL can ignore this request if NO DMA is available.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    66
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
    67
     * PIL may query whether a DMA is really applied via interface 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    68
     * MPeripheralControllerIf::QueryEndpointResource() later.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    69
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
    70
     * @see TUsbPeripheralEndpointInfo::iFeatureWord1.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    71
     */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    72
    const TUint KUsbEndpointInfoFeatureWord1_DMA             = 0x00000001;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    73
089413cdde3c 201028_02
hgs
parents:
diff changeset
    74
    /**
089413cdde3c 201028_02
hgs
parents:
diff changeset
    75
     * Indicates that whether double buffering is preferred to be applied for 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    76
     * this endpoint. 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    77
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
    78
     * Upper application will declare whether double buffering is expected to 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    79
     * be used for this endpoint if there is one available (PSL knows about it)
089413cdde3c 201028_02
hgs
parents:
diff changeset
    80
     * when setup an interface.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    81
     * 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    82
     * PSL can ignore this request if NO double buffering is possible.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    83
     * 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    84
     * PIL may query whether a double buffering is really applied via interface 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    85
     * MPeripheralControllerIf::QueryEndpointResource() later.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    86
     *
089413cdde3c 201028_02
hgs
parents:
diff changeset
    87
     * @see TUsbPeripheralEndpointInfo::iFeatureWord1.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    88
     */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    89
    const TUint KUsbEndpointInfoFeatureWord1_DoubleBuffering = 0x00000002;
089413cdde3c 201028_02
hgs
parents:
diff changeset
    90
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
    91
    /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
    92
     * These are states that are described in the USB standard.
089413cdde3c 201028_02
hgs
parents:
diff changeset
    93
     */
089413cdde3c 201028_02
hgs
parents:
diff changeset
    94
    enum TUsbPeripheralState
089413cdde3c 201028_02
hgs
parents:
diff changeset
    95
        {
089413cdde3c 201028_02
hgs
parents:
diff changeset
    96
        EUsbPeripheralStateUndefined,  // 0
089413cdde3c 201028_02
hgs
parents:
diff changeset
    97
        EUsbPeripheralStateAttached,   // 1
089413cdde3c 201028_02
hgs
parents:
diff changeset
    98
        EUsbPeripheralStatePowered,    // 2
089413cdde3c 201028_02
hgs
parents:
diff changeset
    99
        EUsbPeripheralStateDefault,    // 3
089413cdde3c 201028_02
hgs
parents:
diff changeset
   100
        EUsbPeripheralStateAddress,    // 4
089413cdde3c 201028_02
hgs
parents:
diff changeset
   101
        EUsbPeripheralStateConfigured, // 5
089413cdde3c 201028_02
hgs
parents:
diff changeset
   102
        EUsbPeripheralStateSuspended,  // 6
089413cdde3c 201028_02
hgs
parents:
diff changeset
   103
        EUsbPeripheralNoState = 0xff   // 255 (used as a place holder)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   104
        };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   105
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   106
    /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   107
     * Endpoint capabilities as reported by the PSL driver.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   108
     */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   109
    class TUsbPeripheralEndpointCaps
089413cdde3c 201028_02
hgs
parents:
diff changeset
   110
        {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   111
        public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   112
        /** The supported maximum packet sizes. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   113
        TUint iSizes;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   114
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   115
        /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   116
         * The supported endpoint types and directions.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   117
         * see the bitmap definition for type and dir inside this header.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   118
         */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   119
        TUint iTypesAndDir;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   120
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   121
        /** set it to ETrue if it is a 'high-speed, high bandwidth' endpoint. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   122
        TBool iHighBandwidth;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   123
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   124
        /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   125
         * Reserved for future use. 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   126
         * PSL must set those reserved ram to zero to keep binary compatibility
089413cdde3c 201028_02
hgs
parents:
diff changeset
   127
         * with new (in furture) PIL binary which may utilize some of the 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   128
         * reserved space.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   129
         */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   130
        TUint32 iReserved[2];
089413cdde3c 201028_02
hgs
parents:
diff changeset
   131
        };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   132
    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   133
    /**
089413cdde3c 201028_02
hgs
parents:
diff changeset
   134
     * The desired endpoint capabilities.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   135
     * @see MPeripheralControllerIf::ConfigureEndpoint.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   136
     */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   137
    class TUsbPeripheralEndpointInfo
089413cdde3c 201028_02
hgs
parents:
diff changeset
   138
        {
089413cdde3c 201028_02
hgs
parents:
diff changeset
   139
        public:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   140
        /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   141
         * Endpoint type.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   142
         *(mask: UsbShai::KUsbEpTypeControl, etc., but used as value).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   143
         */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   144
        TUint iType;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   145
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   146
        /** Direction (mask: UsbShai::KUsbEpDirIn, etc., but used as value). */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   147
        TUint iDir;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   148
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   149
        /** Maximum packet size (literal, no mask). */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   150
        TInt iSize;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   151
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   152
        /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   153
         * Interval for polling full-speed interrupt and isochronous endpoints.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   154
         * Expressed either directly in milliseconds with a valid range 1..255
089413cdde3c 201028_02
hgs
parents:
diff changeset
   155
         * (interrupt), or for use as 'value' in the expression of 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   156
         * interval=2^(value-1) with a valid range 1..16 (isochronous).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   157
         */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   158
        TInt iInterval;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   159
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   160
        /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   161
         * Interval for polling high-speed interrupt and isochronous endpoints,
089413cdde3c 201028_02
hgs
parents:
diff changeset
   162
         * or to specify the NAK rate for high-speed control and bulk OUT
089413cdde3c 201028_02
hgs
parents:
diff changeset
   163
         * endpoints. Expressed either for use as 'value' in the expression
089413cdde3c 201028_02
hgs
parents:
diff changeset
   164
         * interval=2^(value-1) with a valid range 1..16 (interrupt and 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   165
         * isochronous), or directly as the maximum NAK rate with a valid range
089413cdde3c 201028_02
hgs
parents:
diff changeset
   166
         * 0..255 (control and bulk).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   167
         */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   168
        TInt iInterval_Hs;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   169
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   170
        /**
089413cdde3c 201028_02
hgs
parents:
diff changeset
   171
         * The number of additional transactions per frame to be scheduled(0..2)
089413cdde3c 201028_02
hgs
parents:
diff changeset
   172
         * (A value greater than zero is only valid for high-speed high bandwidth
089413cdde3c 201028_02
hgs
parents:
diff changeset
   173
         * interrupt and isochronous endpoints. Also note that there are endpoint
089413cdde3c 201028_02
hgs
parents:
diff changeset
   174
         * size restrictions associated with additional transactions - see 9.6.6.).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   175
         */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   176
        TInt iTransactions;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   177
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   178
        /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   179
         * The number of extra bytes that the standard endpoint descriptor
089413cdde3c 201028_02
hgs
parents:
diff changeset
   180
         * should be extended by. In almost all cases, this should be 0 (zero).
089413cdde3c 201028_02
hgs
parents:
diff changeset
   181
         */    
089413cdde3c 201028_02
hgs
parents:
diff changeset
   182
        TInt iExtra;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   183
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   184
        /** 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   185
         * 32 flag bits indicating miscellaneous endpoint features.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   186
         * Currently defined are:
089413cdde3c 201028_02
hgs
parents:
diff changeset
   187
         * - KUsbEndpointInfoFeatureWord1_DMA which means apply DMA to this 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   188
         *   endpoint if available.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   189
         * - KUsbEndpointInfoFeatureWord1_DoubleBuffering which means apply 
089413cdde3c 201028_02
hgs
parents:
diff changeset
   190
         *   double buffering to this endpoint if available.
089413cdde3c 201028_02
hgs
parents:
diff changeset
   191
         */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   192
        TUint32 iFeatureWord1;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   193
        
089413cdde3c 201028_02
hgs
parents:
diff changeset
   194
        /** Reserved for future use. */
089413cdde3c 201028_02
hgs
parents:
diff changeset
   195
        TUint32 iReserved;
089413cdde3c 201028_02
hgs
parents:
diff changeset
   196
        };
089413cdde3c 201028_02
hgs
parents:
diff changeset
   197
    }
089413cdde3c 201028_02
hgs
parents:
diff changeset
   198
#endif //USB_PERIPHERAL_SHAI_SHARED_H
089413cdde3c 201028_02
hgs
parents:
diff changeset
   199
089413cdde3c 201028_02
hgs
parents:
diff changeset
   200
// End of files