remoteconn_plat/generic_hid_api/inc/hidinterfaces.h
author hgs
Thu, 04 Nov 2010 15:31:42 +0800
changeset 60 841f70763fbe
parent 29 3ae5cb0b4c02
permissions -rw-r--r--
201044_04
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     1
/*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     2
* Copyright (c) 2004-2007 Nokia Corporation and/or its subsidiary(-ies).
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     3
* All rights reserved.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     8
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     9
* Initial Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    11
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    12
* Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    13
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    14
* Description:  Declares main application class.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    15
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    16
*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    17
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    18
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    19
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#ifndef C_HIDDRIVER_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#define C_HIDDRIVER_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
#include <ecom/ecom.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
class CReportRoot;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
class MDriverAccess;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
class MTransportLayer;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
class CHidDriver;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
// ----------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
// Return codes from the Generic HID to Transport layers
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
const TInt KErrHidBase = -8000;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
const TInt KErrHidNoDriver = KErrHidBase;           /*!< No driver could be found to handle the request */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
const TInt KErrHidSuspended = KErrHidBase - 1;      /*!< Command not handled - driver is suspended */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
const TInt KErrHidUnrecognised = KErrHidBase - 2;   /*!< Driver could not understand the data */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
const TInt KErrHidUnexpected = KErrHidBase - 3;     /*!< Unsolicited data from the device */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
const TInt KErrHidBadChannel = KErrHidBase - 4;     /*!< Channel was not Int or Ctrl type */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
const TInt KErrHidPartialSupported = KErrHidBase - 5;     /*!< Partil supported hid device */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
// Errors returned by the report translator / generator:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
const TInt KErrUsageNotFound = KErrHidBase - 10;    //!< Usage page/ID wasn't found in the field
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
const TInt KErrValueOutOfRange = KErrHidBase - 11;  //!< Value specified is outside the logical range
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
const TInt KErrNoSpaceInArray = KErrHidBase - 12;   //!< Array field already contains the maximum number of values
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
const TInt KErrBadControlIndex = KErrHidBase - 13;  //!< Control index exceeds the number of controls in the field
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
// ACK codes returned by Set/Get requests to the devices
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
const TInt KErrCommandAckBase = -8100;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
const TInt KErrAckInvalidReportID = KErrCommandAckBase;         /*!< Invalid report ID */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
const TInt KErrAckInvalidParameter = KErrCommandAckBase - 1;    /*!< Invalid or out of range param */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
const TInt KErrAckUnknown = KErrCommandAckBase - 2;             /*!< Command failed, but the device can't determine why */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
const TInt KErrAckFatal = KErrCommandAckBase - 3;               /*!< The device is in an unrecoverable state and must be restarted */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
// Constant for plugin interface:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
const TUid KHidDriverPluginInterfaceUid        = { 0x10201d26 };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
class THidEvent
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
    public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
     * Usage page
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
    TInt iUsagePage;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
     * Keycode
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
    TInt iKeyCode;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
class CHidInputDataHandlingReg: public CBase
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
       
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
     * Two-phased constructor.     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
    static CHidInputDataHandlingReg* NewL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
     * Destructor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
     virtual ~CHidInputDataHandlingReg(); 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
public:        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
     * Check if key event is not allready processed
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
     * @param aUsagePage a usage page to be checked
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
     * @param aUsage a usage code to be checked
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
     * @return true if event is not allready handled
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
    IMPORT_C TBool  AllowedToHandleEvent(TInt aUsagePage, TInt aUsage);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
     * Add handled event
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
     * @param aUsagePage usage page to be handled
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
     * @param aUsage Usage to be handled
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
     */ 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
    IMPORT_C void  AddHandledEvent( TInt aUsagePage, TInt aUsage);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
     * Reset Array 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
    void  Reset();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
    CHidInputDataHandlingReg();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
    void ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
private: 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
     * Event array
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
     * Own.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
    CArrayFixFlat<THidEvent>* iEventArray;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
 *  Transport layer interface class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
 *  Interface allowing the generic HID layer to pass data to a Transport layer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
 *  All commands are asynchronous.  The results are returned via the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
 *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
