From 386f35afb7b3ea5f350286f07eefb76c9d66ec7f Mon Sep 17 00:00:00 2001 From: Natalia Portillo Date: Fri, 8 Sep 2017 17:52:37 +0100 Subject: [PATCH] Added tests for CompactFlash commands. --- DiscImageChef.Tests.Devices/ATA/Cfa.cs | 355 ++++++++++++++++++++++++- 1 file changed, 352 insertions(+), 3 deletions(-) diff --git a/DiscImageChef.Tests.Devices/ATA/Cfa.cs b/DiscImageChef.Tests.Devices/ATA/Cfa.cs index 12544491..5a1c0284 100644 --- a/DiscImageChef.Tests.Devices/ATA/Cfa.cs +++ b/DiscImageChef.Tests.Devices/ATA/Cfa.cs @@ -37,6 +37,7 @@ // //$Id$ using DiscImageChef.Console; using DiscImageChef.Devices; +using DiscImageChef.Decoders.ATA; namespace DiscImageChef.Tests.Devices.ATA { @@ -50,7 +51,8 @@ namespace DiscImageChef.Tests.Devices.ATA DicConsole.WriteLine("Device: {0}", devPath); DicConsole.WriteLine("Send a CompactFlash command to the device:"); DicConsole.WriteLine("1.- Send REQUEST EXTENDED ERROR CODE command."); - DicConsole.WriteLine("2.- Send TRANSLATE SECTOR command."); + DicConsole.WriteLine("2.- Send CHS TRANSLATE SECTOR command."); + DicConsole.WriteLine("3.- Send LBA TRANSLATE SECTOR command."); DicConsole.WriteLine("0.- Return to ATA commands menu."); DicConsole.Write("Choose: "); @@ -67,6 +69,15 @@ namespace DiscImageChef.Tests.Devices.ATA case 0: DicConsole.WriteLine("Returning to ATA commands menu..."); return; + case 1: + RequestExtendedErrorCode(devPath, dev); + continue; + case 2: + TranslateSectorChs(devPath, dev); + continue; + case 3: + TranslateSectorLba(devPath, dev); + continue; default: DicConsole.WriteLine("Incorrect option. Press any key to continue..."); System.Console.ReadKey(); @@ -74,6 +85,344 @@ namespace DiscImageChef.Tests.Devices.ATA } } } - } -} + public static void RequestExtendedErrorCode(string devPath, Device dev) + { + start: + System.Console.Clear(); + bool sense = dev.RequestExtendedErrorCode(out byte errorCode, out AtaErrorRegistersLBA28 errorRegisters, dev.Timeout, out double duration); + + menu: + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("Sending REQUEST EXTENDED ERROR CODE to the device:"); + DicConsole.WriteLine("Command took {0} ms.", duration); + DicConsole.WriteLine("Sense is {0}.", sense); + DicConsole.WriteLine("Error code is {0}.", errorCode); + DicConsole.WriteLine(); + DicConsole.WriteLine("Choose what to do:"); + DicConsole.WriteLine("1.- Decode error registers."); + DicConsole.WriteLine("2.- Send command again."); + DicConsole.WriteLine("0.- Return to CompactFlash commands menu."); + DicConsole.Write("Choose: "); + + string strDev = System.Console.ReadLine(); + if(!int.TryParse(strDev, out int item)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + goto menu; + } + + switch(item) + { + case 0: + DicConsole.WriteLine("Returning to CompactFlash commands menu..."); + return; + case 1: + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("REQUEST EXTENDED ERROR CODE status registers:"); + DicConsole.Write("{0}", MainClass.DecodeATARegisters(errorRegisters)); + DicConsole.WriteLine("Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + goto menu; + case 2: + goto start; + default: + DicConsole.WriteLine("Incorrect option. Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + goto menu; + } + } + + public static void TranslateSectorChs(string devPath, Device dev) + { + ushort cylinder = 0; + byte head = 0; + byte sector = 1; + string strDev; + int item; + + parameters: + while(true) + { + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("Parameters for TRANSLATE SECTOR command:"); + DicConsole.WriteLine("Cylinder: {0}", cylinder); + DicConsole.WriteLine("Head: {0}", head); + DicConsole.WriteLine("Sector: {0}", sector); + DicConsole.WriteLine(); + DicConsole.WriteLine("Choose what to do:"); + DicConsole.WriteLine("1.- Change parameters."); + DicConsole.WriteLine("2.- Send command with these parameters."); + DicConsole.WriteLine("0.- Return to CompactFlash commands menu."); + + strDev = System.Console.ReadLine(); + if(!int.TryParse(strDev, out item)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + System.Console.ReadKey(); + continue; + } + + switch(item) + { + case 0: + DicConsole.WriteLine("Returning to CompactFlash commands menu..."); + return; + case 1: + DicConsole.Write("What cylinder?: "); + strDev = System.Console.ReadLine(); + if(!ushort.TryParse(strDev, out cylinder)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + cylinder = 0; + System.Console.ReadKey(); + continue; + } + DicConsole.Write("What head?: "); + strDev = System.Console.ReadLine(); + if(!byte.TryParse(strDev, out head)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + head = 0; + System.Console.ReadKey(); + continue; + } + if(head > 15) + { + DicConsole.WriteLine("Head cannot be bigger than 15. Setting it to 15..."); + head = 15; + } + DicConsole.Write("What sector?: "); + strDev = System.Console.ReadLine(); + if(!byte.TryParse(strDev, out sector)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + sector = 0; + System.Console.ReadKey(); + continue; + } + break; + case 2: + goto start; + } + } + + start: + System.Console.Clear(); + bool sense = dev.TranslateSector(out byte[] buffer, out AtaErrorRegistersCHS errorRegisters, cylinder, head, sector, dev.Timeout, out double duration); + + menu: + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("Sending TRANSLATE SECTOR to the device:"); + DicConsole.WriteLine("Command took {0} ms.", duration); + DicConsole.WriteLine("Sense is {0}.", sense); + DicConsole.WriteLine("Buffer is {0} bytes.", buffer == null ? "null" : buffer.Length.ToString()); + DicConsole.WriteLine("Buffer is null or empty? {0}", ArrayHelpers.ArrayIsNullOrEmpty(buffer)); + DicConsole.WriteLine(); + DicConsole.WriteLine("Choose what to do:"); + DicConsole.WriteLine("1.- Print buffer."); + DicConsole.WriteLine("2.- Decode buffer."); + DicConsole.WriteLine("3.- Decode error registers."); + DicConsole.WriteLine("4.- Send command again."); + DicConsole.WriteLine("5.- Change parameters."); + DicConsole.WriteLine("0.- Return to CompactFlash commands menu."); + DicConsole.Write("Choose: "); + + strDev = System.Console.ReadLine(); + if(!int.TryParse(strDev, out item)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + goto menu; + } + + switch(item) + { + case 0: + DicConsole.WriteLine("Returning to CompactFlash commands menu..."); + return; + case 1: + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("TRANSLATE SECTOR response:"); + if(buffer != null) + PrintHex.PrintHexArray(buffer, 64); + DicConsole.WriteLine("Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + goto menu; + case 2: + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("TRANSLATE SECTOR decoded response:"); + if(buffer != null) + DicConsole.WriteLine("{0}", Decoders.ATA.Identify.Prettify(buffer)); + DicConsole.WriteLine("Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + goto menu; + case 3: + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("TRANSLATE SECTOR status registers:"); + DicConsole.Write("{0}", MainClass.DecodeATARegisters(errorRegisters)); + DicConsole.WriteLine("Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + goto menu; + case 4: + goto start; + case 5: + goto parameters; + default: + DicConsole.WriteLine("Incorrect option. Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + goto menu; + } + } + + public static void TranslateSectorLba(string devPath, Device dev) + { + uint lba = 0; + string strDev; + int item; + + parameters: + while(true) + { + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("Parameters for TRANSLATE SECTOR command:"); + DicConsole.WriteLine("LBA: {0}", lba); + DicConsole.WriteLine(); + DicConsole.WriteLine("Choose what to do:"); + DicConsole.WriteLine("1.- Change parameters."); + DicConsole.WriteLine("2.- Send command with these parameters."); + DicConsole.WriteLine("0.- Return to CompactFlash commands menu."); + + strDev = System.Console.ReadLine(); + if(!int.TryParse(strDev, out item)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + System.Console.ReadKey(); + continue; + } + + switch(item) + { + case 0: + DicConsole.WriteLine("Returning to CompactFlash commands menu..."); + return; + case 1: + DicConsole.Write("What logical block address?: "); + strDev = System.Console.ReadLine(); + if(!uint.TryParse(strDev, out lba)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + lba = 0; + System.Console.ReadKey(); + continue; + } + if(lba > 0xFFFFFFF) + { + DicConsole.WriteLine("Logical block address cannot be bigger than {0}. Setting it to {0}...", 0xFFFFFFF); + lba = 0xFFFFFFF; + } + break; + case 2: + goto start; + } + } + + start: + System.Console.Clear(); + bool sense = dev.TranslateSector(out byte[] buffer, out AtaErrorRegistersLBA28 errorRegisters, lba, dev.Timeout, out double duration); + + menu: + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("Sending TRANSLATE SECTOR to the device:"); + DicConsole.WriteLine("Command took {0} ms.", duration); + DicConsole.WriteLine("Sense is {0}.", sense); + DicConsole.WriteLine("Buffer is {0} bytes.", buffer == null ? "null" : buffer.Length.ToString()); + DicConsole.WriteLine("Buffer is null or empty? {0}", ArrayHelpers.ArrayIsNullOrEmpty(buffer)); + DicConsole.WriteLine(); + DicConsole.WriteLine("Choose what to do:"); + DicConsole.WriteLine("1.- Print buffer."); + DicConsole.WriteLine("2.- Decode buffer."); + DicConsole.WriteLine("3.- Decode error registers."); + DicConsole.WriteLine("4.- Send command again."); + DicConsole.WriteLine("5.- Change parameters."); + DicConsole.WriteLine("0.- Return to CompactFlash commands menu."); + DicConsole.Write("Choose: "); + + strDev = System.Console.ReadLine(); + if(!int.TryParse(strDev, out item)) + { + DicConsole.WriteLine("Not a number. Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + goto menu; + } + + switch(item) + { + case 0: + DicConsole.WriteLine("Returning to CompactFlash commands menu..."); + return; + case 1: + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("TRANSLATE SECTOR response:"); + if(buffer != null) + PrintHex.PrintHexArray(buffer, 64); + DicConsole.WriteLine("Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + goto menu; + case 2: + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("TRANSLATE SECTOR decoded response:"); + if(buffer != null) + DicConsole.WriteLine("{0}", Decoders.ATA.Identify.Prettify(buffer)); + DicConsole.WriteLine("Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + goto menu; + case 3: + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + DicConsole.WriteLine("TRANSLATE SECTOR status registers:"); + DicConsole.Write("{0}", MainClass.DecodeATARegisters(errorRegisters)); + DicConsole.WriteLine("Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + DicConsole.WriteLine("Device: {0}", devPath); + goto menu; + case 4: + goto start; + case 5: + goto parameters; + default: + DicConsole.WriteLine("Incorrect option. Press any key to continue..."); + System.Console.ReadKey(); + System.Console.Clear(); + goto menu; + } + } + } +} \ No newline at end of file