userlibandfileserver/fileserver/smassstorage/drivepublisher.cpp
author hgs
Mon, 11 Oct 2010 17:54:41 +0100
changeset 286 48e57fb1237e
parent 0 a41df078684a
permissions -rw-r--r--
201039_11
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     1
// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     2
// All rights reserved.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     3
// This component and the accompanying materials are made available
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     4
// under the terms of the License "Eclipse Public License v1.0"
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     5
// which accompanies this distribution, and is available
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     7
//
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     8
// Initial Contributors:
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    10
//
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    11
// Contributors:
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    12
//
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    13
// Description:
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    14
// Class implementation of the drive publishing classes -
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    15
// RDriveMediaErrorPublisher,
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    16
// RDriveStateChangedPublisher,
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    17
// CDriveTransferPublisher,
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    18
// CDriveWriteTransferPublisher,
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    19
// CDriveReadTransferPublisher,
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    20
// CUsbTransferPublisher,
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    21
// CUsbReadTransferPublisher,
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    22
// CUsbReadTransferPublisher.
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    23
//
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    24
//
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    25
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    26
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    27
 @file
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    28
 @internalTechnology
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    29
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    30
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    31
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    32
#include "drivepublisher.h"
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    33
#include "drivemanager.h"
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    34
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    35
#include "OstTraceDefinitions.h"
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    36
#ifdef OST_TRACE_COMPILER_IN_USE
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    37
#include "drivepublisherTraces.h"
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    38
#endif
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    39
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    40
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    41
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    42
//
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    43
// Use Lookup table to translate from the internal pair of state variables
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    44
// to the externally published drive state code.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    45
//
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    46
static const TUint8 table[][5] =
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    47
{
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    48
//TMountState=EDisconnected
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    49
    {EUsbMsDriveState_Disconnected,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    50
     EUsbMsDriveState_Disconnected,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    51
     EUsbMsDriveState_Disconnected,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    52
     EUsbMsDriveState_Disconnected,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    53
     EUsbMsDriveState_Disconnected},
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    54
//TMountState=EConnecting
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    55
    {EUsbMsDriveState_Connecting,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    56
     EUsbMsDriveState_Connecting,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    57
     EUsbMsDriveState_Connecting,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    58
     EUsbMsDriveState_Connecting,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    59
     EUsbMsDriveState_Connecting},
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    60
//TMountState=EConnected
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    61
    //EIdle,EActive,ELocked,EMediaNotPresent,EErrDisMounted
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    62
    {EUsbMsDriveState_Connected,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    63
     EUsbMsDriveState_Active,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    64
     EUsbMsDriveState_Locked,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    65
     EUsbMsDriveState_MediaNotPresent,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    66
     EUsbMsDriveState_Removed},
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    67
//TMountState=EDisconnecting
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    68
    {EUsbMsDriveState_Disconnecting,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    69
     EUsbMsDriveState_Disconnecting,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    70
     EUsbMsDriveState_Disconnecting,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    71
     EUsbMsDriveState_Disconnecting,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    72
     EUsbMsDriveState_Disconnecting}
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    73
};
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    74
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    75
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    76
//----------------------------------------------------------------------------
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    77
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    78
Constructor
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    79
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    80
RDriveMediaErrorPublisher::RDriveMediaErrorPublisher()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    81
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    82
    _LIT_SECURITY_POLICY_PASS(KMassStorageReadPolicy);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    83
    _LIT_SECURITY_POLICY_S0(KMassStorageWritePolicy, KUsbMsDriveState_Category.iUid);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    84
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    85
    TInt result = RProperty::Define(EUsbMsDriveState_MediaError, RProperty::EInt,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    86
                                    KMassStorageReadPolicy, KMassStorageWritePolicy);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    87
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    88
    __ASSERT_DEBUG(result == KErrAlreadyExists || result == KErrNone, User::Invariant());
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    89
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    90
    result = iMediaErrorProperty.Attach(KUsbMsDriveState_Category, EUsbMsDriveState_MediaError);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    91
    __ASSERT_DEBUG(result == KErrNone, User::Invariant());
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    92
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    93
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    94
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    95
RDriveMediaErrorPublisher::~RDriveMediaErrorPublisher()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    96
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    97
    iMediaErrorProperty.Close();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    98
    RProperty::Delete(KUsbMsDriveState_Category, EUsbMsDriveState_MediaError);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
    99
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   100
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   101
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   102
Publishing method
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   103
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   104
Publishes the Media Error property event
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   105
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   106
@param aError ETrue if drive media has an error else EFalse for no error
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   107
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   108
void RDriveMediaErrorPublisher::PublishError(TBool aError)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   109
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   110
    OstTraceFunctionEntry0(DRIVEPUBLISHER_100);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   111
    TInt oldValue;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   112
    iMediaErrorProperty.Get(oldValue);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   113
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   114
    if (oldValue != aError)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   115
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   116
        User::LeaveIfError(iMediaErrorProperty.Set(aError));
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   117
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   118
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   119
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   120
//----------------------------------------------------------------------------
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   121
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   122
Constructor
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   123
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   124
@param aDrives
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   125
@param aDriveMap
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   126
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   127
RDriveStateChangedPublisher::RDriveStateChangedPublisher(TRefMsDriveList aDrives,
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   128
                                                         TRefDriveMap aDriveMap)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   129
    :
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   130
    iDrives(aDrives),
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   131
    iDriveMap(aDriveMap)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   132
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   133
    _LIT_SECURITY_POLICY_PASS(KMassStorageReadPolicy);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   134
    _LIT_SECURITY_POLICY_S0(KMassStorageWritePolicy, KUsbMsDriveState_Category.iUid);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   135
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   136
    TInt result = RProperty::Define(KUsbMsDriveState_Category,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   137
                                    EUsbMsDriveState_DriveStatus, RProperty::EByteArray,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   138
                                    KMassStorageReadPolicy, KMassStorageWritePolicy,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   139
                                    KUsbMsMaxDrives*2);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   140
    __ASSERT_DEBUG(result == KErrAlreadyExists || result == KErrNone, User::Invariant());
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   141
    result = result;    // remove urel warning
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   142
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   143
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   144
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   145
RDriveStateChangedPublisher::~RDriveStateChangedPublisher()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   146
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   147
    RProperty::Delete(KUsbMsDriveState_Category, EUsbMsDriveState_DriveStatus);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   148
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   149
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   150
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   151
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   152
Publishing method
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   153
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   154
Sends a property event on behalf of CMassStorageDrive, with the mountstate and drivestate
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   155
values encoded into one 32-bit word.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   156
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   157
void RDriveStateChangedPublisher::DriveStateChanged()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   158
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   159
    TUsbMsDrivesStatus allDrivesStatus;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   160
    for(TUint8 i=0; i<KUsbMsMaxDrives && iDrives[i]; i++)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   161
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   162
        allDrivesStatus.Append(iDriveMap[i]);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   163
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   164
        CMassStorageDrive::TMountState ms = iDrives[i]->MountState();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   165
        CMassStorageDrive::TDriveState ds = iDrives[i]->DriveState();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   166
        TInt driveStatus = EUsbMsDriveState_Error;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   167
        if((TUint8)ds < sizeof(table[0]) && (TUint8)ms < sizeof(table)/sizeof(table[0]))
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   168
            {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   169
            driveStatus = table[ms][ds];
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   170
            OstTraceExt3(TRACE_SMASSSTORAGE_DRIVE, DRIVEPUBLISHER_110,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   171
                         "ms=%d ds=%d %d", ms, ds, driveStatus);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   172
            }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   173
        allDrivesStatus.Append(driveStatus);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   174
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   175
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   176
    OstTrace1(TRACE_SMASSSTORAGE_DRIVE, DRIVEPUBLISHER_111,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   177
              "Publishing EUsbMsDriveState_DriveStatus for %d drives", allDrivesStatus.Length()/2);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   178
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   179
    if(KErrNone != RProperty::Set(KUsbMsDriveState_Category,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   180
                                  EUsbMsDriveState_DriveStatus,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   181
                                  allDrivesStatus))
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   182
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   183
        __ASSERT_DEBUG(EFalse,User::Invariant());
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   184
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   185
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   186
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   187
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   188
//----------------------------------------------------------------------------
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   189
#ifndef USB_TRANSFER_PUBLISHER
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   190
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   191
Private default constructor to ensure that NewL is used
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   192
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   193
@param aSubKey
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   194
@param aDrives
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   195
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   196
CDriveTransferPublisher::CDriveTransferPublisher(
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   197
    TUsbMsDriveState_Subkey aSubKey,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   198
    TRefMsDriveList aDrives)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   199
    :
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   200
    iSubKey(aSubKey),
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   201
    iDrives(aDrives)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   202
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   203
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   204
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   205
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   206
void CDriveTransferPublisher::ConstructL()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   207
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   208
    _LIT_SECURITY_POLICY_PASS(KMassStorageReadPolicy);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   209
    _LIT_SECURITY_POLICY_S0(KMassStorageWritePolicy, KUsbMsDriveState_Category.iUid);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   210
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   211
    TInt r = RProperty::Define(iSubKey, RProperty::EByteArray,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   212
                               KMassStorageReadPolicy, KMassStorageWritePolicy,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   213
                               KUsbMsMaxDrives*sizeof(TInt));
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   214
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   215
    if (r != KErrAlreadyExists)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   216
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   217
        User::LeaveIfError(r);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   218
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   219
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   220
    User::LeaveIfError(iProperty.Attach(KUsbMsDriveState_Category, iSubKey));
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   221
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   222
    // Create the EDataTransferred timer
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   223
    iTimer = CPeriodic::NewL(CActive::EPriorityStandard);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   224
    iTimerRunning = EFalse;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   225
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   226
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   227
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   228
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   229
Destructor
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   230
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   231
CDriveTransferPublisher::~CDriveTransferPublisher()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   232
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   233
    if(iTimer)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   234
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   235
        iTimer->Cancel();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   236
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   237
    delete iTimer;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   238
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   239
    iProperty.Close();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   240
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   241
    RProperty::Delete(KUsbMsDriveState_Category, iSubKey);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   242
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   243
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   244
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   245
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   246
A static wrapper for the DoPublishDataTransferredEvent member function
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   247
for use as a timer callback function.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   248
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   249
@param obj 'this' pointer
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   250
@return not used in CPeriodic callback (see TCallback)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   251
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   252
TInt CDriveTransferPublisher::PublishDataTransferredEvent(TAny* obj)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   253
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   254
    static_cast<CDriveTransferPublisher*>(obj)->DoPublishDataTransferredEvent();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   255
    return 1;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   256
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   257
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   258
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   259
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   260
Update the data transferred properties if the counts have changed since
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   261
the last update.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   262
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   263
void CDriveTransferPublisher::DoPublishDataTransferredEvent()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   264
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   265
    if (PublishDataTransferred())
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   266
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   267
        // some data has been transfered so reset the counter
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   268
        iTimerCancelCnt = ETimerCancelDelay;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   269
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   270
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   271
    // Update the cancel count if no data was transferred the last
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   272
    // (few) times this has been called
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   273
    if (--iTimerCancelCnt == 0)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   274
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   275
        StopTimer();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   276
        iTimerCancelCnt = ETimerCancelDelay;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   277
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   278
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   279
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   280
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   281
/**
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   282
Update the data transferred properties if the counts have changed since
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   283
the last update.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   284
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   285
TBool CDriveTransferPublisher::PublishDataTransferred()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   286
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   287
    TUsbMsBytesTransferred bytesTransferred;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   288
    TBool dataTransferred = EFalse;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   289
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   290
    for (TInt i=0; i < iDrives.Count() && iDrives[i]; i++)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   291
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   292
        bytesTransferred[i] = GetBytesTransferred(i);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   293
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   294
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   295
    // Update the properties only if they have changed
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   296
    // (or if there's an error reading the old value.)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   297
    // Possible optimisation: keep a copy of the value
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   298
    // as a member variable so we don't need the Get.
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   299
    TUsbMsBytesTransferred oldValue;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   300
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   301
    if ((iProperty.Get(oldValue) != KErrNone) || (oldValue != bytesTransferred))
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   302
        {
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   303
#ifdef __PRINT3
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   304
        for (TInt j=0; j < iDrives.Count() && iDrives[j]; j++)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   305
            {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   306
            if(oldValue[j] != bytesTransferred[j])
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   307
                {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   308
                __PRINT3(_L("CDrivePublisher: KBytes[%d] %d->%d\n"), j, oldValue[j], bytesTransferred[j]);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   309
                }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   310
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   311
#endif
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   312
        if (KErrNone != iProperty.Set(bytesTransferred))
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   313
            {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   314
            __ASSERT_DEBUG(EFalse, User::Invariant());
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   315
            }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   316
        dataTransferred = ETrue;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   317
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   318
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   319
    return dataTransferred;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   320
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   321
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   322
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   323
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   324
Starts timer to periodically publish results.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   325
If the timer is not yet running then start it.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   326
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   327
void CDriveTransferPublisher::StartTimer()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   328
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   329
    if (!iTimerRunning)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   330
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   331
        // EDataTransferred event every second
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   332
        const TTimeIntervalMicroSeconds32 interval = 1 * 1000 * 1000;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   333
        TCallBack callback(PublishDataTransferredEvent, this);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   334
        OstTrace0(TRACE_SMASSSTORAGE_DRIVE, DRIVEPUBLISHER_140, "Starting timer");
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   335
        iTimer->Start(interval, interval, callback);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   336
        iTimerRunning = ETrue;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   337
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   338
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   339
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   340
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   341
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   342
Ensure that the Timer is stopped
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   343
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   344
void CDriveTransferPublisher::StopTimer()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   345
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   346
    if (iTimerRunning)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   347
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   348
        OstTrace0(TRACE_SMASSSTORAGE_DRIVE, DRIVEPUBLISHER_141, "Stopping timer");
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   349
        iTimer->Cancel();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   350
        iTimerRunning = EFalse;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   351
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   352
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   353
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   354
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   355
//----------------------------------------------------------------------------
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   356
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   357
Constructor for Write property
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   358
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   359
@param aDrives
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   360
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   361
CDriveWriteTransferPublisher* CDriveWriteTransferPublisher::NewL(TRefMsDriveList aDrives)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   362
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   363
    CDriveWriteTransferPublisher* self = new (ELeave) CDriveWriteTransferPublisher(aDrives);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   364
    CleanupStack::PushL(self);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   365
    self->ConstructL();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   366
    CleanupStack::Pop();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   367
    return self;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   368
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   369
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   370
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   371
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   372
Constructor
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   373
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   374
@param aDrives
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   375
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   376
CDriveWriteTransferPublisher::CDriveWriteTransferPublisher(TRefMsDriveList aDrives)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   377
    :
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   378
    CDriveTransferPublisher(EUsbMsDriveState_KBytesWritten, aDrives)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   379
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   380
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   381
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   382
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   383
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   384
Transfer function for Write property
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   385
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   386
@param aLun
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   387
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   388
TUint CDriveWriteTransferPublisher::GetBytesTransferred(TUint aLun) const
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   389
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   390
    return iDrives[aLun]->KBytesWritten();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   391
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   392
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   393
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   394
//----------------------------------------------------------------------------
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   395
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   396
Constructor for Read property
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   397
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   398
@param aDrives
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   399
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   400
CDriveReadTransferPublisher* CDriveReadTransferPublisher::NewL(TRefMsDriveList aDrives)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   401
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   402
    CDriveReadTransferPublisher* self = new (ELeave) CDriveReadTransferPublisher(aDrives);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   403
    CleanupStack::PushL(self);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   404
    self->ConstructL();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   405
    CleanupStack::Pop();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   406
    return self;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   407
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   408
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   409
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   410
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   411
Constructor
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   412
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   413
@param aDrives
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   414
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   415
CDriveReadTransferPublisher::CDriveReadTransferPublisher(TRefMsDriveList aDrives)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   416
    :
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   417
    CDriveTransferPublisher(EUsbMsDriveState_KBytesRead, aDrives)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   418
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   419
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   420
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   421
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   422
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   423
Transfer function for Read property
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   424
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   425
@param aLun
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   426
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   427
TUint CDriveReadTransferPublisher::GetBytesTransferred(TUint aLun) const
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   428
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   429
    return iDrives[aLun]->KBytesRead();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   430
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   431
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   432
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   433
//----------------------------------------------------------------------------
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   434
#else
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   435
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   436
Private default constructor to ensure that NewL is used
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   437
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   438
@param aSubKey
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   439
@param aArray
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   440
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   441
CUsbTransferPublisher::CUsbTransferPublisher(
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   442
    TUsbMsDriveState_Subkey aSubKey,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   443
    TRefBytesTransferedList aArray)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   444
    :
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   445
    iSubKey(aSubKey),
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   446
    iArray(aArray)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   447
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   448
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   449
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   450
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   451
void CUsbTransferPublisher::ConstructL()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   452
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   453
    _LIT_SECURITY_POLICY_PASS(KMassStorageReadPolicy);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   454
    _LIT_SECURITY_POLICY_S0(KMassStorageWritePolicy, KUsbMsDriveState_Category.iUid);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   455
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   456
    TInt r = RProperty::Define(iSubKey, RProperty::EByteArray,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   457
                               KMassStorageReadPolicy, KMassStorageWritePolicy,
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   458
                               KUsbMsMaxDrives*sizeof(TInt));
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   459
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   460
    if (r != KErrAlreadyExists)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   461
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   462
        User::LeaveIfError(r);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   463
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   464
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   465
    // Attach to the properties here. Only do this once, continuously attaching
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   466
    // will currently cause a memory leak
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   467
    User::LeaveIfError(iProperty.Attach(KUsbMsDriveState_Category, iSubKey));
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   468
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   469
    // Create the EDataTransferred timer
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   470
    iTimer = CPeriodic::NewL(CActive::EPriorityStandard);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   471
    iTimerRunning = EFalse;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   472
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   473
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   474
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   475
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   476
Destructor
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   477
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   478
CUsbTransferPublisher::~CUsbTransferPublisher()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   479
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   480
    if(iTimer)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   481
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   482
        iTimer->Cancel();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   483
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   484
    delete iTimer;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   485
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   486
    iProperty.Close();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   487
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   488
    RProperty::Delete(KUsbMsDriveState_Category, iSubKey);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   489
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   490
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   491
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   492
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   493
A static wrapper for the DoPublishDataTransferredEvent member function
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   494
for use as a timer callback function.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   495
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   496
@param obj 'this' pointer
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   497
@return not used in CPeriodic callback (see TCallback)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   498
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   499
TInt CUsbTransferPublisher::PublishDataTransferredEvent(TAny* obj)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   500
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   501
    static_cast<CUsbTransferPublisher*>(obj)->DoPublishDataTransferredEvent();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   502
    return 1;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   503
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   504
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   505
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   506
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   507
Update the data transferred properties if the counts have changed since
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   508
the last update.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   509
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   510
void CUsbTransferPublisher::DoPublishDataTransferredEvent()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   511
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   512
    if (PublishDataTransferred())
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   513
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   514
        // some data has been transfered so reset the counter
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   515
        iTimerCancelCnt = ETimerCancelDelay;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   516
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   517
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   518
    // Update the cancel count if no data was transferred the last
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   519
    // (few) times this has been called
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   520
    if (--iTimerCancelCnt == 0)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   521
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   522
        StopTimer();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   523
        iTimerCancelCnt = ETimerCancelDelay;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   524
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   525
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   526
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   527
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   528
/**
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   529
Update the data transferred properties if the counts have changed since
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   530
the last update.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   531
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   532
TBool CUsbTransferPublisher::PublishDataTransferred()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   533
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   534
    TUsbMsBytesTransferred bytesTransferred;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   535
    TBool dataTransferred = EFalse;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   536
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   537
    for (TInt i = 0; i < iArray.Count(); i++)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   538
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   539
        bytesTransferred[i] = GetBytesTransferred(i);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   540
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   541
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   542
    // Update the properties only if they have changed
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   543
    // (or if there's an error reading the old value.)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   544
    // Possible optimisation: keep a copy of the value
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   545
    // as a member variable so we don't need the Get.
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   546
    TUsbMsBytesTransferred oldValue;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   547
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   548
    if ((iProperty.Get(oldValue) != KErrNone) || (oldValue != bytesTransferred))
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   549
        {
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   550
#ifdef __PRINT3
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   551
        // trace of the bytes transferred
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   552
        for (TInt j=0; j < iArray.Count(); j++)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   553
            {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   554
            if(oldValue[j] != bytesTransferred[j])
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   555
                {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   556
                __PRINT3(_L("CDrivePublisher: KBytes[%d] %d->%d\n"), j, oldValue[j], bytesTransferred[j]);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   557
                }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   558
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   559
#endif
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   560
        if (KErrNone != iProperty.Set(bytesTransferred))
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   561
            {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   562
            __ASSERT_DEBUG(EFalse, User::Invariant());
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   563
            }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   564
        dataTransferred = ETrue;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   565
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   566
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   567
    return dataTransferred;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   568
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   569
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   570
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   571
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   572
Starts timer to periodically publish results.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   573
If the timer is not yet running then start it.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   574
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   575
void CUsbTransferPublisher::StartTimer()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   576
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   577
    if (!iTimerRunning)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   578
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   579
        // EDataTransferred event every second
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   580
        const TTimeIntervalMicroSeconds32 interval = 1 * 1000 * 1000;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   581
        TCallBack callback(PublishDataTransferredEvent, this);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   582
        OstTrace0(TRACE_SMASSSTORAGE_DRIVE, DRIVEPUBLISHER_120, "Starting timer");
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   583
        iTimer->Start(interval, interval, callback);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   584
        iTimerRunning = ETrue;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   585
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   586
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   587
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   588
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   589
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   590
Ensure that the Timer is stopped
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   591
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   592
void CUsbTransferPublisher::StopTimer()
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   593
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   594
    if (iTimerRunning)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   595
        {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   596
        OstTrace0(TRACE_SMASSSTORAGE_DRIVE, DRIVEPUBLISHER_130, "Stopping timer");
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   597
        iTimer->Cancel();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   598
        iTimerRunning = EFalse;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   599
        }
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   600
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   601
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   602
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   603
//----------------------------------------------------------------------------
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   604
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   605
Constructor for Write property
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   606
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   607
@param aArray
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   608
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   609
CUsbWriteTransferPublisher* CUsbWriteTransferPublisher::NewL(TRefBytesTransferedList aArray)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   610
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   611
    CUsbWriteTransferPublisher* self = new (ELeave) CUsbWriteTransferPublisher(aArray);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   612
    CleanupStack::PushL(self);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   613
    self->ConstructL();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   614
    CleanupStack::Pop();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   615
    return self;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   616
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   617
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   618
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   619
CUsbWriteTransferPublisher::CUsbWriteTransferPublisher(
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   620
    TRefBytesTransferedList aArray)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   621
    :
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   622
    CUsbTransferPublisher(EUsbMsDriveState_KBytesWritten, aArray)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   623
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   624
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   625
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   626
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   627
//----------------------------------------------------------------------------
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   628
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   629
Constructor for Read property
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   630
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   631
@param aArray
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   632
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   633
CUsbReadTransferPublisher* CUsbReadTransferPublisher::NewL(TRefBytesTransferedList aArray)
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   634
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   635
    CUsbReadTransferPublisher* self = new (ELeave) CUsbReadTransferPublisher(aArray);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   636
    CleanupStack::PushL(self);
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   637
    self->ConstructL();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   638
    CleanupStack::Pop();
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   639
    return self;
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   640
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   641
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   642
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   643
CUsbReadTransferPublisher::CUsbReadTransferPublisher(
286
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   644
    TRefBytesTransferedList aArray)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   645
    :
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   646
    CUsbTransferPublisher(EUsbMsDriveState_KBytesRead, aArray)
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   647
    {
48e57fb1237e 201039_11
hgs
parents: 0
diff changeset
   648
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   649
#endif // USB_TRANSFER_PUBLISHER