class MTransportLayer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
     * Request for the country code of the given device.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
     * @return country code.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
    virtual TUint CountryCodeL(TInt aConnID) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
     * Request for the vendor identifier for the given device.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
     * @return vendor id.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
    virtual TUint VendorIdL(TInt aConnID) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
     * Request for the product identifier for the given device.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
     * @return product id.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
    virtual TUint ProductIdL(TInt aConnID) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
     * Request for the current device report protocol. The protocol will be
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
     * received as a control report via the CHidTransport::DataIn function
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
     * @param aInterface The interface we want to get the protocol from
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
    virtual void GetProtocolL(TInt aConnID,  TUint16 aInterface) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
     * Request to put the device in the specified protocol
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
     * @param aValue The requested protocol for the device (boot or report)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
     * @param aInterface The interface we want to set the protocol for
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   193
    virtual void SetProtocolL(TInt aConnID, TUint16 aValue,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
        TUint16 aInterface) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
     * Request for a device report. The data will be received as a control report
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   198
     * via the CHidTransport::DataIn function
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   199
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   200
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   201
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   202
     * @param aReportType The type of report (input/output/feature) requested
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   203
     * @param aReportID The specific report required
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   204
     * @param aInterface The interface we want the report from
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   205
     * @param aLength The expected length of the report buffer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   206
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   207
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   208
    virtual void GetReportL(TInt aConnID, TUint8 aReportType,TUint8 aReportID,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   209
        TUint16 aInterface, TUint16 aLength) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   210
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   211
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   212
     * Request to send a report to a device. The response will be reported via the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   213
     * CHidTransport::CommandResult function
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   214
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   215
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   216
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   217
     * @param aReportType The type of report (input/output/feature) requested
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   218
     * @param aReportID The specific report required to set
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   219
     * @param aInterface The interface we want to send the report to
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   220
     * @param aReport The report payload to be sent to the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   221
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   222
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   223
    virtual void SetReportL(TInt aConnID, TUint8 aReportType,TUint8 aReportID,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   224
        TUint16 aInterface, const TDesC8& aReport) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   225
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   226
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   227
     * Request to send data to a device. There are no responses to this report from device.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   228
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   229
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   230
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   231
     * @param aReportID The specific report required
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   232
     * @param aInterface The interface we want to send the report to
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   233
     * @param aReport The report payload to be sent to the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   234
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   235
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   236
    virtual void DataOutL(TInt aConnID, TUint8 aReportID,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   237
        TUint16 aInterface, const TDesC8& aReport) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   238
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   239
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   240
     * Request for the current idle rate of a report from the device. The response
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   241
     * will be recevied via the CHidTransport::DataIn function
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   242
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   243
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   244
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   245
     * @param aReportID The specific report to be queried
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   246
     * @param aInterface The interface we want to query for idle rate
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   247
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   248
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   249
    virtual void GetIdleL(TInt aConnID, TUint8 aReportID,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   250
        TUint16 aInterface) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   251
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   252
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   253
     * Request to set the current idle rate for a report on the device.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   254
     * The response will be received via the CHidTransport::CommandResult function
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   255
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   256
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   257
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   258
     * @param aReportID The specific report to be queried
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   259
     * @param aDuration The time period between idle reports (4ms per bit. An
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   260
     *        interval of 0 disables idle reports so that Interrupt reports are only ever
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   261
     *        received when the reported data has changed
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   262
     * @param aReportID The specific report to be queried
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   263
     * @param aInterface The interface we want to query for idle rate
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   264
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   265
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   266
    virtual void SetIdleL(TInt aConnID,  TUint8 aDuration, TUint8 aReportID,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   267
        TUint16 aInterface) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   268
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   269
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   270
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   271
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   272
 *  Driver access interface
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   273
 *  Interface allowing drivers to request data from and send data to devices via
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   274
 *  the Generic HID layer.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   275
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   276
 *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   277
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   278
class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   279
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   280
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   281
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   282
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   283
     * The type of report requested from the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   284
     * Note: The enumeration values map directly to the HID equivalent values
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   285
     * (Passed as TUint16 values to the transport layer)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   286
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   287
    enum TReportType
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   288
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   289
        EInput=1,     /*!< Input report */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   290
        EOutput,      /*!< Output report */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   291
        EFeature      /*!< Feature report */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   292
        };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   293
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   294
    /** Return codes from the Generic HID to the device drivers
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   295
     * Note: The enumeration values map directly to the HID equivalent values
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   296
     *(Passed as TUint8 values to the transport layer)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   297
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   298
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   299
    enum TProtocols
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   300
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   301
        EBoot=0,        /*!< Boot Protocol */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   302
        EReport=1       /*!< Report Protocol */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   303
        };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   304
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   305
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   306
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   307
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   308
     * Retrieves the country code for the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   309
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   310
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   311
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   312
     * @return contry code
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   313
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   314
    virtual TUint CountryCodeL(TInt aConnID) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   315
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   316
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   317
     * Retrieves the  for the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   318
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   319
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   320
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   321
     * @return vendor id
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   322
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   323
    virtual TUint VendorIdL(TInt aConnID) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   324
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   325
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   326
     * Retrieves the product identifier for the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   327
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   328
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   329
     * @param aConnID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   330
     * @return produrct id
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   331
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   332
    virtual TUint ProductIdL(TInt aConnID) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   333
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   334
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   335
     * Requests the current protocol for the device (boot or report)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   336
     * Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   337
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   338
     * because the device is currently unavaila
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   339
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   340
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   341
     * @param aConnectionID The connection id
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   342
     * @param aInterface The current interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   343
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   344
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   345
    virtual void GetProtocolL(TInt aConnectionID,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   346
        TUint16 aInterface) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   347
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   348
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   349
     * Requests a report from the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   350
     * Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   351
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   352
     * because the device is currently unavailable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   353
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   354
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   355
     * @param aConnectionId The connection id
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   356
     * @param aReportId The report required from the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   357
     * @param aInterface The current interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   358
     * @param aLength ** NOT USED **
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   359
     * @return None
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   360
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   361
    virtual void GetReportL(TInt aConnectionId, TUint8 aReportId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   362
        TUint16 aInterface, TUint16 aLength) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   363
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   364
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   365
     * Requests the current Idle setting for the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   366
     * Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   367
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   368
     * because the device is currently unavailable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   369
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   370
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   371
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   372
     * @param aReportId The report required from the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   373
     * @param aInterface The current interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   374
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   375
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   376
    virtual void GetIdleL(TInt aConnectionId, TUint8 aReportId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   377
        TUint16 aInterface ) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   378
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   379
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   380
     * Sets the protocol to be used for reports
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   381
     * Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   382
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   383
     * because the device is currently unavailable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   384
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   385
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   386
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   387
     * @param aInterface The current interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   388
     * @param aProtocol The required protocol (boot or report)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   389
     * @parem aDriver Calling driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   390
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   391
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   392
    virtual void SetProtocolL(TInt aConnectionId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   393
        TUint16 aInterface, TProtocols aProtocol, CHidDriver* aDriver) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   394
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   395
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   396
     * Sets the idle interval for interrupt data.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   397
     * Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   398
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   399
     * because the device is currently unavailable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   400
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   401
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   402
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   403
     * @param aDuration The idle interval, in steps of 0.04ms intervals (where
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   404
     *                  1 = 0.04ms, 2=0.08ms). 0 will disable idle so reports
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   405
     *                   are only sent when the state of the device changes
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   406
     * @param aInterface The current interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   407
     * @param aReportId The report whose idle rate is being set
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   408
     * @param aInterface The current interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   409
     * @parem aDriver Calling driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   410
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   411
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   412
    virtual void SetIdleL(TInt aConnectionId, TUint8 aDuration,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   413
        TUint8 aReportId, TUint16 aInterface, CHidDriver* aDriver) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   414
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   415
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   416
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   417
     * Sends a report to the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   418
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   419
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   420
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   421
     * @param aReportId The report to receive the setup report
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   422
     * @param aReportType The type of report being sent to the device (input, output
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   423
     *                     or Feature)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   424
     * @param aPayload The report being sent to the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   425
     * @parem aDriver Calling driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   426
     * @param aInterface The current interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   427
     * @return KErrNone The request was successful and the result of the command is
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   428
     *         expected at a later time (as a CmdAck message), KErrInUse The request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   429
     *         was not successful because the transport layer is busy with a previous
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   430
     *         request, KErrNotReady The request failed because the device is currently
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   431
     *         unavailable and KErrNoMemory The request failed because not enough memory
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   432
     *         available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   433
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   434
    virtual void SetReportL(TInt aConnectionId, TUint8 aReportId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   435
        TReportType aReportType, const TDesC8& aPayload,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   436
        TUint16 aInterface, CHidDriver* aDriver) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   437
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   438
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   439
     * Sends a report to the device (from host) using Interrupt Channel as DATA
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   440
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   441
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   442
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   443
     * @param aReportId The report to receive the setup report
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   444
     * @param aPayload The report being sent to the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   445
     * @param aInterface The current interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   446
     * @return KErrNone The request was successful and the result of the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   447
     *         command is expected at a later time (as a CmdAck message),
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   448
     *         KErrInUse The request was not successful because the transport layer is
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   449
     *         busy with a previous request, KErrNotReady The request failed because the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   450
     *         device is currently unavailable and KErrNoMemory The request failed because
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   451
     *         not enough memory available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   452
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   453
    virtual void DataOutL(TInt aConnectionId, TUint8 aReportId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   454
        /*TReportType aReportType,*/ const TDesC8& aPayload,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   455
        TUint16 aInterface) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   456
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   457
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   458
     * A request for the parsed descriptor container object so the driver can
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   459
     * retrieve the report format(s)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   460
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   461
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   462
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   463
     * @return A pointer to the parsed report descriptor container and
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   464
     *        NULL if no parsed report descriptor container exists
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   465
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   466
    virtual CReportRoot* ReportDescriptor(TInt aConnectionId) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   467
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   468
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   469
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   470
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   471
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   472
 *  Hid transport interface
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   473
 *  Interface allowing the transport layer to pass data to the Generic HID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   474
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   475
 *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   476
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   477
class CHidTransport : public CBase
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   478
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   479
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   480
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   481
     * Defines the channel type for the DataIn function
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   482
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   483
    enum THidChannelType
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   484
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   485
        EHidChannelInt,     /*!< Interrupt channel */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   486
        EHidChannelCtrl     /*!< Control channel */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   487
        };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   488
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   489
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   490
     *Driver state (active or suspended)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   491
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   492
    enum TDriverState
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   493
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   494
        EActive,            /*!< Driver will handle interrupt data */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   495
        ESuspend            /*!< the driver will not handle interrupt data */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   496
        };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   497
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   498
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   499
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   500
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   501
     * Called when a device has connected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   502
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   503
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   504
     * @param aConnectionId The transport-layer enumeration for the connection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   505
     * @param aDescriptor The report descriptor for the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   506
     * @return KErrNone The connection will be handled by one or more drivers,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   507
     *         KErrHidNoDriver No driver was found to handle the connected device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   508
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   509
    virtual TInt ConnectedL(TInt aConnectionId, const TDesC8& aDescriptor) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   510
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   511
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   512
     * Called when a device has been disconnected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   513
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   514
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   515
     * @param aConnectionId The transport-layer enumeration for the connection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   516
     * @param aDescriptor The report descriptor for the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   517
     * @return KErrNone The device was recognised and its drivers were unloaded and
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   518
     *         KErrHidNoDriver No driver was found to handle the connected device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   519
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   520
    virtual TInt Disconnected(TInt aConnectionId) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   521
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   522
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   523
     * Called when a device has been disconnected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   524
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   525
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   526
     * @param aConnectionId Transport layer connection enumeration
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   527
     * @param aChannel Channel ID (Interrupt or Control)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   528
     * @param aPayload The complete report payload
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   529
     * @return KErrNone The payload was handled by one or more drivers,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   530
     *         KErrHidNoDriver No driver is handling reports from the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   531
     *         and KErrHidSuspended The report was not handled because all the drivers
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   532
     *         handling the device are suspended
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   533
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   534
    virtual TInt DataIn(TInt aConnectionId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   535
        THidChannelType aChannel, const TDesC8& aPayload) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   536
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   537
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   538
     * Suspends or Resumes the driver(s) handling the connection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   539
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   540
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   541
     * @param aConnectionId Transport layer connection enumeration
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   542
     * @param aActive The requested state of the driver (active or suspended)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   543
     * @return KErrNone The driver was successfully put into the requested state,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   544
     *         and KErrHidAlreadyInState All the drivers were already in the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   545
     *         requested state
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   546
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   547
    virtual TInt DriverActive(TInt aConnectionId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   548
        CHidTransport::TDriverState aActive) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   549
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   550
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   551
     * Called by the transport layers to inform the generic HID of the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   552
     * success of the last Set... command.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   553
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   554
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   555
     * @param aConnectionId Transport layer connection enumeration
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   556
     * @param  aCmdAck Status of the last Set... command
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   557
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   558
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   559
    virtual void CommandResult(TInt aConnectionId, TInt aCmdAck) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   560
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   561
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   562
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   563
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   564
 *  Driver plugin interface
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   565
 *  Interface allowing drivers to request data from and send data to devices via
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   566
 *  the Generic HID layer.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   567
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   568
 *  @lib generichid.lib 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   569
 *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   570
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   571
class CHidDriver : public CBase
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   572
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   573
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   574
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   575
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   576
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   577
     * Two-phased constructor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   578
     * @param aImplementationUid Implementation UID of the plugin to be
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   579
     *                           created.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   580
     * @param aHid               Driver acces interface
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   581
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   582
    IMPORT_C static CHidDriver* NewL(
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   583
	    const TUid aImplementationUid,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   584
    	MDriverAccess* aHid );
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   585
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   586
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   587
     * Destructor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   588
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   589
     IMPORT_C virtual ~CHidDriver();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   590
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   591
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   592
     * Called by the Generic HID to see if the factory can use reports described by
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   593
     * the parsed report descriptor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   594
     * NOTE: The current implementation supports just one driver and that driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   595
     * that will either handle all the reports from the device or none at all.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   596
     * Report ID is not currently being taken into account.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   597
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   598
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   599
     * @param aReportDescriptor Parsed HID report descriptor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   600
     * @return KErrNone The driver will handle reports from the report descriptor and
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   601
     *         KErrHidUnrecognised The driver cannot handle reports from the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   602
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   603
    virtual TInt CanHandleReportL(CReportRoot* aReportDescriptor) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   604
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   605
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   606
     * Called by the Generic HID layer when a device has sent a report on the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   607
     * interrupt or control channel
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   608
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   609
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   610
     * @param aChannel Channel ID (Interrupt or Control)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   611
     * @param aPayload The complete report payload
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   612
     * @return Error if data can't be handled.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   613
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   614
    virtual TInt DataIn(CHidTransport::THidChannelType aChannel,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   615
        const TDesC8& aPayload) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   616
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   617
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   618
     * Called by the Generic HID layer when the handled device has been disconnected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   619
     * interrupt or control channel
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   620
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   621
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   622
     * @param aReason Disconnection code
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   623
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   624
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   625
    virtual void Disconnected(TInt aReason) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   626
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   627
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   628
     * Called after a driver is sucessfully created by the Generic HID,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   629
     * when a device is connected.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   630
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   631
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   632
     * @param aConnectionId An number used to identify the device in
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   633
     * subsequent calls from the driver to the generic HID, for example
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   634
     * when sending data to the device.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   635
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   636
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   637
    virtual void InitialiseL(TInt aConnectionId) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   638
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   639
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   640
     * Enables the driver so that it will configure the device and
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   641
     * start handling interrupt reports from the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   642
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   643
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   644
     * @param aConnectionId A number used to identify the device in
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   645
     * subsequent calls from the driver to the Generic HID, for example
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   646
     * when sending data to the device.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   647
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   648
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   649
    virtual void StartL(TInt aConnectionId) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   650
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   651
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   652
     * Disables the driver so that it will stop handling device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   653
     * interrupt reports
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   654
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   655
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   656
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   657
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   658
    virtual void Stop() = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   659
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   660
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   661
     * Called by the transport layers to inform the generic HID of
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   662
     * the success of the last Set... command.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   663
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   664
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   665
     * @param  aCmdAck Status of the last Set... command
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   666
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   667
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   668
    virtual void CommandResult(TInt aCmdAck) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   669
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   670
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   671
     * Return count of supported fields
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   672
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   673
     * @since S60 v5.0     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   674
     * @return Number of supported fields.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   675
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   676
    virtual TInt SupportedFieldCount()= 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   677
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   678
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   679
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   680
     * Set input handling registy 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   681
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   682
     * @since S60 v5.0     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   683
     * @param aHandlingReg  a Input handling registry
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   684
     * @return Number of supported fields.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   685
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   686
    virtual void SetInputHandlingReg(CHidInputDataHandlingReg* aHandlingReg) = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   687
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   688
    protected:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   689
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   690
     * C++ constructor.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   691
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   692
    IMPORT_C CHidDriver();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   693
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   694
    private: // Data
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   695
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   696
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   697
     * ECOM plugin instance UID.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   698
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   699
    TUid iDtor_ID_Key;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   700
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   701
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   702
#endif
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   703
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   704