--- a/baseintegtests/baseintegrationtest/testsuites/sd/src/sdfieldcheck.cpp Mon Oct 19 15:55:17 2009 +0100
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,1007 +0,0 @@
-// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
-// All rights reserved.
-// This component and the accompanying materials are made available
-// under the terms of the License "Eclipse Public License v1.0"
-// which accompanies this distribution, and is available
-// at the URL "http://www.eclipse.org/legal/epl-v10.html".
-//
-// Initial Contributors:
-// Nokia Corporation - initial contribution.
-//
-// Contributors:
-//
-// Description:
-// Ensure the File System complies with the SD specification
-//
-//
-
-#include "sdfieldcheck.h"
-
-const TUint32 KSectorSize = 512;
-
-/*
-Class constructor
-
-@param None
-@return None
-*/
-CBaseTestSDFieldCheck::CBaseTestSDFieldCheck(CBaseTestSDServer& aOurServer) : iServer(aOurServer)
- {
- SetTestStepName(KTestStepFieldCheck);
- }
-
-/*
-Test Step Preamble
- - Load device driver for direct disk access
-
-@param None
-@return EPass if successful or EFail if not
-@see TVerdict
-*/
-TVerdict CBaseTestSDFieldCheck::doTestStepPreambleL()
- {
- SetTestStepResult(EFail);
-
- if (!InitDeviceDriver())
- return TestStepResult();
-
- SetTestStepResult(EPass);
- return TestStepResult();
- }
-
-/*
-Test step
-
-@param None
-@return EPass if successful or EFail if not
-@see TVerdict
-*/
-TVerdict CBaseTestSDFieldCheck::doTestStepL()
- {
- if (TestStepResult() == EPass)
- {
- TInt checktype = 0;
- _LIT(KFieldCheckType, "FieldCheckType");
- if (!GetIntFromConfig(ConfigSection(), KFieldCheckType, checktype))
- {
- ERR_PRINTF1(_L("INI file read error"));
- SetTestStepResult(EFail);
- return TestStepResult();
- }
- switch (checktype)
- {
- case 1:
- FS1();
- break;
- case 2:
- if (iServer.iSharedData.iFsType < 0x0b)
- // FAT12/16
- {
- FS2();
- }
- else
- // FAT32
- {
- FS2Fat32();
- }
- break;
- case 3:
- if (iServer.iSharedData.iFsType < 0x0b)
- {
- FS3();
- }
- else
- {
- INFO_PRINTF1(_L("Test step skipped: not a FAT12/16 partition"));
- }
- break;
- case 4:
- if (iServer.iSharedData.iFsType < 0x0b)
- {
- FS4();
- }
- else
- {
- INFO_PRINTF1(_L("Test step skipped: not a FAT12/16 partition"));
- }
- break;
- case 5:
- if (iServer.iSharedData.iFsType < 0x0b)
- {
- FS5();
- }
- else
- {
- INFO_PRINTF1(_L("Test step skipped: not a FAT12/16 partition"));
- }
- break;
- case 6:
- if (iServer.iSharedData.iFsType >= 0x0b)
- {
- FSInfo();
- }
- else
- {
- INFO_PRINTF1(_L("Test step skipped: not a FAT32 partition"));
- }
- break;
- case 7:
- if (iServer.iSharedData.iFsType >= 0x0b)
- {
- FSBackupSectors();
- }
- else
- {
- INFO_PRINTF1(_L("Test step skipped: not a FAT32 partition"));
- }
- break;
- default:
- ERR_PRINTF2(_L("Invalid check type value: %d"), checktype);
- SetTestStepResult(EFail);
- return TestStepResult();
- }
- }
- else
- {
- INFO_PRINTF1(_L("Test preamble did not complete succesfully - Test Step skipped"));
- }
- return TestStepResult();
- }
-
-
-/*
-Field Check of MBR and Partition Table
-
-@param None
-@return None
-*/
-void CBaseTestSDFieldCheck::FS1()
- {
- INFO_PRINTF1(_L("FS1 - Field Check of MBR and Partition Table"));
- TBuf8<KSectorSize> sector;
-
- if (ReadSector(0, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
-
- // See section 3.1.3. Arrangement of the Partition Area (FAT12/16)
- // and section 4.1.3. Arrangement of the Partition Area (FAT32)
- // of the SD Specification for details
-
- // Also see SD Test Specification for File Systems
-
- TInt relativeSector = SYMBIAN_TEST_LE4(sector[446 + 8], sector[446 + 9], sector[446 + 10], sector[446 + 11]);
-
- // Save values for later use
- iServer.iSharedData.iTotalSector = SYMBIAN_TEST_LE4(sector[446 + 12], sector[446 + 13], sector[446 + 14], sector[446 + 15]);
- iServer.iSharedData.iPartitionBootSector = relativeSector;
-
- TInt noHeads = 0;
- if (iCardSizeInSectors <= 32768) { noHeads = 2; } // <=16MB
- else if (iCardSizeInSectors <= 65536) { noHeads = 4; } // <=32MB
- else if (iCardSizeInSectors <= 262144) { noHeads = 8; } // <=128MB
- else if (iCardSizeInSectors <= 1032192) { noHeads = 16; } // <=504MB
- else if (iCardSizeInSectors <= 2064384) { noHeads = 32; } // <=1008MB
- else if (iCardSizeInSectors <= 4128768) { noHeads = 64; } // <=2016MB
- else if (iCardSizeInSectors <= 8257536) { noHeads = 128; } // <=4032GB
- else { noHeads = 255; }
-
- TInt sectorsPerTrack = 0;
- if (iCardSizeInSectors <= 4096) { sectorsPerTrack = 16; } // <=2MB
- else if (iCardSizeInSectors <= 524288) { sectorsPerTrack = 32; } // <=256MB
- else { sectorsPerTrack = 63; }
-
- TInt expected;
-
- // FS1-1
- INFO_PRINTF2(_L("FS 1-1 Boot Indicator: %02xh"), sector[446]);
- SYMBIAN_TEST_TESTNOPANIC(sector[446] == 0x00 || sector[446] == 0x80);
-
- // FS1-2
- if (relativeSector <= 16450560) // FAT12/16
- {
- expected = (relativeSector % (noHeads * sectorsPerTrack)) / sectorsPerTrack;
- }
- else
- {
- expected = 0xfe;
- }
- INFO_PRINTF3(_L("FS 1-2 Starting Head: %02xh (expected: %02xh)"), sector[446 + 1], expected);
- SYMBIAN_TEST_TESTNOPANIC(sector[446 + 1] == expected);
-
- // FS1-3
- if (relativeSector <= 16450560) // FAT12/16
- {
- expected = relativeSector % sectorsPerTrack + 1;
- }
- else
- {
- expected = 0x3f;
- }
- INFO_PRINTF3(_L("FS 1-3 Starting Sector: %02xh (expected %02xh)"), sector[446 + 2] & 0x3f, expected);
- SYMBIAN_TEST_TESTNOPANIC((sector[446 + 2] & 0x3f) == expected);
-
- // FS1-4
- if (relativeSector <= 16450560) // FAT12/16
- {
- expected = relativeSector / (noHeads * sectorsPerTrack);
- }
- else
- {
- expected = 0x3ff;
- }
- INFO_PRINTF3(_L("FS 1-4 Starting Cylinder: %03xh (expected %03xh) "), ((sector[446 + 2] & 0xc0) << 2) + sector[446 + 3], expected);
- SYMBIAN_TEST_TESTNOPANIC(((sector[446 + 2] & 0xc0) << 2) + sector[446 + 3] == expected);
-
- // FS1-5
- INFO_PRINTF2(_L("FS 1-5 System ID: %02xh"), sector[446 + 4]);
- if (iServer.iSharedData.iTotalSector < 32680)
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[446 + 4] == 0x01);
- }
- else if (iServer.iSharedData.iTotalSector < 65536)
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[446 + 4] == 0x04);
- }
- else if (iServer.iSharedData.iTotalSector <= 4194304) // FAT16 (<=2048MB)
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[446 + 4] == 0x06);
- }
- else if (iServer.iSharedData.iTotalSector + relativeSector <= 16450560) // FAT32 and ending location of partition doesn't exceed 8032.5MB
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[446 + 4] == 0x0b);
- }
- else
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[446 + 4] == 0x0c);
- }
- iServer.iSharedData.iFsType = sector[446 + 4];
-
- // FS1-6
- if (iServer.iSharedData.iTotalSector + relativeSector <= 16450560) // FAT12/16
- {
- expected = ((relativeSector + iServer.iSharedData.iTotalSector - 1) % (noHeads * sectorsPerTrack)) / sectorsPerTrack;
- }
- else
- {
- expected = 0xfe;
- }
- INFO_PRINTF3(_L("FS 1-6 Ending Head: %02xh (expected: %02xh)"), sector[446 + 5], expected);
- SYMBIAN_TEST_TESTNOPANIC(sector[446 + 5] == expected);
-
- // FS1-7
- if (iServer.iSharedData.iTotalSector + relativeSector <= 16450560) // FAT12/16
- {
- expected = (relativeSector + iServer.iSharedData.iTotalSector - 1) % sectorsPerTrack + 1;
- }
- else
- {
- expected = 0x3f;
- }
- INFO_PRINTF3(_L("FS 1-7 Ending Sector: %02xh (expected %02xh)"), sector[446 + 6] & 0x3f, expected);
- SYMBIAN_TEST_TESTNOPANIC((sector[446 + 6] & 0x3f) == expected);
-
- // FS1-8
- if (iServer.iSharedData.iTotalSector + relativeSector <= 16450560) // FAT12/16
- {
- expected = (relativeSector + iServer.iSharedData.iTotalSector - 1) / (noHeads * sectorsPerTrack);
- }
- else
- {
- expected = 0x3ff;
- }
- INFO_PRINTF3(_L("FS 1-8 Ending Cylinder: %03xh (expected %03xh)"), ((sector[446 + 6] & 0xc0) << 2) + sector[446 + 7], expected);
- SYMBIAN_TEST_TESTNOPANIC(((sector[446 + 6] & 0xc0) << 2) + sector[446 + 7] == expected);
-
- // FS1-9
- INFO_PRINTF2(_L("FS 1-9 Relative Sector: %08xh"), relativeSector);
- SYMBIAN_TEST_TESTNOPANIC(relativeSector < iCardSizeInSectors);
-
- // FS1-10
- INFO_PRINTF2(_L("FS 1-10 Total Sector: %08xh"), iServer.iSharedData.iTotalSector);
- SYMBIAN_TEST_TESTNOPANIC(iServer.iSharedData.iTotalSector <= iCardSizeInSectors);
-
- // FS1-11
- INFO_PRINTF1(_L("FS 1-11 Partition Table 2"));
- for (TInt i = 0; i < 16; i++)
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[462 + i] == 0);
- }
-
- // FS1-12
- INFO_PRINTF1(_L("FS 1-12 Partition Table 3"));
- for (TInt i = 0; i < 16; i++)
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[478 + i] == 0);
- }
-
- // FS1-13
- INFO_PRINTF1(_L("FS 1-13 Partition Table 4"));
- for (TInt i = 0; i < 16; i++)
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[494 + i] == 0);
- }
-
- // FS1-15
- INFO_PRINTF3(_L("FS 1-14 Signature Word %02xh %02xh"), sector[510], sector[511]);
- SYMBIAN_TEST_TESTNOPANIC(sector[510] == 0x55);
- SYMBIAN_TEST_TESTNOPANIC(sector[511] == 0xaa);
-
- for (TInt i = 0; i < KSectorSize / 16; i++)
- {
- TBuf<60> buffer;
- buffer.Format(_L("%08x:"), i * 16);
- for (TInt j = 0; j < 16; j++)
- {
- buffer.AppendFormat(_L(" %02x"), sector[i * 16 + j]);
- }
- INFO_PRINTF2(_L("%S"), &buffer);
- }
- }
-
-/*
-Field Check of Partition Boot Sector (FAT12/16)
-
-@param None
-@return None
-*/
-void CBaseTestSDFieldCheck::FS2()
- {
- INFO_PRINTF1(_L("FS2 - Field Check of Partition Boot Sector"));
- // See section 3.2.1. Partition Boot Sector (FAT12/16)
- // of the SD Specification for details
-
- // Also see SD Test Specification for File Systems
- TBuf8<KSectorSize> sector;
-
- if (ReadSector(iServer.iSharedData.iPartitionBootSector, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
-
- TInt sectorsPerCluster = 0;
- if (iCardSizeInSectors <= 16384) { sectorsPerCluster = 16; } // <=8MB
- else if (iCardSizeInSectors <= 2097152) { sectorsPerCluster = 32; } // <=1024MB
- else { sectorsPerCluster = 64; }
-
- iServer.iSharedData.iNumberOfClusters = (iServer.iSharedData.iTotalSector - (1 + SYMBIAN_TEST_LE2(sector[22], sector[23]) * 2 + (KSectorSize * 32 / KSectorSize))) / sectorsPerCluster;
-
- if (sector[38] != 0x29) // FDC
- {
- // FS2-1
- INFO_PRINTF4(_L("FS 2-1 Jump Command: %02xh %02xh %02xh"), sector[0], sector[1], sector[2]);
- SYMBIAN_TEST_TESTNOPANIC((sector[0] == 0xe9) ||
- ((sector[0] == 0xeb) && (sector[2] == 0x90)));
-
- // FS2-2
- INFO_PRINTF2(_L("FS 2-2 Sector Size: %04xh"), SYMBIAN_TEST_LE2(sector[11], sector[12]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[11], sector[12]) == KSectorSize);
-
- // FS2-3
- INFO_PRINTF3(_L("FS 2-3 Sectors per Cluster: %02xh (expected %02xh)"), sector[13], sectorsPerCluster);
- SYMBIAN_TEST_TESTNOPANIC(sector[13] == sectorsPerCluster);
-
- // FS2-4
- INFO_PRINTF2(_L("FS 2-4 Reserved Sector Count: %04xh"), SYMBIAN_TEST_LE2(sector[14], sector[15]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[14], sector[15]) == 1);
- iServer.iSharedData.iReservedSectorCount = SYMBIAN_TEST_LE2(sector[14], sector[15]);
-
- // FS2-5
- INFO_PRINTF2(_L("FS 2-5 Number of FATs: %02xh"), sector[16]);
- SYMBIAN_TEST_TESTNOPANIC(sector[16] == 2);
-
- // FS2-6
- INFO_PRINTF2(_L("FS 2-6 Number of Root Directory entries: %04xh"), SYMBIAN_TEST_LE2(sector[17], sector[18]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[17], sector[18]) == KSectorSize);
-
- // FS2-7
- INFO_PRINTF2(_L("FS 2-7 Total Sectors: %04xh"), SYMBIAN_TEST_LE2(sector[19], sector[20]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[19], sector[20]) <= 65535);
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[19], sector[20]) == iServer.iSharedData.iTotalSector);
-
- // FS2-8
- INFO_PRINTF2(_L("FS 2-8 Medium Identifier: %02xh"), sector[21]);
- SYMBIAN_TEST_TESTNOPANIC(sector[21] == 0xf8);
-
- // FS2-9
- if (iServer.iSharedData.iNumberOfClusters < 4085)
- {
- iServer.iSharedData.iSectorsPerFat = 1 + (1 + ((iServer.iSharedData.iNumberOfClusters + 2) * 3 / 2)) / KSectorSize;
- }
- else
- {
- iServer.iSharedData.iSectorsPerFat = 1 + ((iServer.iSharedData.iNumberOfClusters + 2) * 2) / KSectorSize;
- }
- INFO_PRINTF3(_L("FS 2-9 Sector per FAT: %04xh (expected %04xh)"), SYMBIAN_TEST_LE2(sector[22], sector[23]), iServer.iSharedData.iSectorsPerFat);
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[22], sector[23]) == iServer.iSharedData.iSectorsPerFat);
-
- // FS2-10
- INFO_PRINTF2(_L("FS 2-10 Sectors per Track: %04xh"), SYMBIAN_TEST_LE2(sector[24], sector[25]));
- if (iCardSizeInSectors <= 4096)
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[24], sector[25]) == 16); // <=2MB
- }
- else if (iCardSizeInSectors <= 524288)
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[24], sector[25]) == 32); // <=256MB
- }
- else
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[24], sector[25]) == 63);
- }
-
- // FS2-11
- INFO_PRINTF2(_L("FS 2-11 Number of Sides: %04xh"), SYMBIAN_TEST_LE2(sector[26], sector[27]));
- if (iCardSizeInSectors <= 32768) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 2); } // <=16MB
- else if (iCardSizeInSectors <= 65536) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 4); } // <=32MB
- else if (iCardSizeInSectors <= 262144) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 8); } // <=128MB
- else if (iCardSizeInSectors <= 1032192) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 16); } // <=504MB
- else if (iCardSizeInSectors <= 2064384) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 32); } // <=1008MB
- else if (iCardSizeInSectors <= 4128768) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 64); } // <=2016MB
- else { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 128); }
-
- // FS2-12
- INFO_PRINTF3(_L("FS 2-12 Reserved for future standardisation: %02x %02x"), sector[28], sector[29]);
- SYMBIAN_TEST_TESTNOPANIC(sector[28] == 0 && sector[29] == 0);
-
- // FS2-13
- INFO_PRINTF3(_L("FS 2-12 Signature Word: %02xh %02xh"), sector[510], sector[511]);
- SYMBIAN_TEST_TESTNOPANIC(sector[510] == 0x55 && sector[511] == 0xaa);
- }
- else // Extended FDC
- {
- // FS2-14
- INFO_PRINTF4(_L("FS 2-14 Jump Command: %02xh %02xh %02xh"), sector[0], sector[1], sector[2]);
- SYMBIAN_TEST_TESTNOPANIC((sector[0] == 0xe9) ||
- ((sector[0] == 0xeb) && (sector[2] == 0x90)));
-
- // FS2-15
- INFO_PRINTF2(_L("FS 2-15 Sector Size: %04xh"), SYMBIAN_TEST_LE2(sector[11], sector[12]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[11], sector[12]) == KSectorSize);
-
- // FS2-16
- INFO_PRINTF3(_L("FS 2-16 Sectors per Cluster: %02xh (expected %02xh)"), sector[13], sectorsPerCluster);
- SYMBIAN_TEST_TESTNOPANIC(sector[13] == sectorsPerCluster);
-
- // FS2-17
- INFO_PRINTF2(_L("FS 2-17 Reserved Sector Count: %04xh"), SYMBIAN_TEST_LE2(sector[14], sector[15]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[14], sector[15]) == 1);
-
- // FS2-18
- INFO_PRINTF2(_L("FS 2-18 Number of FATs: %02xh"), sector[16]);
- SYMBIAN_TEST_TESTNOPANIC(sector[16] == 2);
-
- // FS2-19
- INFO_PRINTF2(_L("FS 2-19 Number of Root Directory entries: %04xh"), SYMBIAN_TEST_LE2(sector[17], sector[18]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[17], sector[18]) == KSectorSize);
-
- // FS2-20
- INFO_PRINTF2(_L("FS 2-20 Total Sectors: %04xh"), SYMBIAN_TEST_LE2(sector[19], sector[20]));
- if (iServer.iSharedData.iTotalSector <= 65535)
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[19], sector[20]) == iServer.iSharedData.iTotalSector);
- }
- else
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[19], sector[20]) == 0);
- }
-
- // FS2-21
- INFO_PRINTF2(_L("FS 2-21 Medium Identifier: %02xh"), sector[21]);
- SYMBIAN_TEST_TESTNOPANIC(sector[21] == 0xf8);
-
- // FS2-22
- if (iServer.iSharedData.iNumberOfClusters < 4085)
- {
- iServer.iSharedData.iSectorsPerFat = 1 + (1 + ((iServer.iSharedData.iNumberOfClusters + 2) * 3 / 2)) / KSectorSize;
- }
- else
- {
- iServer.iSharedData.iSectorsPerFat = 1 + ((iServer.iSharedData.iNumberOfClusters + 2) * 2) / KSectorSize;
- }
- INFO_PRINTF3(_L("FS 2-22 Sector per FAT: %04xh (expected %04xh)"), SYMBIAN_TEST_LE2(sector[22], sector[23]), iServer.iSharedData.iSectorsPerFat);
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[22], sector[23]) == iServer.iSharedData.iSectorsPerFat);
-
- // FS2-23
- INFO_PRINTF2(_L("FS 2-23 Sectors per Track: %04xh"), SYMBIAN_TEST_LE2(sector[24], sector[25]));
- if (iCardSizeInSectors <= 4096)
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[24], sector[25]) == 16); // <=2MB
- }
- else if (iCardSizeInSectors <= 524288)
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[24], sector[25]) == 32); // <=256MB
- }
- else
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[24], sector[25]) == 63);
- }
-
- // FS2-24
- INFO_PRINTF2(_L("FS 2-24 Number of Sides: %04xh"), SYMBIAN_TEST_LE2(sector[26], sector[27]));
- if (iCardSizeInSectors <= 32768) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 2); } // <=16MB
- else if (iCardSizeInSectors <= 65536) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 4); } // <=32MB
- else if (iCardSizeInSectors <= 262144) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 8); } // <=128MB
- else if (iCardSizeInSectors <= 1032192) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 16); } // <=504MB
- else if (iCardSizeInSectors <= 2064384) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 32); } // <=1008MB
- else if (iCardSizeInSectors <= 4128768) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 64); } // <=2016MB
- else { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 128); }
-
- // FS2-25
- INFO_PRINTF2(_L("FS 2-25 Number of Hidden Sectors %08xh"), SYMBIAN_TEST_LE4(sector[28], sector[29], sector[30], sector[31]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE4(sector[28], sector[29], sector[30], sector[31]) == iServer.iSharedData.iPartitionBootSector);
-
- // FS2-26
- INFO_PRINTF2(_L("FS 2-26 Total Sectors %08xh"), SYMBIAN_TEST_LE4(sector[32], sector[33], sector[34], sector[35]));
- if (iServer.iSharedData.iTotalSector <= 65535)
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE4(sector[32], sector[33], sector[34], sector[35]) == 0);
- }
- else
- {
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE4(sector[32], sector[33], sector[34], sector[35]) == iServer.iSharedData.iTotalSector);
- }
-
- // FS2-27
- INFO_PRINTF2(_L("FS 2-27 Physical Disk Number: %02xh"), sector[36]);
- SYMBIAN_TEST_TESTNOPANIC(sector[36] == 0x80);
-
- // FS2-28
- INFO_PRINTF2(_L("FS 2-28 Reserved: %02xh"), sector[37]);
- SYMBIAN_TEST_TESTNOPANIC(sector[37] == 0);
-
- // FS2-29
- INFO_PRINTF9(_L("FS 2-29 File System Type: '%c%c%c%c%c%c%c%c'"), sector[54], sector[55], sector[56], sector[57], sector[58], sector[59], sector[60], sector[61]);
- SYMBIAN_TEST_TESTNOPANIC((sector[54] == 'F') && (sector[55] == 'A') && (sector[56] == 'T') && (sector[57] == '1') && (sector[59] == ' ') && (sector[60] == ' ') && (sector[61] == ' '));
- if (iServer.iSharedData.iNumberOfClusters < 4085)
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[58] == '2');
- }
- else
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[58] == '6');
- }
-
- // FS2-30
- INFO_PRINTF3(_L("FS 2-30 Signature Word: %02xh %02xh"), sector[510], sector[511]);
- SYMBIAN_TEST_TESTNOPANIC(sector[510] == 0x55 && sector[511] == 0xaa);
- }
-
- for (TInt i = 0; i < KSectorSize / 16; i++)
- {
- TBuf<60> buffer;
- buffer.Format(_L("%08x:"), i * 16 + iServer.iSharedData.iPartitionBootSector);
- for (TInt j = 0; j < 16; j++)
- {
- buffer.AppendFormat(_L(" %02x"), sector[i * 16 + j]);
- }
- INFO_PRINTF2(_L("%S"), &buffer);
- }
- }
-
-/*
-Field Check of Partition Boot Sector (FAT32)
-
-@param None
-@return None
-*/
-void CBaseTestSDFieldCheck::FS2Fat32()
- {
- INFO_PRINTF1(_L("FS2 - Field Check of Partition Boot Sector"));
- // See section 4.2.1. Partition Boot Sector (FAT32)
- // of the SD Specification for details
-
- TBuf8<KSectorSize> sector;
-
- if (ReadSector(iServer.iSharedData.iPartitionBootSector, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
-
- TInt sectorsPerCluster = 0;
- if (iCardSizeInSectors <= 16384) { sectorsPerCluster = 16; } // <=8MB
- else if (iCardSizeInSectors <= 2097152) { sectorsPerCluster = 32; } // <=1024MB
- else { sectorsPerCluster = 64; }
-
- iServer.iSharedData.iNumberOfClusters = (iServer.iSharedData.iTotalSector - (1 + SYMBIAN_TEST_LE2(sector[22], sector[23]) * 2 + (KSectorSize * 32 / KSectorSize))) / sectorsPerCluster;
-
- // Calculations (SD Spec, Annex c.2.4)
- TUint32 KBoundaryUnit = 8192;
- TUint32 KSectorsPerCluster = 64;
- TUint32 KFatBits = 32;
- TUint32 KSectorsInMBR = KBoundaryUnit;
-
- // Caclculate number of sectors per FAT according to section C.2.4
- TUint32 sf = SYMBIAN_TEST_CEIL(KFatBits * iCardSizeInSectors / KSectorsPerCluster, KSectorSize * 8);
- TUint32 sfp;
- TUint32 rsc;
- TBool cond13 = ETrue;
- do
- {
- TUint32 n = 0;
- while (KBoundaryUnit * n < 2 * sf + 9)
- {
- n++;
- }
- rsc = KBoundaryUnit * n - 2 * sf;
- TInt ssa = rsc + 2 * sf;
- do {
- TInt max = SYMBIAN_TEST_IP(iCardSizeInSectors - KSectorsInMBR - ssa, KSectorsPerCluster) + 1;
- sfp = SYMBIAN_TEST_CEIL((2 + (max - 1)) * KFatBits, KSectorSize * 8);
- if (sfp > sf)
- {
- ssa += KBoundaryUnit;
- rsc += KBoundaryUnit;
- }
- } while (sfp > sf);
- if (sf != sfp)
- {
- sf--;
- cond13 = EFalse;
- }
- else
- {
- cond13 = ETrue;
- }
- } while (!cond13);
-
- // FS2-31
- INFO_PRINTF4(_L("FS 2-31 Jump Command: %02xh %02xh %02xh"), sector[0], sector[1], sector[2]);
- SYMBIAN_TEST_TESTNOPANIC((sector[0] == 0xe9) ||
- ((sector[0] == 0xeb) && (sector[2] == 0x90)));
-
- // FS2-32
- INFO_PRINTF3(_L("FS 2-32 Sector Size: %04xh (expected %04xh)"), SYMBIAN_TEST_LE2(sector[11], sector[12]), KSectorSize);
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[11], sector[12]) == KSectorSize);
-
- // FS2-33
- INFO_PRINTF3(_L("FS 2-33 Sectors per Cluster: %02xh (expected %02xh)"), sector[13], KSectorsPerCluster);
- SYMBIAN_TEST_TESTNOPANIC(sector[13] == KSectorsPerCluster);
-
- // FS2-34
- INFO_PRINTF3(_L("FS 2-34 Reserved Sector Count: %04xh (expected %04xh)"), SYMBIAN_TEST_LE2(sector[14], sector[15]), rsc);
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[14], sector[15]) == rsc);
-
- // FS2-35
- INFO_PRINTF2(_L("FS 2-35 Number of FATs: %02xh"), sector[16]);
- SYMBIAN_TEST_TESTNOPANIC(sector[16] == 2);
-
- // FS2-36
- INFO_PRINTF2(_L("FS 2-36 Number of Root Directory entries: %04xh"), SYMBIAN_TEST_LE2(sector[17], sector[18]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[17], sector[18]) == 0); // FAT32 No max root dir entries
-
- // FS2-37
- INFO_PRINTF2(_L("FS 2-37 Total Sectors: %04xh"), SYMBIAN_TEST_LE2(sector[19], sector[20]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[19], sector[20]) == 0);
-
- // FS2-38
- INFO_PRINTF2(_L("FS 2-38 Medium Identifier: %02xh"), sector[21]);
- SYMBIAN_TEST_TESTNOPANIC(sector[21] == 0xf8);
-
- // FS2-39
- INFO_PRINTF2(_L("FS 2-39 Sector per FAT: %04xh"), SYMBIAN_TEST_LE2(sector[22], sector[23]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[22], sector[23]) == 0); // This field not used in the FAT32 spec
-
- // FS2-40
- INFO_PRINTF2(_L("FS 2-40 Sectors per Track: %04xh"), SYMBIAN_TEST_LE2(sector[24], sector[25]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[24], sector[25]) == 63);
-
- // FS2-41
- INFO_PRINTF2(_L("FS 2-41 Number of Sides: %04xh"), SYMBIAN_TEST_LE2(sector[26], sector[27]));
- if (iCardSizeInSectors <= 8257536) { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 128); } // <=4032MB
- else { SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[26], sector[27]) == 255); }
-
- // FS2-42
- INFO_PRINTF2(_L("FS 2-42 Number of Hidden Sectors %08xh"), SYMBIAN_TEST_LE4(sector[28], sector[29], sector[30], sector[31]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE4(sector[28], sector[29], sector[30], sector[31]) == iServer.iSharedData.iPartitionBootSector);
-
- // FS2-43
- INFO_PRINTF2(_L("FS 2-43 Total Sectors %08xh"), SYMBIAN_TEST_LE4(sector[32], sector[33], sector[34], sector[35]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE4(sector[32], sector[33], sector[34], sector[35]) == iServer.iSharedData.iTotalSector);
-
- // FS2-44
- INFO_PRINTF3(_L("FS 2-44 Sectors per FAT for FAT32 %08xh (expected: %08xh)"), SYMBIAN_TEST_LE4(sector[36], sector[37], sector[38], sector[39]), sf);
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE4(sector[36], sector[37], sector[38], sector[39]) == sf);
-
- // FS2-45
- INFO_PRINTF2(_L("FS 2-45 Extension Flag %04xh"), SYMBIAN_TEST_LE2(sector[40], sector[41]));
-
- // FS2-46
- INFO_PRINTF2(_L("FS 2-46 FS Version %04xh"), SYMBIAN_TEST_LE2(sector[42], sector[43]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[42], sector[43]) == 0);
-
- // FS2-47
- INFO_PRINTF2(_L("FS 2-47 Root Cluster %08xh"), SYMBIAN_TEST_LE4(sector[44], sector[45], sector[46], sector[47]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE4(sector[44], sector[45], sector[46], sector[47]) >= 2);
-
- // FS2-48
- INFO_PRINTF2(_L("FS 2-48 FS Info %04xh"), SYMBIAN_TEST_LE2(sector[48], sector[49]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[48], sector[49]) == 1);
-
- // FS2-49
- INFO_PRINTF2(_L("FS 2-49 Backup Boot Sector %04xh"), SYMBIAN_TEST_LE2(sector[50], sector[51]));
- SYMBIAN_TEST_TESTNOPANIC(SYMBIAN_TEST_LE2(sector[50], sector[51]) == 6);
-
- // FS2-50
- INFO_PRINTF2(_L("FS 2-50 Physical Disk Number: %02xh"), sector[64]);
- SYMBIAN_TEST_TESTNOPANIC(sector[64] == 0x80);
-
- // FS2-51
- INFO_PRINTF2(_L("FS 2-51 Extended Boot Record Signature: %02xh"), sector[66]);
- SYMBIAN_TEST_TESTNOPANIC(sector[66] == 0x29);
-
- // FS2-52
- INFO_PRINTF9(_L("FS 2-52 File System Type: '%c%c%c%c%c%c%c%c'"), sector[82], sector[83], sector[84], sector[85], sector[86], sector[87], sector[88], sector[89]);
- SYMBIAN_TEST_TESTNOPANIC((sector[82] == 'F') && (sector[83] == 'A') && (sector[84] == 'T') && (sector[85] == '3') && (sector[86] == '2')&& (sector[87] == ' ') && (sector[88] == ' ') && (sector[89] == ' '));
-
- // FS2-53
- INFO_PRINTF3(_L("FS 2-30 Signature Word: %02xh %02xh"), sector[510], sector[511]);
- SYMBIAN_TEST_TESTNOPANIC(sector[510] == 0x55 && sector[511] == 0xaa);
-
- for (TInt i = 0; i < KSectorSize / 16; i++)
- {
- TBuf<60> buffer;
- buffer.Format(_L("%08x:"), i * 16 + iServer.iSharedData.iPartitionBootSector);
- for (TInt j = 0; j < 16; j++)
- {
- buffer.AppendFormat(_L(" %02x"), sector[i * 16 + j]);
- }
- INFO_PRINTF2(_L("%S"), &buffer);
- }
- }
-
-/*
-Field Check of FAT32 FS Info Sector
-
-@param None
-@return None
-*/
-void CBaseTestSDFieldCheck::FSInfo()
- {
- // See section 4.2.2. FS Info Sector
- // of the SD Specification for details
-
- INFO_PRINTF1(_L("FSx - Field Check of FAT32's FS Info Sector"));
- TBuf8<KSectorSize> sector;
-
- if (ReadSector(iServer.iSharedData.iPartitionBootSector + 1, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
-
- //
- INFO_PRINTF5(_L("- Lead Signature: %02xh %02xh %02xh %02xh"), sector[0], sector[1], sector[2], sector[3]);
- SYMBIAN_TEST_TESTNOPANIC(sector[0] == 0x52);
- SYMBIAN_TEST_TESTNOPANIC(sector[1] == 0x52);
- SYMBIAN_TEST_TESTNOPANIC(sector[2] == 0x61);
- SYMBIAN_TEST_TESTNOPANIC(sector[3] == 0x41);
-
- //
- for (TInt i = 4; i < 484; i++)
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[i] == 0);
- }
-
- //
- INFO_PRINTF5(_L("- Structure Signature: %02xh %02xh %02xh %02xh"), sector[484], sector[485], sector[486], sector[487]);
- SYMBIAN_TEST_TESTNOPANIC(sector[484] == 0x72);
- SYMBIAN_TEST_TESTNOPANIC(sector[485] == 0x72);
- SYMBIAN_TEST_TESTNOPANIC(sector[486] == 0x41);
- SYMBIAN_TEST_TESTNOPANIC(sector[487] == 0x61);
-
- //
- INFO_PRINTF2(_L("- Free Cluster Count: %08xh"), SYMBIAN_TEST_LE4(sector[488], sector[489], sector[490], sector[491]));
- INFO_PRINTF2(_L("- Next Free Cluster: %08xh"), SYMBIAN_TEST_LE4(sector[492], sector[493], sector[494], sector[495]));
-
- INFO_PRINTF5(_L("- Trail Signature: %02xh %02xh %02xh %02xh"), sector[508], sector[509], sector[510], sector[511]);
- SYMBIAN_TEST_TESTNOPANIC(sector[508] == 0);
- SYMBIAN_TEST_TESTNOPANIC(sector[509] == 0);
- SYMBIAN_TEST_TESTNOPANIC(sector[510] == 0x55);
- SYMBIAN_TEST_TESTNOPANIC(sector[511] == 0xaa);
-
- for (TInt i = 0; i < KSectorSize / 16; i++)
- {
- TBuf<60> buffer;
- buffer.Format(_L("%08x:"), i * 16 + iServer.iSharedData.iPartitionBootSector + 1);
- for (TInt j = 0; j < 16; j++)
- {
- buffer.AppendFormat(_L(" %02x"), sector[i * 16 + j]);
- }
- INFO_PRINTF2(_L("%S"), &buffer);
- }
- }
-
-/*
-Field Check of the File Allocation Table
-
-@param None
-@return None
-*/
-void CBaseTestSDFieldCheck::FS3()
- {
- INFO_PRINTF1(_L("FS3 - Field Check of File Allocation Table"));
- // See section 3.2.2. File Allocation Table
- // of the SD Specification for details
-
- // Also see SD Test Specification for File Systems
- TBuf8<KSectorSize> sector;
-
- if (ReadSector(iServer.iSharedData.iPartitionBootSector + 1, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
-
- // FS3-1
- if (iServer.iSharedData.iNumberOfClusters < 4085)
- {
- INFO_PRINTF4(_L("FS 3-1 Head 3 bytes of First FAT: %02xh %02xh %02xh"), sector[0], sector[1], sector[2]);
- SYMBIAN_TEST_TESTNOPANIC((sector[0] == 0xf8) && (sector[1] == 0xff) && (sector[2] == 0xff));
- }
- else
- {
- INFO_PRINTF5(_L("FS 3-1 Head 4 bytes of First FAT: %02xh %02xh %02xh %02xh"), sector[0], sector[1], sector[2], sector[3]);
- SYMBIAN_TEST_TESTNOPANIC((sector[0] == 0xf8) && (sector[1] == 0xff) && (sector[2] == 0xff) && (sector[3] == 0xff));
- }
-
- // FS3-2
- INFO_PRINTF1(_L("FS 3-2 Read First FAT"));
- for (TInt i = 0; i < iServer.iSharedData.iSectorsPerFat; i++)
- {
- if (ReadSector(iServer.iSharedData.iPartitionBootSector + 1 + i, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
- for (TInt j = 0; j < KSectorSize; j++)
- {
- if ((i > 0) || ((i == 0) && (j > 3)) || ((i == 0) && (j == 3) && (iServer.iSharedData.iNumberOfClusters < 4085)))
- {
- SYMBIAN_TEST_TESTNOPANIC(sector[j] == 0);
- }
- }
- }
-
- if (ReadSector(iServer.iSharedData.iPartitionBootSector + 1 + iServer.iSharedData.iSectorsPerFat, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
-
- // FS3-3
- if (iServer.iSharedData.iNumberOfClusters < 4085)
- {
- INFO_PRINTF4(_L("FS 3-3 Head 3 bytes of Second FAT: %02xh %02xh %02xh"), sector[0], sector[1], sector[2]);
- SYMBIAN_TEST_TESTNOPANIC((sector[0] == 0xf8) && (sector[1] == 0xff) && (sector[2] == 0xff));
- }
- else
- {
- INFO_PRINTF5(_L("FS 3-3 Head 4 bytes of Second FAT: %02xh %02xh %02xh"), sector[0], sector[1], sector[2], sector[3]);
- SYMBIAN_TEST_TESTNOPANIC((sector[0] == 0xf8) && (sector[1] == 0xff) && (sector[2] == 0xff) && (sector[3] == 0xff));
- }
-
- // FS3-4
- INFO_PRINTF1(_L("FS 3-4 Read Second FAT"));
- for (TInt i = 0; i < iServer.iSharedData.iSectorsPerFat; i++)
- {
- if (ReadSector(iServer.iSharedData.iPartitionBootSector + 1 + iServer.iSharedData.iSectorsPerFat + i, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
- for (TInt j = 0; j < KSectorSize; j++)
- {
- TInt sec = 0;
- if ((i > 0) || ((i == 0) && (j > 3)) || ((i == 0) && (j == 3) && (iServer.iSharedData.iNumberOfClusters < 4085)))
- {
- sec = sec | sector[j];
- }
- SYMBIAN_TEST_TESTNOPANIC(sec == 0);
- }
- }
- }
-
-/*
-Field Check of Root Directory
-
-@param None
-@return None
-*/
-void CBaseTestSDFieldCheck::FS4()
- {
- INFO_PRINTF1(_L("FS4 - Field Check of Root Directory"));
- // See SD Test Specification for File Systems for details
- TBuf8<KSectorSize> sector;
-
- INFO_PRINTF1(_L("FS 4-1 Read Root Directory"));
- for (TInt i = 0; i < KSectorSize / 16; i++)
- {
- TInt sec = 0;
- if (ReadSector(iServer.iSharedData.iPartitionBootSector + 1 + i + iServer.iSharedData.iSectorsPerFat * 2, sector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
- for (TInt j = 0; j < KSectorSize; j++)
- {
- sec = sec | sector[j];
- }
- SYMBIAN_TEST_TESTNOPANIC(sec == 0);
- }
- }
-
-/*
-File Systen Layout Check
-
-@param None
-@return None
-*/
-void CBaseTestSDFieldCheck::FS5()
- {
- INFO_PRINTF1(_L("FS5 - File System Layout Check"));
- // See SD Test Specification for File Systems for details
-
- TInt boundaryUnit = 0;
- if (iCardSizeInSectors <= 16384) { boundaryUnit = 16; } // <= 8MB
- else if (iCardSizeInSectors <= 131072) { boundaryUnit = 32; } // <= 64MB
- else if (iCardSizeInSectors <= 1048576) { boundaryUnit = 64; } // <= 256MB
- else { boundaryUnit = 128; }
-
- INFO_PRINTF2(_L("Boundary Unit: %d"), boundaryUnit);
- INFO_PRINTF2(_L("Relative Sector: %d"), iServer.iSharedData.iPartitionBootSector);
- INFO_PRINTF2(_L("Reserved Sector Count: %d"), iServer.iSharedData.iReservedSectorCount);
- INFO_PRINTF2(_L("Sectors per FAT: %d"), iServer.iSharedData.iSectorsPerFat);
- SYMBIAN_TEST_TESTNOPANIC((iServer.iSharedData.iPartitionBootSector + iServer.iSharedData.iReservedSectorCount + iServer.iSharedData.iSectorsPerFat * 2 + 33) % boundaryUnit == 0);
- SYMBIAN_TEST_TESTNOPANIC(iServer.iSharedData.iPartitionBootSector >= boundaryUnit);
- }
-
-/*
-Compare Boot Sectors and Backup Boot Sectors
-
-@param None
-@return None
-*/
-void CBaseTestSDFieldCheck::FSBackupSectors()
- {
- INFO_PRINTF1(_L("FSx - Compare Boot Sectors and Backup Boot Sectors"));
- // Backup sectors must start on sector 6 (relative)
- TBuf8<KSectorSize> originalsector;
- TBuf8<KSectorSize> backupsector;
-
- for (TInt i = 0; i < 3; i++)
- {
- INFO_PRINTF2(_L("Boot sector comparison %d/3"), i + 1);
- if (ReadSector(iServer.iSharedData.iPartitionBootSector + i, originalsector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
- if (ReadSector(iServer.iSharedData.iPartitionBootSector + i + 6, backupsector) != KErrNone)
- {
- SetTestStepResult(EFail);
- return;
- }
- TBool areIdentical = ETrue;
- for (TInt j = 0; j < KSectorSize; j++)
- {
- if (originalsector[j] != backupsector[j])
- {
- areIdentical = EFalse;
- }
- }
- if (areIdentical)
- {
- INFO_PRINTF1(_L("Sectors are identical"));
- }
- else
- {
- ERR_PRINTF1(_L("Sectors are not identical"));
- SetTestStepResult(EFail);
- }
- }
- }