userlibandfileserver/fileserver/smassstorage/scsiprot.cpp
author hgs
Mon, 11 Oct 2010 17:54:41 +0100
changeset 286 48e57fb1237e
parent 90 947f0dc9f7a8
permissions -rw-r--r--
201039_11
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
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
//
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    15
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    16
#include <e32std.h>
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    17
#include "mtransport.h"
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    18
#include "mprotocol.h"
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    19
#include "scsiprot.h"
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    20
#ifdef MSDC_MULTITHREADED
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    21
#include "rwdrivethread.h"
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    22
#endif // MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    23
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    24
#include "OstTraceDefinitions.h"
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    25
#ifdef OST_TRACE_COMPILER_IN_USE
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    26
#include "scsiprotTraces.h"
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    27
#endif
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    28
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    29
// Helper macros
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    30
#define LBA(x) static_cast<TUint32>((x[3] << 24) | (x[4] << 16) | (x[5] << 8) | x[6])
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    31
#define LEN(x) static_cast<TUint16>((x[8] << 8) | x[9])
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    32
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    33
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    34
static const TUint32 KDefaultBlockSize = 0x200;  //default block size for FAT
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    35
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    36
static const TUint KUndefinedLun = 0xFFFF;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    37
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    38
static const TUint8 KAllPages = 0x3F;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    39
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    40
static const TUint8 KChangeableValues = 0x1;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    41
static const TUint8 KDefaultValues = 0x2;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    42
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    43
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    44
Default constructor for TSenseInfo
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    45
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    46
TSenseInfo::TSenseInfo()
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    47
    : iSenseCode(ENoSense),
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    48
      iAdditional(EAscNull),
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    49
      iQualifier(EAscqNull)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    50
    {}
0
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
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
Set sense with no additional info.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    55
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    56
@param aSenseCode sense key
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    57
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    58
void TSenseInfo::SetSense(TSenseCode aSenseCode)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    59
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    60
    iSenseCode = static_cast<TUint8>(aSenseCode);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    61
    iAdditional = EAscNull;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    62
    iQualifier = EAscqNull;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    63
    OstTraceExt3(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_SETSENSE1, "    SENSE CODE %d ASC %d ASC %d", iSenseCode, iAdditional, iQualifier);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    64
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    65
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    66
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    67
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    68
Set sense with additional info.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    69
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    70
@param aSenseCode sense key
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    71
@param aAdditional additional sense code (ASC)
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    72
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    73
void TSenseInfo::SetSense(TSenseCode aSenseCode, TAdditionalCode aAdditional)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    74
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    75
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    76
    iSenseCode = static_cast<TUint8>(aSenseCode);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    77
    iAdditional = static_cast<TUint8>(aAdditional);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    78
    iQualifier = EAscqNull;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    79
    OstTraceExt3(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_SETSENSE2, "    SENSE CODE %d ASC %d ASC %d", iSenseCode, iAdditional, iQualifier);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    80
    }
0
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
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
Set sense with additional info and qualifier.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    85
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    86
@param aSenseCode sense key
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    87
@param aAdditional additional sense code (ASC)
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    88
@param aQualifier additional sense code qualifier (ASCQ)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    89
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
    90
void TSenseInfo::SetSense(TSenseCode aSenseCode,
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    91
                          TAdditionalCode aAdditional,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    92
                          TAdditionalSenseCodeQualifier aQualifier)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    93
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    94
    iSenseCode = static_cast<TUint8>(aSenseCode);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    95
    iAdditional = static_cast<TUint8>(aAdditional);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    96
    iQualifier = static_cast<TUint8>(aQualifier);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    97
    OstTraceExt3(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_SETSENSE3, "    SENSE CODE %d ASC %d ASC %d", iSenseCode, iAdditional, iQualifier);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
    98
    }
