remoteconn_plat/generic_hid_api/inc/hidgeneric.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
#ifndef C_GENERICHID_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#define C_GENERICHID_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include <hidinterfaces.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
class CDriverListItem;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
class TElement;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
class CParser;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
class CReportRoot;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
class CConnectionInfo;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
 *  Generic HID main class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
 *  Generic HID layer, allowing the HID Transport layers and device drivers to
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
 *  pass data to the Generic HID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
 *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
 *  @lib generichid.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
 *  @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
 */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
class CGenericHid : public CHidTransport, public MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
    virtual ~CGenericHid();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
     * Constructs a generic HID layer with a reference to the owner so commands can
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
     * be sent to connected devices
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
     * @param aTransportLayer The owning transport layer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
     * @return a Pointer to an instantiated Generic HID layer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
    IMPORT_C static CGenericHid* NewL(MTransportLayer* aTransportLayer);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
     * Constructs a generic HID layer with a reference to the owner so commands can
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
     * be sent to connected devices
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
     * @param aTransportLayer The owning transport layer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
     * @return a Pointer to an instantiated Generic HID layer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
    IMPORT_C static CGenericHid* NewLC(MTransportLayer* aTransportLayer);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
     * Retrieves the country code for the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
     * @param aConnectionID The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
     * @return  a country code
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
    TUint CountryCodeL(TInt aConnectionID);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
     * Retrieves the country code for the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
     * @param aConnectionId The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
     * @return a vendor ir
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
    TUint VendorIdL(TInt aConnectionId);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
     * Retrieves the product identifier for the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
     * @param aConnectionId The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
     * @return  a prodcut id
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
    TUint ProductIdL(TInt aConnectionId);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
     * Sets the protocol to be used for reports. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
     * Leaves KErrInUse The request was not successful because the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
     * transport layer is busy with a previous request,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
     * KErrNotReady The request failed because the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
     * is currently unavailable and KErrNotFound The request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
     * was unsuccessful
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
     * @param aConnectionId The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
     * @param aInterface The device interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
     * @param aProtocol The requested report protocol (boot or report)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
     * @parem aDriver Calling driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
     * @return  None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
    void SetProtocolL(TInt aConnectionId, TUint16 aInterface,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
        MDriverAccess::TProtocols aProtocol, CHidDriver* aDriver);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
     * Requests the current protocol from the HID device.  This is an asynchronous
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
     * request. The protocol value will come through at a later time
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
     * @param aConnectionId The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
     * @param aInterface The hid interface
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
     * @return None. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
    void GetProtocolL(TInt aConnectionId,  TUint16 aInterface);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
     * A request for a report from the device.  This is an asynchronous request.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
     * The report will come through at a later time
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
     * @param aConnectionId The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
     * @param aReportId report id to be get
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
     * @param aInterface The device interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
     * @param aLength report lenght
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
     * @return  None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
    void GetReportL(TInt aConnectionId, TUint8 aReportId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
        TUint16 aInterface, TUint16 aLength);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
     * A request to send a report payload to the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
     * Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
     * because the device is currently unavailable
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 aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
     * @param aReportId The report id
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
     * @param aReportType Type of report (input/output/feature)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
     * @param aPayload The report containing the device setup packet
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
     * @param aInterface The device interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
     * @parem aDriver Calling driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
    void SetReportL(TInt aConnectionId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
        TUint8 aReportId, MDriverAccess::TReportType aReportType,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
        const TDesC8& aPayload, TUint16 aInterface, CHidDriver* aDriver);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
     * A request to send a report payload to the HID device in Interrupt Channel
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
     * Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
     * because the device is currently unavailable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
     * @param aReportId report id which payload to be send
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
     * @param aPayload The report containing the device setup packet
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
     * @param aInterface The device interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
     * @return  None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
    void DataOutL(TInt aConnectionId,  TUint8 aReportId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
                              const TDesC8& aPayload, TUint16 aInterface);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
     * Request for the current idle setting for the device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
     * This is an asynchronous request.  The idle value will come through at a
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
     * later time. Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
     * because the device is currently unavailable
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 aConnectionId The device identifier
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
     * @param aReportId The report ID for which we want the idle rate
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
     * @param aInterface The device interface being used by the driver
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
    void GetIdleL(TInt aConnectionId, TUint8 aReportId, TUint16 aInterface);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
     * Fromm class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
     * Request to the HID device to set the specified idle rate
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   198
     * A request to send a report payload to the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   199
     * Leaves whit KErrInUse The request was not successful because the transport 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   200
     * layer is busy with previous request and KErrNotReady The request failed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   201
     * because the device is currently unavailable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   202
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   203
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   204
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   205
     * @param aDuration The number of 0.04ms intervals to wait between reports
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   206
     * @param aReportId The report for which the idle rate is being set
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   207
     * @param aInterface The device interface being used by the driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   208
     * @parem aDriver Calling driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   209
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   210
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   211
    void SetIdleL(TInt aConnectionId, TUint8 aDuration,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   212
        TUint8 aReportId, TUint16 aInterface, CHidDriver* aDriver);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   213
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   214
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   215
     * From class CHidTransport
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   216
     * Called by the transport layers to inform the generic HID of the success of
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   217
     * the last Set... command.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   218
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   219
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   220
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   221
     * @param aCmdAck Status of the last Set... command
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   222
     * @return None.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   223
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   224
    void CommandResult(TInt aConnectionId, TInt aCmdAck);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   225
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   226
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   227
     * From class MDriverAccess
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   228
     * Gives the device driver access to the results of the report
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   229
     * descriptor parsing
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   230
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   231
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   232
     * @param aConnectionId The device ID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   233
     * @return A pointer to the parsed descriptor object.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   234
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   235
    CReportRoot* ReportDescriptor(TInt aConnectionId);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   236
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   237
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   238
     * From class CHidTransport
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   239
     * Called by a transport layer when a device has connected and the report
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   240
     * descriptors have been obtained
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   241
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   242
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   243
     * @param aConnectionId The tansport-layer enumeration for the connection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   244
     * @param aDescriptor The report descriptor for the connected HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   245
     * @return KErrNone if a driver was found, otherwise an error code
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   246
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   247
    TInt ConnectedL(TInt aConnectionId, const TDesC8& aDescriptor);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   248
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   249
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   250
     * From class CHidTransport
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   251
     * Called by a transport layer when a device has been disconnected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   252
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   253
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   254
     * @param aConnectionId The tansport-layer enumeration for the connection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   255
     * @return KErrNone if a driver was found, otherwise an error code
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   256
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   257
    TInt Disconnected(TInt aConnectionId);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   258
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   259
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   260
     * From class CHidTransport
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   261
     * Called by the transport layer when a device has sent a report on the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   262
     * interrupt or control channel
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   263
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   264
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   265
     * @param aConnectionId The tansport-layer enumeration for the connection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   266
     * @param aChannel Channel ID (Interrupt or Control)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   267
     * @param aPayload The complete report payload
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   268
     * @return KErrNone if the data was handled by the driver, otherwise an error code
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   269
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   270
    virtual TInt DataIn(TInt aConnectionId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   271
        CHidTransport::THidChannelType aChannel, const TDesC8& aPayload);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   272
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   273
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   274
     * From class CHidTransport
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   275
     * Called by the transport layer to suspend or resume a driver
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   276
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   277
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   278
     * @param aConnectionId The tansport-layer enumeration for the connection
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   279
     * @param aActive EActive to start the driver(s), ESuspend to suspend
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   280
     * @return KErrNone if the driver was successfully activated, otherwise an error code
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   281
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   282
    TInt DriverActive(TInt aConnectionId,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   283
        CHidTransport::TDriverState aActive);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   284
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   285
protected:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   286
    CGenericHid(MTransportLayer* aTransportLayer);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   287
    void ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   288
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   289
private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   290
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   291
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   292
     * Remove drivers
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   293
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   294
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   295
     * @return None
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   296
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   297
    void RemoveDrivers();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   298
              
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   299
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   300
     * Attempts to find a driver that is handling reports from the HID device
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   301
     *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   302
     * @since S60 v5.0
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   303
     * @return Connection information
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   304
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   305
    CConnectionInfo* SeekConnectionInfo(TInt aConnectionId);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   306
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   307
private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   308
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   309
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   310
     * Instantiated driver list
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   311
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   312
    TSglQue<CDriverListItem> iDriverList;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   313
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   314
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   315
     * Parser
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   316
     * Own.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   317
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   318
    CParser* iParser;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   319
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   320
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   321
     * Parser
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   322
     * Not own.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   323
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   324
    MTransportLayer* iTransportLayer;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   325
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   326
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   327
     * Connection information
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   328
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   329
    RPointerArray<CConnectionInfo> iConnectionInfo;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   330
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   331
    /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   332
     * Input data handling registry 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   333
     * Own.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   334
     */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   335
    CHidInputDataHandlingReg* iInputHandlingReg;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   336
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   337
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   338
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   339
#endif