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