0
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
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
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
Creates the CScsiProtocol object.  Called during controller initialisation.
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 aDriveManager reference to the drive manager object
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
CScsiProtocol* CScsiProtocol::NewL(CDriveManager& aDriveManager)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   109
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   110
    CScsiProtocol* self = new (ELeave) CScsiProtocol(aDriveManager);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   111
    CleanupStack::PushL(self);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   112
    self->ConstructL();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   113
    CleanupStack::Pop();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   114
    return self;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   115
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   116
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   117
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   118
c'tor
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
@param aDriveManager reference to the drive manager object
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
CScsiProtocol::CScsiProtocol(CDriveManager& aDriveManager):
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   123
    iDriveManager(aDriveManager),
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   124
    iLastCommand(EUndefinedCommand),
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   125
    iLastLun(KUndefinedLun),
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   126
    iMediaWriteSize(KDefaultMediaWriteSize)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   127
    {
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   128
#ifdef USB_TRANSFER_PUBLISHER
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   129
    iWriteTransferPublisher = CUsbWriteTransferPublisher::NewL(iBytesWritten);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   130
    iReadTransferPublisher = CUsbReadTransferPublisher::NewL(iBytesRead);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   131
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   132
    for (TUint i = 0; i < KUsbMsMaxDrives; i++)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   133
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   134
        iBytesRead[i] = 0;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   135
        iBytesWritten[i] = 0;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   136
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   137
#else
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   138
    iWriteTransferPublisher = CDriveWriteTransferPublisher::NewL(aDriveManager.iDrives);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   139
    iReadTransferPublisher = CDriveReadTransferPublisher::NewL(aDriveManager.iDrives);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   140
#endif
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   141
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   142
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
CScsiProtocol::~CScsiProtocol()
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   145
    {
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   146
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   147
    OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_DES, "Deleting Drive Threads");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   148
    delete iWriteDriveThread;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   149
    delete iReadDriveThread;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   150
#endif // MSDC_MULTITHREADED
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   151
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   152
    delete iWriteTransferPublisher;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   153
    delete iReadTransferPublisher;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   154
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   155
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 CScsiProtocol::ConstructL()
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   158
    {
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   159
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   160
    OstTrace0(TRACE_SMASSSTORAGE, _CSCSIPROTOCOL, "Creating Drive Threads");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   161
    iWriteDriveThread = CWriteDriveThread::NewL();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   162
    iReadDriveThread = CReadDriveThread::NewL();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   163
#endif // MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   164
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   165
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   166
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   167
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   168
Associates the transport with the protocol. Called during initialisation of the controller.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   169
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   170
@param aTransport pointer to the transport object
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   171
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   172
void CScsiProtocol::RegisterTransport(MTransportBase* aTransport)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   173
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   174
    iTransport = aTransport;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   175
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   176
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   177
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   178
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   179
Called by the Transport when it detects that the USB device is either running
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   180
at High Speed or is at least capable of HS operation. The Protocol can use this
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   181
information (for instance) to select the optimal write block size to use.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   182
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   183
This function is preferably called before actual MS data transfer operation
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   184
starts, and usually only once.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   185
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
void CScsiProtocol::ReportHighSpeedDevice()
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   188
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   189
    iMediaWriteSize = KHsMediaWriteSize;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   190
    OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_REPORTHIGHSPEEDDEVICE,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   191
              "HS Device reported: SCSI will use 0x%x bytes disk write size", iMediaWriteSize);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   192
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   193
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   194
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   195
TInt CScsiProtocol::SetScsiParameters(TMassStorageConfig aConfig)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   196
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   197
    iConfig = aConfig;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   198
    return KErrNone;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   199
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   200
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   201
#ifdef MSDC_MULTITHREADED
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   202
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   203
void CScsiProtocol::ProcessWriteComplete (TUint8* aAddress, TAny* aPtr)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   204
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   205
    ((CScsiProtocol*)aPtr)->iTransport->ProcessReadData(aAddress);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   206
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   207
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   208
void CScsiProtocol::InitializeBufferPointers(TPtr8& aDes1, TPtr8& aDes2) // Todo Change name later - InitializeReadBufferSomething
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   209
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   210
    iReadDriveThread->iThreadContext->iBuffer.SetUpReadBuf(aDes1, aDes2);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   211
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   212
#endif
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   213
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   214
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   215
Called by the transport layer when a packet is available for decoding.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   216
If an error occurs, the sense code is updated and EFalse is returned.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   217
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   218
@param aData
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   219
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   220
@return  ETrue if command was decoded and executed successfully
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   221
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   222
TBool CScsiProtocol::DecodePacket(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   223
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   224
    TUint command = aData[1];
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   225
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   226
    if (command != ERequestSense)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   227
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   228
        iSenseInfo.SetSense(TSenseInfo::ENoSense);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   229
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   230
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   231
    OstTraceExt2(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_DECODEPACKET, "Command=0x%x LUN=%d", command, aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   232
    switch (command)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   233
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   234
        case ETestUnitReady:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   235
            HandleUnitReady(aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   236
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   237
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   238
        case ERequestSense:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   239
            HandleRequestSense(aData);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   240
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   241
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   242
        case EInquiry:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   243
            HandleInquiry(aData, aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   244
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   245
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   246
        case EModeSense6:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   247
            HandleModeSense6(aData, aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   248
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   249
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
   250
        case EModeSense10:
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
   251
            HandleModeSense10(aData, aLun);
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
   252
            break;
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
   253
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   254
        case EStartStopUnit:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   255
            HandleStartStopUnit(aData, aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   256
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   257
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   258
        case EPreventMediaRemoval:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   259
            HandlePreventMediaRemoval(aData, aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   260
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   261
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   262
        case EReadCapacity:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   263
            HandleReadCapacity(aData, aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   264
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   265
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   266
        case ERead10:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   267
            HandleRead10(aData, aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   268
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   269
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   270
        case EWrite10:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   271
            HandleWrite10(aData,aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   272
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   273
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   274
        case EVerify10:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   275
            HandleVerify10(aData, aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   276
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   277
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   278
        case EReadFormatCapacities:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   279
            HandleReadFormatCapacities(aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   280
            break;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   281
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   282
        default:
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   283
            iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidCmdCode);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   284
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   285
    return(iSenseInfo.SenseOk());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   286
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   287
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   288
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   289
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   290
Checks if drive ready
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   291
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   292
@param aLun Logic unit number
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   293
@return pointer to drive correspondent to LUN if drive mounted and ready, NULL otherwise
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   294
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   295
CMassStorageDrive* CScsiProtocol::GetCheckDrive(TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   296
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   297
    TInt err=KErrNone;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   298
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   299
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   300
    // check for deferred errors
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   301
    if (iWriteDriveThread->DeferredError())
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   302
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   303
        iWriteDriveThread->ClearDeferredError();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   304
        iDeferredSenseInfo.SetSense(TSenseInfo::EMediumError);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   305
        return NULL;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   306
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   307
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   308
#endif
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   309
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   310
    CMassStorageDrive* drive= iDriveManager.Drive(aLun, err);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   311
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   312
    if (err !=KErrNone || drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   313
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   314
        OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_GETCHECKDRIVE1, "No drive available");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   315
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::ELuNotSupported);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   316
        return NULL;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   317
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   318
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   319
    CMassStorageDrive::TMountState mountState = drive->MountState();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   320
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   321
    if (mountState == CMassStorageDrive::EDisconnected || mountState == CMassStorageDrive::EConnecting)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   322
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   323
        OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_GETCHECKDRIVE2, "Drive disconnected");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   324
        iSenseInfo.SetSense(TSenseInfo::ENotReady,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   325
                            TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   326
        return NULL;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   327
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   328
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   329
    CMassStorageDrive::TDriveState state = drive->CheckDriveState();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   330
    if (state == CMassStorageDrive::EMediaNotPresent || state == CMassStorageDrive::ELocked)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   331
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   332
        OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_GETCHECKDRIVE3, "Media not present or locked. state =0x%X", state);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   333
        iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   334
        return NULL;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   335
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   336
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   337
    if (drive->IsMediaChanged(ETrue))  //reset "media changed" status
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   338
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   339
        OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_GETCHECKDRIVE4, "Media was changed");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   340
        // SAM-2 Section 5.9.5 Unit Attention Condition
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   341
        iSenseInfo.SetSense(TSenseInfo::EUnitAttention, TSenseInfo::ENotReadyToReadyChange);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   342
        iDriveManager.Connect(aLun);   //publish event to USB app
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   343
        return NULL;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   344
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   345
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   346
    if (mountState == CMassStorageDrive::EDisconnecting)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   347
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   348
        OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_GETCHECKDRIVE5, "Drive disconnecting");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   349
        iSenseInfo.SetSense(TSenseInfo::ENotReady,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   350
                            TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   351
        return NULL;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   352
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   353
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   354
    return drive;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   355
    }
0
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
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
Command Parser for the UNIT READY command (0x00)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   360
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   361
@param aLun Logic unit number
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   362
@return ETrue if successful,
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   363
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   364
TBool CScsiProtocol::HandleUnitReady(TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   365
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   366
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_TESTUNITREADY, ">>> TEST UNIT READY");
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   367
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   368
    iWriteDriveThread->WaitForWriteEmpty();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   369
#endif
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   370
    return GetCheckDrive(aLun) ? (TBool)ETrue : (TBool)EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   371
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   372
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
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   375
Command Parser for the REQUEST SENSE command (0x03)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   376
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   377
@return ETrue if successful,
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   378
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   379
TBool CScsiProtocol::HandleRequestSense(TPtrC8& aData)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   380
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   381
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_REQUESTSENSE, ">>> REQUEST SENSE");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   382
    TUint length = aData[5];
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   383
    OstTrace1(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_REQUESTSENSE1, "    length = %d", length);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   384
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   385
    TPtr8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   386
    iTransport->GetCommandBufPtr(writeBuf, KRequestSenseCommandLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   387
    writeBuf.FillZ(KRequestSenseCommandLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   388
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   389
    TSenseInfo* senseInfo;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   390
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   391
    if (!iDeferredSenseInfo.SenseOk())
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   392
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   393
        writeBuf[00] = 0x71; //(deferred errors)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   394
        senseInfo = &iDeferredSenseInfo;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   395
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   396
    else
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   397
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   398
        writeBuf[00] = 0x70; //(current errors)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   399
        senseInfo = &iSenseInfo;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   400
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   401
#else
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   402
    senseInfo = &iSenseInfo;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   403
    writeBuf[00] = 0x70; //(current errors)
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   404
#endif
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   405
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   406
    writeBuf[02] = static_cast<TUint8>(senseInfo->iSenseCode & 0x0F);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   407
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   408
    writeBuf[12] = senseInfo->iAdditional;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   409
    writeBuf[13] = senseInfo->iQualifier;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   410
    if (length<18 && length >=8)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   411
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   412
        writeBuf.SetLength(length);  //length of response code data
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   413
        writeBuf[07] = TUint8(length - 8);  //additional sence length
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   414
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   415
    else if (length >= KRequestSenseCommandLength)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   416
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   417
        writeBuf[07] = KRequestSenseCommandLength - 8;  // we have max 18 byte to send
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   418
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   419
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   420
    OstTraceExt4(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_REQUESTSENSE2,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   421
             "    Response=0x%x Sense=0x%x, Additional=0x%x, Qualifier=0x%x",
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   422
             (TUint)writeBuf[0], (TUint)writeBuf[02], (TUint)writeBuf[12], (TUint)writeBuf[13]);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   423
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   424
    TPtrC8 writeBuf1 = writeBuf.Left(length);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   425
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   426
    iTransport->SetupWriteData(writeBuf1);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   427
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   428
    // clear the sense info
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   429
    iSenseInfo.SetSense(TSenseInfo::ENoSense);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   430
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   431
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   432
    iDeferredSenseInfo.SetSense(TSenseInfo::ENoSense);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   433
#endif
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   434
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   435
    return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   436
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   437
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   438
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   439
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   440
Command Parser for the INQUIRY command (0x12)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   441
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   442
@param aLun Logic unit number
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   443
@return ETrue if successful,
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   444
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   445
TBool CScsiProtocol::HandleInquiry(TPtrC8& aData, TUint  aLun )
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   446
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   447
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_INQUIRY, ">>> INQUIRY");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   448
    TBool cmdDt = aData[2] & 0x2;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   449
    TBool evpd  = aData[2] & 0x1;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   450
    TUint8 page = aData[3];
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   451
    if (cmdDt || evpd || page || aLun >= KUsbMsMaxDrives)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   452
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   453
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   454
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   455
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   456
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   457
    TPtr8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   458
    iTransport->GetCommandBufPtr(writeBuf, KInquiryCommandLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   459
    writeBuf.FillZ(KInquiryCommandLength);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   460
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   461
    writeBuf[1] = 0x80; // MSB: RMB : Removable
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   462
    writeBuf[3] = 0x02; // AERC, TrmTsk, NormACA, Response Data Format
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   463
    writeBuf[4] = 0x1F; // Additional Length
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   464
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   465
    TPtr8 vendorId(&writeBuf[8], 8, 8);     // Vendor ID (Vendor Specific/Logged by T10)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   466
    vendorId.Fill(' ', 8);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   467
    vendorId.Copy(iConfig.iVendorId);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   468
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   469
    TPtr8 productId(&writeBuf[16], 16, 16); // Product ID (Vendor Specific)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   470
    productId.Fill(' ', 16);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   471
    productId.Copy(iConfig.iProductId);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   472
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   473
    TPtr8 productRev(&writeBuf[32], 4, 4);      // Product Revision Level (Vendor Specific)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   474
    productRev.Fill(' ', 4);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   475
    productRev.Copy(iConfig.iProductRev);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   476
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   477
    OstTraceData(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_INQUIRY1, "Vendor ID %s", vendorId.Ptr(), vendorId.Length());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   478
    OstTraceData(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_INQUIRY2, "Product ID %s", productId.Ptr(), productId.Length());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   479
    OstTraceData(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_INQUIRY3, "Product Rev %s", productRev.Ptr(), productRev.Length());
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   480
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   481
    TUint length = aData[5];
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   482
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   483
    TPtrC8 writeBuf1 = writeBuf.Left(length);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   484
    iTransport->SetupWriteData(writeBuf1);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   485
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   486
    iSenseInfo.SetSense(TSenseInfo::ENoSense);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   487
    return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   488
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   489
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
 Command Parser for the START STOP UNIT command (0x1B)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   493
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   494
 @param aData command data (started form position 1)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   495
 @param aLun Logic unit number
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   496
 @return ETrue if successful, TFalse otherwise
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   497
 */
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   498
TBool CScsiProtocol::HandleStartStopUnit(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   499
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   500
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_STARTSTOPUNIT, ">>> START STOP UNIT");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   501
    const TUint8 KStartMask = 0x01;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   502
    const TUint8 KImmedMask = 0x01;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   503
    const TUint8 KLoejMask = 0x02;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   504
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   505
    TBool immed = aData[2] & KImmedMask ? (TBool)ETrue : (TBool)EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   506
    TBool start = aData[5] & KStartMask ? (TBool)ETrue : (TBool)EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   507
    TBool loej = aData[5] & KLoejMask ? (TBool)ETrue : (TBool)EFalse;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   508
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   509
    OstTrace1(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_STARTSTOPUNIT1, "    IMMED = %d", immed);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   510
    OstTrace1(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_STARTSTOPUNIT2, "    START = %d", start);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   511
    OstTrace1(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_STARTSTOPUNIT3, "    LOEJ = %d", loej);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   512
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   513
    TInt err(KErrNone);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   514
    if (loej)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   515
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   516
        if(start)   //Start unit
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   517
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   518
            err = iDriveManager.Connect(aLun);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   519
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   520
#ifdef USB_TRANSFER_PUBLISHER
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   521
            iBytesRead[aLun] = 0;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   522
            iBytesWritten[aLun] = 0;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   523
#endif
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   524
            // publish the initial values
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   525
            iWriteTransferPublisher->DoPublishDataTransferredEvent();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   526
            iReadTransferPublisher->DoPublishDataTransferredEvent();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   527
            }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   528
        else        //Stop unit
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   529
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   530
            iDriveManager.SetCritical(aLun, EFalse);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   531
            err = iDriveManager.Disconnect(aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   532
            }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   533
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   534
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   535
    if (err !=KErrNone)  //actually we have error here only if the LUN is incorrect
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   536
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   537
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::ELuNotSupported);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   538
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   539
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   540
    if (immed)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   541
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   542
        return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   543
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   544
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   545
    CMassStorageDrive* drive= iDriveManager.Drive(aLun, err);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   546
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   547
    if (err !=KErrNone || drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   548
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   549
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::ELuNotSupported);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   550
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   551
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   552
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   553
    TInt  timeLeft (20);   // 1 sec timeout
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   554
    CMassStorageDrive::TMountState mountState;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   555
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   556
    do
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   557
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   558
        User::After(1000 * 50);     // 50 mSec
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   559
        --timeLeft;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   560
        mountState = drive->MountState();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   561
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   562
        if ((!start && mountState != CMassStorageDrive::EConnected)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   563
             ||
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   564
             (start &&
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   565
                (mountState == CMassStorageDrive::EDisconnecting ||
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   566
                mountState == CMassStorageDrive::EConnected))
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   567
            )
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   568
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   569
            return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   570
            }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   571
        } while (timeLeft>0);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   572
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   573
    //timeout happend
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   574
    iSenseInfo.SetSense(TSenseInfo::ENotReady,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   575
                        TSenseInfo::EAscLogicalUnitDoesNotRespondToSelection);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   576
    return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   577
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   578
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   579
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   580
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   581
Command Parser for the PREVENT/ALLOW MEDIA REMOVAL command (0x1E)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   582
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   583
@param aData command data (started form position 1)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   584
@param aLun Logic unit number
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   585
@return ETrue if successful.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   586
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   587
TBool CScsiProtocol::HandlePreventMediaRemoval(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   588
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   589
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_PREVENTMEDIAREMOVAL, ">>> PREVENT MEDIA REMOVAL");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   590
    CMassStorageDrive* drive=GetCheckDrive(aLun);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   591
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   592
    if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   593
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   594
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   595
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   596
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   597
    TInt prevent = aData[5] & 0x01;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   598
    OstTrace1(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_PREVENTMEDIAREMOVAL1, "    prevent = %d", prevent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   599
    iDriveManager.SetCritical(aLun, prevent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   600
    return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   601
    }
0
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
/** Cancel active state, Invoked by transnport when it stops */
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   605
TInt CScsiProtocol::Cancel()
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   606
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   607
    iDriveManager.SetCritical(CDriveManager::KAllLuns, EFalse);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   608
    return KErrNone;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   609
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   610
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   611
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   612
TBool CScsiProtocol::HandleReadFormatCapacities(TUint aLun)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   613
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   614
 * Command Parser for the READ FORMAT CAPACITIES command (0x23)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   615
 *
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   616
 * @return ETrue if successful, else a standard Symbian OS error code.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   617
 */
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   618
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   619
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_READFORMATCAPACITIES, ">>> READ FORMAT CAPACITIES");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   620
    CMassStorageDrive* drive=GetCheckDrive(aLun);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   621
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   622
    if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   623
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   624
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   625
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   626
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   627
    TLocalDriveCapsV4 driveInfo;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   628
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   629
    TInt err = drive->Caps(driveInfo);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   630
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   631
    if(err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   632
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   633
        OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEREADFORMATCAPACITIES, "Can't obtain drive Caps. Err=%d", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   634
        iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   635
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   636
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   637
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   638
    TInt64 driveBlocks = (driveInfo.iDriveAtt & KDriveAttLogicallyRemovable) ? driveInfo.iSize : driveInfo.MediaSizeInBytes();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   639
    driveBlocks /= MAKE_TINT64(0, KDefaultBlockSize);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   640
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   641
    TPtr8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   642
    iTransport->GetCommandBufPtr(writeBuf, KReadFormatCapacitiesCommandLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   643
    writeBuf.FillZ(KReadFormatCapacitiesCommandLength);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   644
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   645
    writeBuf[3] = 0x08; // Capacity List Length
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   646
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   647
    TUint32 numBlocks = I64LOW(driveBlocks);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   648
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   649
    writeBuf[4] = static_cast<TUint8>((numBlocks & 0xFF000000) >> 24);  // Number of blocks
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   650
    writeBuf[5] = static_cast<TUint8>((numBlocks & 0x00FF0000) >> 16);  //
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   651
    writeBuf[6] = static_cast<TUint8>((numBlocks & 0x0000FF00) >> 8);   //
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   652
    writeBuf[7] = static_cast<TUint8>((numBlocks & 0x000000FF));        //
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   653
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   654
    writeBuf[8] = 0x02; // Formatted size
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   655
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   656
    writeBuf[9]  = 0x00;    // 512 Byte Blocks
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   657
    writeBuf[10] = 0x02;    //
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   658
    writeBuf[11] = 0x00;    //
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   659
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   660
    TPtrC8 writeBuf1 = writeBuf;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   661
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   662
    iTransport->SetupWriteData(writeBuf1);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   663
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   664
    return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   665
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   666
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   667
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   668
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   669
Command Parser for the READ CAPACITY(10) command (0x25)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   670
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   671
@param aData command data (started form position 1)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   672
@param aLun Logic unit number
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   673
@return ETrue if successful.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   674
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   675
TBool CScsiProtocol::HandleReadCapacity(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   676
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   677
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_READCAPACITY, ">>> READ CAPACITY");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   678
    CMassStorageDrive* drive=GetCheckDrive(aLun);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   679
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   680
    if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   681
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   682
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   683
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   684
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   685
    TInt pmi = aData[9] & 0x01;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   686
    TInt lba = aData[3] | aData[4] | aData[5] | aData[6];
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   687
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   688
    if (pmi || lba)   //do not support partial medium indicator
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   689
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   690
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   691
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   692
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   693
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   694
    TLocalDriveCapsV4 driveInfo;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   695
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   696
    TInt err = drive->Caps(driveInfo);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   697
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   698
    if(err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   699
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   700
        OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEREADCAPACITY1, "ERROR: Can't obtain drive Caps Err=%d", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   701
        iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   702
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   703
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   704
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   705
    TInt64 driveBlocks = 0;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   706
    if (driveInfo.iDriveAtt & KDriveAttLogicallyRemovable)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   707
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   708
        // Partition Access only
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   709
        driveBlocks = driveInfo.iSize / MAKE_TINT64(0, KDefaultBlockSize);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   710
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   711
    else
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   712
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   713
        // whole Media Access
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   714
        driveBlocks = driveInfo.MediaSizeInBytes() / MAKE_TINT64(0, KDefaultBlockSize) - 1;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   715
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   716
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   717
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   718
    TPtr8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   719
    iTransport->GetCommandBufPtr(writeBuf, KReadCapacityCommandLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   720
    writeBuf.FillZ(KReadCapacityCommandLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   721
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   722
    if (I64HIGH(driveBlocks) == 0)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   723
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   724
        TUint32 numBlocks = I64LOW(driveBlocks);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   725
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   726
        OstTraceExt2(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_HANDLEREADCAPACITY2,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   727
                  "    Block size=0x%x, NumBlocks=0x%x",
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   728
                  KDefaultBlockSize, numBlocks);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   729
        writeBuf[0] = static_cast<TUint8>((numBlocks & 0xFF000000) >> 24);  // Number of blocks
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   730
        writeBuf[1] = static_cast<TUint8>((numBlocks & 0x00FF0000) >> 16);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   731
        writeBuf[2] = static_cast<TUint8>((numBlocks & 0x0000FF00) >> 8);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   732
        writeBuf[3] = static_cast<TUint8>((numBlocks & 0x000000FF));
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   733
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   734
    else
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   735
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   736
        writeBuf[0] = writeBuf[1] = writeBuf[2] = writeBuf[3] = 0xFF;  // indicate that size more then )0xFFFFFFFF
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   737
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   738
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   739
    writeBuf[4] = static_cast<TUint8>((KDefaultBlockSize & 0xFF000000) >> 24);  // Block Size
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   740
    writeBuf[5] = static_cast<TUint8>((KDefaultBlockSize & 0x00FF0000) >> 16);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   741
    writeBuf[6] = static_cast<TUint8>((KDefaultBlockSize & 0x0000FF00) >> 8);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   742
    writeBuf[7] = static_cast<TUint8>((KDefaultBlockSize & 0x000000FF));
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   743
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   744
    TPtrC8 writeBuf1 = writeBuf;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   745
    iTransport->SetupWriteData(writeBuf1);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   746
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   747
    return KErrNone;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   748
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   749
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   750
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   751
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   752
Command Parser for the READ10 command (0x28)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   753
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   754
@param aData command data (started form position 1)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   755
@param aLun Logic unit number
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   756
@return ETrue if successful.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   757
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   758
TBool CScsiProtocol::HandleRead10(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   759
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   760
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_READ10, ">>> READ(10)");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   761
    CMassStorageDrive* drive = GetCheckDrive(aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   762
    if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   763
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   764
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   765
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   766
    TInt rdProtect = aData[2] >> 5;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   767
    if (rdProtect)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   768
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   769
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   770
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   771
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   772
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   773
    const TUint32 lba = LBA(aData);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   774
    const TUint32 len = LEN(aData);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   775
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   776
    OstTraceExt2(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_HANDLEREAD10_1,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   777
              "    LBA = 0x%x Transfer Len = 0x%x", lba, len);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   778
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   779
    if (!len)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   780
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   781
        return ETrue; // do nothing - this is not an error
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   782
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   783
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   784
    TLocalDriveCapsV4 driveInfo;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   785
    TInt err = drive->Caps(driveInfo);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   786
    if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   787
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   788
        OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEREAD10_2, "Can't obtain drive Caps. Err=%d", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   789
        iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   790
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   791
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   792
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   793
    const TInt64 bOffset = MAKE_TINT64(0, lba) * KDefaultBlockSize;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   794
    const TInt bLength = len * KDefaultBlockSize;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   795
    const TInt64 theEnd = bOffset + MAKE_TINT64(0, bLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   796
    const TInt64 mediaSize = (driveInfo.iDriveAtt & KDriveAttLogicallyRemovable) ? driveInfo.iSize : driveInfo.MediaSizeInBytes() ;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   797
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   798
    if (theEnd > mediaSize)  //check if media big enough for this request
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   799
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   800
        OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEREAD10_3, "ERROR: Requested size is out of media range");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   801
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::ELbaOutOfRange);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   802
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   803
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   804
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   805
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   806
    iWriteDriveThread->WaitForWriteEmpty();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   807
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   808
    // check if our buffer can hold requested data
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   809
    if (iReadDriveThread->iThreadContext->MaxBufferLength() < bLength)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   810
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   811
        OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEREAD10_4, "ERROR: Buffer too small");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   812
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   813
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   814
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   815
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   816
    // Optimisation note : If the host is reading from sectors it just wrote to,
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   817
    // then we have to force a cache-miss so that the real data is read from the
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   818
    // drive. It would be possible to service the read from the write buffers,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   819
    // but as the host is probably trying to verify the write data, we don't do
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   820
    // that for now.
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   821
    if (!iReadDriveThread->ReadDriveData(drive, bOffset, bLength, iWriteDriveThread->IsRecentlyWritten(bOffset,bLength)))
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   822
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   823
        iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   824
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   825
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   826
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   827
    iWriteDriveThread->SetCommandWrite10(EFalse);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   828
    TBlockDesc* &desc = iReadDriveThread->iThreadContext->iBuffer.iDescReadPtr;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   829
    TPtrC8 writeBuf1 = desc->iBuf;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   830
#else
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   831
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   832
    TPtr8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   833
    iTransport->GetReadDataBufPtr(writeBuf);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   834
    // check if our buffer can hold requested data
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   835
    if (writeBuf.MaxLength() < bLength)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   836
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   837
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   838
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   839
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   840
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   841
    err = drive->Read(bOffset, bLength, writeBuf, drive->IsWholeMediaAccess());
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   842
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   843
    if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   844
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   845
        OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEREAD10_5, "ERROR: Read failed err=%d", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   846
        iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   847
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   848
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   849
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   850
    TPtrC8 writeBuf1 = writeBuf;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   851
#endif // MSDC_MULTITHREADED
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   852
#ifdef USB_TRANSFER_PUBLISHER
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   853
    iBytesRead[aLun] += writeBuf1.Length();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   854
#endif
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   855
    iReadTransferPublisher->StartTimer();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   856
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   857
    // Set up data write to the host
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   858
    iTransport->SetupWriteData(writeBuf1);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   859
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   860
    return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   861
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   862
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   863
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   864
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   865
Command Parser for the WRITE(10) command (0x2A)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   866
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   867
@param aData command data (started form position 1)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   868
@param aLun Logic unit number
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   869
@return ETrue if successful.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   870
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   871
TBool CScsiProtocol::HandleWrite10(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   872
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   873
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_WRITE10, ">>> WRITE(10)");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   874
    CMassStorageDrive* drive = GetCheckDrive(aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   875
    if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   876
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   877
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   878
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   879
    TInt wrProtect = aData[2] >> 5;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   880
    if (wrProtect)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   881
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   882
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   883
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   884
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   885
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   886
    const TUint32 lba = LBA(aData);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   887
    const TUint32 len = LEN(aData);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   888
    OstTraceExt2(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_HANDLEWRITE10_1, "LBA = 0x%x, Transfer Len = 0x%x", lba, len);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   889
    if (!len)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   890
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   891
        return ETrue; // do nothing - this is not an error
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   892
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   893
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   894
    TLocalDriveCapsV4 driveInfo;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   895
    TInt err = drive->Caps(driveInfo);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   896
    if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   897
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   898
        OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_WRITE10_2, "ERROR: Can't obtain drive Caps Err=%d", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   899
        iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   900
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   901
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   902
    if (driveInfo.iMediaAtt & KMediaAttWriteProtected ||
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   903
        driveInfo.iMediaAtt & KMediaAttLocked)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   904
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   905
        iSenseInfo.SetSense(TSenseInfo::EDataProtection, TSenseInfo::EWriteProtected);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   906
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   907
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   908
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   909
    const TInt64 bOffset = MAKE_TINT64(0, lba) * KDefaultBlockSize;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   910
    iBytesRemain = len * KDefaultBlockSize;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   911
    const TInt64 theEnd = bOffset + MAKE_TINT64(0, iBytesRemain);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   912
    const TInt64 mediaSize = (driveInfo.iDriveAtt & KDriveAttLogicallyRemovable) ? driveInfo.iSize : driveInfo.MediaSizeInBytes() ;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   913
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   914
    if (theEnd > mediaSize)  //check if media big enough for this request
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   915
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   916
        OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEWRITE10_3, "Requested size is out of media range");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   917
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::ELbaOutOfRange);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   918
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   919
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   920
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   921
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   922
    iWriteDriveThread->SetCommandWrite10(ETrue);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   923
#endif
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   924
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   925
    // Set up the first request for data from the host - either
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   926
    // KMaxBufSize or the entire transfer length, whichever is smallest.
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   927
    TUint thisLength = (iBytesRemain > KMaxBufSize) ? KMaxBufSize : iBytesRemain;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   928
    thisLength = (thisLength > iMediaWriteSize) ? iMediaWriteSize : thisLength;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   929
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   930
    iOffset = bOffset;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   931
    iLastCommand = EWrite10;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   932
    iLastLun = aLun;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   933
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   934
    iWriteTransferPublisher->StartTimer();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   935
    iTransport->SetupReadData(thisLength);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   936
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   937
    return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   938
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   939
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   940
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   941
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   942
Command Parser for the VERIFY(10) command (0x2F)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   943
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   944
@param aData command data (started form position 1)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   945
@param aLun Logic unit number
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   946
@return ETrue if successful.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   947
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   948
TBool CScsiProtocol::HandleVerify10(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   949
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   950
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_VERIFY10, ">>> VERIFY(10)");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   951
    CMassStorageDrive* drive = GetCheckDrive(aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   952
    if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   953
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   954
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   955
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   956
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   957
    TInt vrProtect = aData[2] >> 5;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   958
    if (vrProtect)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   959
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   960
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   961
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   962
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   963
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   964
    const TUint32 lba = LBA(aData);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   965
    const TUint32 len = LEN(aData);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   966
    OstTraceExt2(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_VERIFY10_1, "VERIFY(10) : LBA = 0x%x Transfer Len = 0x%x", lba, len);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   967
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   968
    TInt bytChk = aData[2] & 0x02;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   969
    if (!len)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   970
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   971
        return ETrue; // do nothing - this is not an error
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   972
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   973
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   974
    TLocalDriveCapsV4 driveInfo;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   975
    TInt err = drive->Caps(driveInfo);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   976
    if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   977
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   978
        OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_VERIFY10_2, "ERROR: Can't obtain drive Caps Err=%d", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   979
        iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   980
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   981
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   982
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   983
    const TInt64 bOffset = MAKE_TINT64(0, lba) * KDefaultBlockSize;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   984
    const TInt bLength = len * KDefaultBlockSize;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   985
    const TInt64 theEnd = bOffset + MAKE_TINT64(0, bLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   986
    const TInt64 mediaSize = (driveInfo.iDriveAtt & KDriveAttLogicallyRemovable) ? driveInfo.iSize : driveInfo.MediaSizeInBytes() ;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   987
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   988
    // check if media big enough for this request
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   989
    if (theEnd > mediaSize)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   990
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   991
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::ELbaOutOfRange);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   992
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   993
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   994
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   995
    // check if our buffer can hold requested data
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   996
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   997
    if (iWriteDriveThread->iThreadContext->MaxBufferLength() < bLength)
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
   998
#else
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
   999
    TPtr8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1000
    iTransport->GetReadDataBufPtr(writeBuf);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1001
    if (writeBuf.MaxLength() < bLength)
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1002
#endif
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1003
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1004
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest, TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1005
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1006
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1007
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1008
    if (!bytChk)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1009
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1010
        // BYTCHK==0 : Perform a medium verification with no data comparison and not transfer any data from the application client data-out buffer.
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1011
        // The device should attempt to read from the specified locations
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1012
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1013
        TPtr8 writeBuf = iWriteDriveThread->iThreadContext->GetReadBuffer(bLength);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1014
#else
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1015
        writeBuf.SetLength(bLength);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1016
#endif
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1017
        err = drive->Read(bOffset, bLength, writeBuf, drive->IsWholeMediaAccess());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1018
        if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1019
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1020
            iSenseInfo.SetSense(TSenseInfo::EMisCompare);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1021
            return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1022
            }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1023
        return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1024
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1025
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1026
    // BYTCHK==1 : perform a byte-by-byte comparison of user data read from the medium & user data transferred from the application client data-out buffer.
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1027
    // The host sends data in the data-transport phase, and the device should verify that the received data matches what is stored in the device.
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1028
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1029
    iOffset = bOffset;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1030
    iLastCommand = EVerify10;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1031
    iLastLun = aLun;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1032
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1033
    iTransport->SetupReadData(bLength);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1034
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1035
    return ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1036
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1037
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1038
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1039
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1040
Called by the transport when the requested data has been read or an error has
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1041
occurred during the read.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1042
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1043
@param aError Indicate if an error occurs during reading data by transport.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1044
@return KErrAbort if command processing is complete but has failed,
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1045
        KErrCompletion if sufficient data is available in the buffer to process
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1046
        the transfer immediately, KErrNotReady if insufficient data is
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1047
        available in the buffer so the transport should wait for it to arrive,
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1048
        KErrNone if command processing is complete and was successful.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1049
*/
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1050
TInt CScsiProtocol::ReadComplete(TInt aError)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1051
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1052
    OstTrace1(TRACE_SMASSSTORAGE_MEDIA, CSCSIPROTOCOL_READCOMPLETE0, "ReadComplete = 0x%X", aError);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1053
    const TInt64 bOffset = iOffset;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1054
    TUint8 lastCommand = iLastCommand;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1055
    TUint lastLun = iLastLun;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1056
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1057
    iOffset = 0;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1058
    iLastCommand = EUndefinedCommand;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1059
    iLastLun = KUndefinedLun;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1060
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1061
//  OstTrace1(TRACE_SMASSSTORAGE_MEDIA, CSCSIPROTOCOL_READCOMPLETE1, "lastCommand = d", lastCommand);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1062
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1063
    if (aError != KErrNone ||
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1064
        lastCommand == EUndefinedCommand ||
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1065
        lastLun == KUndefinedLun)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1066
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1067
        iSenseInfo.SetSense(TSenseInfo::EAbortedCommand);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1068
        return KErrAbort;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1069
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1070
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1071
    CMassStorageDrive* drive = GetCheckDrive(lastLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1072
    if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1073
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1074
        return KErrAbort;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1075
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1076
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1077
    if (lastCommand == EWrite10)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1078
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1079
        TPtrC8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1080
        iTransport->GetWriteDataBufPtr(writeBuf);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1081
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1082
#ifdef USB_TRANSFER_PUBLISHER
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1083
    iBytesWritten[lastLun] += writeBuf.Length();
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1084
#endif
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1085
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1086
#ifdef MSDC_MULTITHREADED
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1087
        TInt err = iWriteDriveThread->WriteDriveData(drive, bOffset, writeBuf, ProcessWriteComplete, this);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1088
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1089
        if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1090
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1091
            iDeferredSenseInfo.SetSense(TSenseInfo::EMediumError);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1092
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1093
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1094
        TUint thisLength = iWriteDriveThread->WriteBufferLength();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1095
#else
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1096
        OstTrace1(TRACE_SMASSSTORAGE_MEDIA, CSCSIPROTOCOL_READCOMPLETE2, "SCSI: writing 0x%x bytes", writeBuf.Length());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1097
        TInt err = drive->Write(bOffset, writeBuf, drive->IsWholeMediaAccess());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1098
        if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1099
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1100
            OstTrace1(TRACE_SMASSSTORAGE_MEDIA, CSCSIPROTOCOL_READCOMPLETE3, "Error after write = 0x%x", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1101
            iSenseInfo.SetSense(TSenseInfo::EAbortedCommand);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1102
            return KErrAbort;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1103
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1104
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1105
        TUint thisLength = writeBuf.Length();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1106
#endif // MSDC_MULTITHREADED
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1107
        iOffset = bOffset + MAKE_TINT64(0, thisLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1108
        iBytesRemain -= thisLength;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1109
        if ((TInt)iBytesRemain > 0)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1110
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1111
            // More data is expected - set up another request to read from the host
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1112
            iLastCommand = EWrite10;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1113
            iLastLun = lastLun;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1114
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1115
            TUint minLength = (iBytesRemain < iMediaWriteSize) ? iBytesRemain : iMediaWriteSize;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1116
            TUint bytesAvail = iTransport->BytesAvailable() & ~(KDefaultBlockSize-1);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1117
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1118
            TBool wait = EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1119
            thisLength = bytesAvail ? bytesAvail : minLength;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1120
            if (thisLength < minLength)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1121
                {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1122
                // Not enough data is available at the transport to satisfy the request,
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1123
                // so return KErrNotReady to indicate that the transport should wait.
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1124
                thisLength = minLength;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1125
                wait = ETrue;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1126
                }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1127
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1128
            thisLength = (thisLength > KMaxBufSize) ? KMaxBufSize : thisLength;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1129
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1130
            iTransport->SetupReadData(thisLength);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1131
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1132
            return wait ? KErrNotReady : KErrCompletion;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1133
            }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1134
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1135
    else if (lastCommand == EVerify10)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1136
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1137
        HBufC8* hostData = NULL;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1138
        TPtrC8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1139
        iTransport->GetWriteDataBufPtr(writeBuf);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1140
#ifdef MSDC_MULTITHREADED
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1141
        TRAPD(err, hostData = HBufC8::NewL(writeBuf.Length()));
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1142
#else
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1143
        TRAPD(err, hostData = HBufC8::NewL(writeBuf.Length()));
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1144
#endif
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1145
        if (err != KErrNone || hostData == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1146
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1147
            iSenseInfo.SetSense(TSenseInfo::EAbortedCommand, TSenseInfo::EInsufficientRes);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1148
            return KErrAbort;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1149
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1150
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1151
#ifdef MSDC_MULTITHREADED
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1152
        // copy the data
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1153
        *hostData = writeBuf;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1154
        TPtr8 readBuf = iWriteDriveThread->iThreadContext->GetReadBuffer();
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1155
        err = drive->Read(bOffset, writeBuf.Length(), readBuf, drive->IsWholeMediaAccess());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1156
        if (err == KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1157
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1158
            err = (hostData->Compare(readBuf) == 0) ? KErrNone : KErrCorrupt;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1159
            }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1160
#else
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1161
        *hostData = writeBuf;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1162
        TPtr8 readBuf((TUint8*) writeBuf.Ptr(), writeBuf.Length());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1163
        err = drive->Read(bOffset, writeBuf.Length(), readBuf, drive->IsWholeMediaAccess());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1164
        if (err == KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1165
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1166
            err = (hostData->Compare(readBuf) == 0) ? KErrNone : KErrCorrupt;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1167
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1168
#endif
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1169
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1170
        if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1171
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1172
            iSenseInfo.SetSense(TSenseInfo::EMisCompare);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1173
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1174
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1175
        delete hostData;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1176
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1177
    else // unknown command
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1178
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1179
        iSenseInfo.SetSense(TSenseInfo::EAbortedCommand);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1180
        }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1181
    return iSenseInfo.SenseOk() ? KErrNone : KErrAbort;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1182
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1183
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1184
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1185
/**
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1186
Command Parser for the MODE SENSE(06) command (0x1A)
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1187
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1188
@return ETrue if successful.
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1189
*/
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1190
TBool CScsiProtocol::HandleModeSense6(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1191
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1192
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_MODESENSE6, ">>> MODESENSE(06)");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1193
    TInt pageCode = aData[3] & 0x3F;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1194
    TUint8 pageControl= static_cast<TUint8>(aData[3] >>6);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1195
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1196
    if (pageCode != KAllPages || pageControl == KChangeableValues)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1197
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1198
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest,TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1199
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1200
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1201
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1202
    // reserve 4 bytes for Length, Media type, Device-specific parameter and Block descriptor length
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1203
    TPtr8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1204
    iTransport->GetCommandBufPtr(writeBuf, KModeSense6CommandLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1205
    writeBuf.FillZ(KModeSense6CommandLength);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1206
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1207
    if (pageControl != KDefaultValues)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1208
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1209
        //check if drive write protected
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1210
        CMassStorageDrive* drive=GetCheckDrive(aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1211
        if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1212
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1213
            OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEMODESENSE6_1, "drive == null");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1214
            return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1215
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1216
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1217
        TLocalDriveCapsV4 driveInfo;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1218
        TInt err = drive->Caps(driveInfo);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1219
        if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1220
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1221
            OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_MODESENSE6_2, "ERROR: Can't obtain drive Caps Err=%d", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1222
            iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1223
            return EFalse ;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1224
            }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1225
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1226
        if (driveInfo.iMediaAtt & KMediaAttWriteProtected)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1227
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1228
            writeBuf[2] = 1<<7;  // set SWP bit at the Device Specific parameters
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1229
            }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1230
        }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1231
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1232
    writeBuf[0]=3;  //Sending only Mode parameter header
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1233
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1234
    TPtrC8 writeBuf1 = writeBuf;
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1235
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1236
    iTransport->SetupWriteData(writeBuf1);
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1237
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1238
    return (iSenseInfo.SenseOk());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1239
    }
0
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1240
a41df078684a Convert Kernelhwsrv package from SFL to EPL
John Imhofe
parents:
diff changeset
  1241
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1242
/**
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1243
Command Parser for the MODE SENSE(10) command (0x5A)
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1244
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1245
@return ETrue if successful.
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1246
*/
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1247
TBool CScsiProtocol::HandleModeSense10(TPtrC8& aData, TUint aLun)
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1248
    {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1249
    OstTrace0(TRACE_SMASSSTORAGE_SCSI, CSCSIPROTOCOL_MODESENSE10, ">>> MODESENSE(10)");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1250
    TInt pageCode = aData[3] & 0x3F;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1251
    TUint8 pageControl= static_cast<TUint8>(aData[3] >>6);
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1252
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1253
    if (pageCode != KAllPages || pageControl == KChangeableValues)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1254
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1255
        iSenseInfo.SetSense(TSenseInfo::EIllegalRequest,TSenseInfo::EInvalidFieldInCdb);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1256
        return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1257
        }
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1258
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1259
    // reserve 8 bytes for Length, Media type, Device-specific parameter and Block descriptor length
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1260
    TPtr8 writeBuf(NULL, 0);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1261
    iTransport->GetCommandBufPtr(writeBuf, KModeSense10CommandLength);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1262
    writeBuf.FillZ(KModeSense10CommandLength);
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1263
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1264
    if (pageControl != KDefaultValues)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1265
        {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1266
        //check if drive write protected
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1267
        CMassStorageDrive* drive=GetCheckDrive(aLun);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1268
        if (drive == NULL)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1269
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1270
            OstTrace0(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_HANDLEMODESENSE10_1, "drive == null");
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1271
            return EFalse;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1272
            }
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1273
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1274
        TLocalDriveCapsV4 driveInfo;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1275
        TInt err = drive->Caps(driveInfo);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1276
        if (err != KErrNone)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1277
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1278
            OstTrace1(TRACE_SMASSSTORAGE, CSCSIPROTOCOL_MODESENSE10_1, "ERROR: Can't obtain drive Caps Err=%d", err);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1279
            iSenseInfo.SetSense(TSenseInfo::ENotReady, TSenseInfo::EMediaNotPresent);
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1280
            return EFalse ;
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1281
            }
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1282
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1283
        if (driveInfo.iMediaAtt & KMediaAttWriteProtected)
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1284
            {
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1285
            writeBuf[3] = 1<<7;  // set SWP bit at the Device Specific parameters
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1286
            }
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1287
        }
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1288
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1289
    writeBuf[1]=6;  //Sending only Mode parameter header
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1290
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1291
    TPtrC8 writeBuf1 = writeBuf;
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1292
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1293
    iTransport->SetupWriteData(writeBuf1);
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1294
286
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1295
    return (iSenseInfo.SenseOk());
48e57fb1237e 201039_11
hgs
parents: 90
diff changeset
  1296
    }
90
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1297
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1298
947f0dc9f7a8 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 0
diff changeset
  1299