userlibandfileserver/fileserver/smassstorage/cusbmassstoragecontroller.cpp
author hgs
Mon, 11 Oct 2010 17:54:41 +0100
changeset 286 48e57fb1237e
parent 271 dc268b18d709
permissions -rw-r--r--
201039_11
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
271
dc268b18d709 201037_07
hgs
parents: 0
diff changeset
     1
// Copyright (c) 2004-2010 Nokia Corporation and/or its subsidiary(-ies).
0
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:
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    14
// CUsbMassStorageController implementation.
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    15
//
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    16
//
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    17
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    18
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    19
 @file
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    20
 @internalTechnology
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    21
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    22
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    23
#include <e32std.h>
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    24
#include "mtransport.h"
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    25
#include "mprotocol.h"
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    26
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    27
#include "scsiprot.h"
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    28
#include "cusbmassstorageserver.h"
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    29
#include "drivemanager.h"
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    30
#include "cusbmassstoragecontroller.h"
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    31
#include "cbulkonlytransport.h"
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    32
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    33
#include "OstTraceDefinitions.h"
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    34
#ifdef OST_TRACE_COMPILER_IN_USE
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    35
#include "cusbmassstoragecontrollerTraces.h"
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    36
#endif
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    37
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    38
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    39
Destructor
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    40
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    41
CUsbMassStorageController::~CUsbMassStorageController()
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    42
    {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    43
    delete iServer;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    44
    delete iProtocol;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    45
    delete iTransport;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    46
    delete iDriveManager;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    47
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    48
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    49
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    50
Creates the drive manager, transport, protocol and server
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    51
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    52
@param aMaxDrives Maximum number of Mass Storage drives supported.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    53
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    54
void CUsbMassStorageController::CreateL(RArray<TInt>& aDriveMapping)
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    55
    {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    56
    OstTraceFunctionEntry0(CUSBMASSSTORAGECONTROLLER_100);
271
dc268b18d709 201037_07
hgs
parents: 0
diff changeset
    57
#if !defined(__WINS__) && !defined(__X86__)
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    58
    iTransportLddFlag = EUsbcsc; // Create transport object using SC Ldd By default
271
dc268b18d709 201037_07
hgs
parents: 0
diff changeset
    59
#else
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    60
    iTransportLddFlag = EUsbc;
271
dc268b18d709 201037_07
hgs
parents: 0
diff changeset
    61
#endif
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    62
    //Save this value for use in the Reset method.
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    63
    iMaxDrives = aDriveMapping.Count();
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    64
    OstTrace1(TRACE_SMASSSTORAGE_FS, CUSBMASSSTORAGECONTROLLER_101,
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    65
              "MaxDrives = %d", iMaxDrives);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    66
    //Create and init drive manager
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    67
    iDriveManager = CDriveManager::NewL(aDriveMapping);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    68
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    69
    //Create transport and protocol and initialize them
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    70
    iTransport = CBulkOnlyTransport::NewL(iMaxDrives, *this, iTransportLddFlag);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    71
    if (!iTransport)
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    72
        User::Leave(KErrNoMemory);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    73
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    74
    iProtocol = CScsiProtocol::NewL(*iDriveManager);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    75
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    76
    //Create and start server
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    77
    iServer = CUsbMassStorageServer::NewLC(*this);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    78
    CleanupStack::Pop(iServer);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    79
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    80
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    81
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    82
Returns a reference to the drive manager
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    83
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    84
@return A reference to the drive manager
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    85
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    86
CDriveManager& CUsbMassStorageController::DriveManager()
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    87
    {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    88
    return *iDriveManager;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    89
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    90
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    91
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    92
void CUsbMassStorageController::GetTransport(MTransportBase* &aTransport)
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    93
    {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    94
    aTransport = iTransport;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
    95
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    96
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    97
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    98
Starts the transport and initializes the protocol.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    99
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   100
@param aConfig Reference to Mass Storage configuration data
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
TInt CUsbMassStorageController::Start(TMassStorageConfig& aConfig)
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   103
    {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   104
    OstTraceFunctionEntry0(CUSBMASSSTORAGECONTROLLER_200);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   105
    //Save this value for use in the Reset method.
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   106
    iConfig = aConfig;
0
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
    __ASSERT_DEBUG(iTransport, User::Invariant());
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   109
    if ((iTransport->InitialiseTransportL((TInt) iTransportLddFlag)) != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   110
        {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   111
        iTransportLddFlag = EUsbc; // If SC Ldd not present use the default USB Client Ldd
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   112
        delete iTransport;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   113
        iTransport = CBulkOnlyTransport::NewL(iMaxDrives, *this, iTransportLddFlag);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   114
        if (!iTransport)
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   115
            User::Leave(KErrNoMemory);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   116
        if ((iTransport->InitialiseTransportL((TInt) iTransportLddFlag)) != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   117
            return KErrNotFound;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   118
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   119
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   120
    TInt err = KErrNotReady;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   121
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   122
    if (iProtocol && iTransport)
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   123
        {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   124
        iTransport->RegisterProtocol(*iProtocol);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   125
        iProtocol->RegisterTransport(iTransport);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   126
        ((CScsiProtocol*)iProtocol)->SetScsiParameters(aConfig);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   127
        err = iTransport->Start();
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   128
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   129
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   130
    return err;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   131
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   132
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   133
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   134
Stops the transport.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   135
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   136
TInt CUsbMassStorageController::Stop()
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   137
    {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   138
    OstTraceFunctionEntry0(CUSBMASSSTORAGECONTROLLER_110);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   139
    TInt err = KErrNotReady;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   140
    if (iTransport)
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   141
        {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   142
        err = iTransport->Stop();
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   143
        }
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   144
    TInt i=0;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   145
    for (i=0; i<=iMaxDrives; ++i)
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   146
        {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   147
        iDriveManager->SetCritical(i, EFalse);   //unset critical
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   148
        }
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   149
    return err;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   150
    }
0
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
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   153
Delete the transport and protocol and start new ones.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   154
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   155
void CUsbMassStorageController::Reset()
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   156
    {
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   157
    OstTraceFunctionEntry0(CUSBMASSSTORAGECONTROLLER_120);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   158
    delete iProtocol;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   159
    iProtocol = NULL;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   160
286
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   161
    //Create transport and protocol and initialize them
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   162
    TRAPD(err,iProtocol = CScsiProtocol::NewL(*iDriveManager));
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   163
    err = err;
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   164
    __ASSERT_DEBUG(err==KErrNone, User::Invariant());
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   165
    iTransport->RegisterProtocol(*iProtocol);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   166
    iProtocol->RegisterTransport(iTransport);
48e57fb1237e 201039_11
hgs
parents: 271
diff changeset
   167
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   168