diff -r a41df078684a -r 4122176ea935 baseintegtests/baseintegrationtest/testsuites/sd/src/sdfieldcheck.cpp --- 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 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 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 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 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 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 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 originalsector; - TBuf8 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); - } - } - }