Files
Aaru/Aaru.Core/Logging/ErrorLog.cs

499 lines
19 KiB
C#
Raw Normal View History

2020-07-19 22:01:25 +01:00
// /***************************************************************************
// Aaru Data Preservation Suite
// ----------------------------------------------------------------------------
//
// Filename : ErrorLog.cs
// Author(s) : Natalia Portillo <claunia@claunia.com>
//
// Component : Core algorithms.
//
// --[ License ] --------------------------------------------------------------
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
//
// ----------------------------------------------------------------------------
2024-12-19 10:45:18 +00:00
// Copyright © 2011-2025 Natalia Portillo
2020-07-19 22:01:25 +01:00
// ****************************************************************************/
2020-07-13 18:54:41 +01:00
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using Aaru.Decoders.ATA;
using Aaru.Decoders.SCSI;
namespace Aaru.Core.Logging;
2022-03-06 13:29:38 +00:00
/// <summary>Logs errors</summary>
public sealed class ErrorLog
2020-07-13 18:54:41 +01:00
{
2022-03-06 13:29:38 +00:00
readonly StreamWriter _logSw;
/// <summary>Initializes the error log</summary>
/// <param name="outputFile">Output log file</param>
public ErrorLog(string outputFile)
2020-07-13 18:54:41 +01:00
{
2024-05-01 04:05:22 +01:00
if(string.IsNullOrEmpty(outputFile)) return;
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw = new StreamWriter(outputFile, true);
2020-07-13 18:54:41 +01:00
_logSw.WriteLine(Localization.Core.Start_error_logging_on_0, DateTime.Now);
_logSw.WriteLine(Localization.Core.Log_section_separator);
2022-03-06 13:29:38 +00:00
_logSw.Flush();
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
/// <summary>Finishes and closes the error log</summary>
public void Close()
{
_logSw.WriteLine(Localization.Core.Log_section_separator);
_logSw.WriteLine(Localization.Core.End_logging_on_0, DateTime.Now);
2022-03-06 13:29:38 +00:00
_logSw.Close();
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
/// <summary>Register an ATA error after sending a CHS command</summary>
/// <param name="command">Command</param>
/// <param name="osError"><c>true</c> if operating system returned an error status instead of the device</param>
/// <param name="errno">Operating system error number</param>
/// <param name="registers">Error registers</param>
public void WriteLine(string command, bool osError, int errno, AtaErrorRegistersChs registers)
{
if(osError)
2020-07-13 18:54:41 +01:00
{
_logSw.WriteLine(Localization.Core.ATA_command_0_operating_system_error_1, command, errno);
2022-03-06 13:29:38 +00:00
_logSw.Flush();
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
else
2020-07-13 18:54:41 +01:00
{
2024-05-01 04:39:38 +01:00
List<string> error = [];
List<string> status = [];
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x01) == 0x01) status.Add("ERR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x02) == 0x02) status.Add("IDX");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x04) == 0x04) status.Add("CORR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x08) == 0x08) status.Add("DRQ");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x10) == 0x10) status.Add("SRV");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x20) == 0x20) status.Add("DF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x40) == 0x40) status.Add("RDY");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x80) == 0x80) status.Add("BSY");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x01) == 0x01) error.Add("AMNF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x02) == 0x02) error.Add("T0NF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x04) == 0x04) error.Add("ABRT");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x08) == 0x08) error.Add("MCR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x10) == 0x10) error.Add("IDNF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x20) == 0x20) error.Add("MC");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x40) == 0x40) error.Add("UNC");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x80) == 0x80) error.Add("BBK");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.ATA_command_0_error_status_1_error_2,
command,
string.Join(' ', status),
string.Join(' ', error));
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
/// <summary>Register an ATA error after trying to read using CHS commands</summary>
/// <param name="cylinder">Cylinder</param>
/// <param name="head">Head</param>
/// <param name="sector">Sector</param>
/// <param name="osError"><c>true</c> if operating system returned an error status instead of the device</param>
/// <param name="errno">Operating system error number</param>
/// <param name="registers">Error registers</param>
2023-10-03 22:57:50 +01:00
public void WriteLine(ushort cylinder, byte head, byte sector, bool osError, int errno,
2022-03-06 13:29:38 +00:00
AtaErrorRegistersChs registers)
{
if(osError)
2020-07-13 18:54:41 +01:00
{
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.ATA_reading_CHS_0_1_2_operating_system_error_3,
cylinder,
head,
sector,
2022-03-06 13:29:38 +00:00
errno);
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
}
else
{
2024-05-01 04:39:38 +01:00
List<string> error = [];
List<string> status = [];
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x01) == 0x01) status.Add("ERR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x02) == 0x02) status.Add("IDX");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x04) == 0x04) status.Add("CORR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x08) == 0x08) status.Add("DRQ");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x10) == 0x10) status.Add("SRV");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x20) == 0x20) status.Add("DF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x40) == 0x40) status.Add("RDY");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x80) == 0x80) status.Add("BSY");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x01) == 0x01) error.Add("AMNF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x02) == 0x02) error.Add("T0NF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x04) == 0x04) error.Add("ABRT");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x08) == 0x08) error.Add("MCR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x10) == 0x10) error.Add("IDNF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x20) == 0x20) error.Add("MC");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x40) == 0x40) error.Add("UNC");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x80) == 0x80) error.Add("BBK");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.ATA_reading_CHS_0_1_2_error_status_3_error_4,
cylinder,
head,
sector,
string.Join(' ', status),
string.Join(' ', error));
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
/// <summary>Register an ATA error after trying to read using 28-bit LBA commands</summary>
/// <param name="block">Starting block</param>
/// <param name="osError"><c>true</c> if operating system returned an error status instead of the device</param>
/// <param name="errno">Operating system error number</param>
/// <param name="registers">Error registers</param>
public void WriteLine(ulong block, bool osError, int errno, AtaErrorRegistersLba28 registers)
{
if(osError)
2020-07-13 18:54:41 +01:00
{
_logSw.WriteLine(Localization.Core.ATA_reading_LBA_0_operating_system_error_1, block, errno);
2022-03-06 13:29:38 +00:00
_logSw.Flush();
}
else
{
2024-05-01 04:39:38 +01:00
List<string> error = [];
List<string> status = [];
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x01) == 0x01) status.Add("ERR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x02) == 0x02) status.Add("IDX");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x04) == 0x04) status.Add("CORR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x08) == 0x08) status.Add("DRQ");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x10) == 0x10) status.Add("SRV");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x20) == 0x20) status.Add("DF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x40) == 0x40) status.Add("RDY");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x80) == 0x80) status.Add("BSY");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x01) == 0x01) error.Add("AMNF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x02) == 0x02) error.Add("T0NF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x04) == 0x04) error.Add("ABRT");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x08) == 0x08) error.Add("MCR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x10) == 0x10) error.Add("IDNF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x20) == 0x20) error.Add("MC");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x40) == 0x40) error.Add("UNC");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x80) == 0x80) error.Add("BBK");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.ATA_reading_LBA_0_error_status_1_error_2,
block,
string.Join(' ', status),
string.Join(' ', error));
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
/// <summary>Register an ATA error after trying to read using 48-bit LBA commands</summary>
/// <param name="block">Starting block</param>
/// <param name="osError"><c>true</c> if operating system returned an error status instead of the device</param>
/// <param name="errno">Operating system error number</param>
/// <param name="registers">Error registers</param>
public void WriteLine(ulong block, bool osError, int errno, AtaErrorRegistersLba48 registers)
{
if(osError)
2020-07-13 18:54:41 +01:00
{
_logSw.WriteLine(Localization.Core.ATA_reading_LBA_0_operating_system_error_1, block, errno);
2022-03-06 13:29:38 +00:00
_logSw.Flush();
}
else
{
2024-05-01 04:39:38 +01:00
List<string> error = [];
List<string> status = [];
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x01) == 0x01) status.Add("ERR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x02) == 0x02) status.Add("IDX");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x04) == 0x04) status.Add("CORR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x08) == 0x08) status.Add("DRQ");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x10) == 0x10) status.Add("SRV");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x20) == 0x20) status.Add("DF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x40) == 0x40) status.Add("RDY");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Status & 0x80) == 0x80) status.Add("BSY");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x01) == 0x01) error.Add("AMNF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x02) == 0x02) error.Add("T0NF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x04) == 0x04) error.Add("ABRT");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x08) == 0x08) error.Add("MCR");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x10) == 0x10) error.Add("IDNF");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x20) == 0x20) error.Add("MC");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x40) == 0x40) error.Add("UNC");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if((registers.Error & 0x80) == 0x80) error.Add("BBK");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.ATA_reading_LBA_0_error_status_1_error_2,
block,
string.Join(' ', status),
string.Join(' ', error));
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
}
}
/// <summary>Register a SCSI error after sending a command</summary>
/// <param name="command">Command</param>
/// <param name="osError"><c>true</c> if operating system returned an error status instead of the device</param>
/// <param name="errno">Operating system error number</param>
/// <param name="senseBuffer">REQUEST SENSE response buffer</param>
public void WriteLine(string command, bool osError, int errno, byte[] senseBuffer)
{
if(osError)
{
_logSw.WriteLine(Localization.Core.SCSI_command_0_operating_system_error_1, command, errno);
2022-03-06 13:29:38 +00:00
_logSw.Flush();
return;
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
DecodedSense? decodedSense = Sense.Decode(senseBuffer);
2025-08-22 19:57:09 +01:00
string prettySense = Sense.PrettifySense(senseBuffer.ToArray());
string hexSense = string.Join(' ', senseBuffer.Select(b => $"{b:X2}"));
2022-03-06 13:29:38 +00:00
if(decodedSense.HasValue)
2020-07-13 18:54:41 +01:00
{
2022-03-06 13:29:38 +00:00
if(prettySense != null)
2020-07-13 18:54:41 +01:00
{
2024-05-01 04:05:22 +01:00
if(prettySense.StartsWith("SCSI SENSE: ", StringComparison.Ordinal)) prettySense = prettySense[12..];
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if(prettySense.EndsWith('\n')) prettySense = prettySense[..^1];
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
prettySense = prettySense.Replace("\n", " - ");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.SCSI_command_0_error_SENSE_1_ASC_2_ASCQ_3_4_5,
command,
decodedSense.Value.SenseKey,
decodedSense.Value.ASC,
decodedSense.Value.ASCQ,
hexSense,
2022-03-07 07:36:44 +00:00
prettySense);
2022-03-06 13:29:38 +00:00
}
else
2023-10-03 22:57:50 +01:00
{
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.SCSI_command_0_error_SENSE_1_ASC_2_ASCQ_3_4,
command,
decodedSense.Value.SenseKey,
decodedSense.Value.ASC,
decodedSense.Value.ASCQ,
2022-03-06 13:29:38 +00:00
hexSense);
2023-10-03 22:57:50 +01:00
}
2022-03-06 13:29:38 +00:00
}
else
{
if(prettySense != null)
2020-07-13 18:54:41 +01:00
{
2024-05-01 04:05:22 +01:00
if(prettySense.StartsWith("SCSI SENSE: ", StringComparison.Ordinal)) prettySense = prettySense[12..];
2022-03-06 13:29:38 +00:00
2024-05-01 04:05:22 +01:00
if(prettySense.EndsWith('\n')) prettySense = prettySense[..^1];
2022-03-06 13:29:38 +00:00
prettySense = prettySense.Replace("\n", " - ");
_logSw.WriteLine(Localization.Core.SCSI_command_0_error_1_2, command, hexSense, prettySense);
2020-07-13 18:54:41 +01:00
}
else
_logSw.WriteLine(Localization.Core.SCSI_command_0_error_1, command, hexSense);
2022-03-06 13:29:38 +00:00
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
}
2025-08-22 19:57:09 +01:00
public void WriteLine(ulong block, bool osError, int errno, ReadOnlySpan<byte> senseBuffer) =>
WriteLine(block, osError, errno, senseBuffer.ToArray());
2022-03-06 13:29:38 +00:00
/// <summary>Register an SCSI error after trying to read</summary>
/// <param name="block">Starting block</param>
/// <param name="osError"><c>true</c> if operating system returned an error status instead of the device</param>
/// <param name="errno">Operating system error number</param>
/// <param name="senseBuffer">REQUEST SENSE response buffer</param>
public void WriteLine(ulong block, bool osError, int errno, byte[] senseBuffer)
{
if(osError)
{
_logSw.WriteLine(Localization.Core.SCSI_reading_LBA_0_operating_system_error_1, block, errno);
2020-07-13 18:54:41 +01:00
_logSw.Flush();
2022-03-06 13:29:38 +00:00
2024-05-01 04:05:22 +01:00
if(senseBuffer is null || senseBuffer.Length == 0 || senseBuffer.All(s => s == 0)) return;
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
DecodedSense? decodedSense = Sense.Decode(senseBuffer);
2025-08-22 19:57:09 +01:00
string prettySense = Sense.PrettifySense(senseBuffer.ToArray());
string hexSense = string.Join(' ', senseBuffer.Select(b => $"{b:X2}"));
2022-03-06 13:29:38 +00:00
if(decodedSense.HasValue)
2020-07-13 18:54:41 +01:00
{
2022-03-06 13:29:38 +00:00
if(prettySense != null)
2020-07-13 18:54:41 +01:00
{
2024-05-01 04:05:22 +01:00
if(prettySense.StartsWith("SCSI SENSE: ", StringComparison.Ordinal)) prettySense = prettySense[12..];
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if(prettySense.EndsWith('\n')) prettySense = prettySense[..^1];
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
prettySense = prettySense.Replace("\n", " - ");
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.SCSI_reading_LBA_0_error_SENSE_1_ASC_2_ASCQ_3_4_5,
block,
decodedSense.Value.SenseKey,
decodedSense.Value.ASC,
decodedSense.Value.ASCQ,
hexSense,
2022-03-07 07:36:44 +00:00
prettySense);
2020-07-13 18:54:41 +01:00
}
else
2023-10-03 22:57:50 +01:00
{
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.SCSI_reading_LBA_0_error_SENSE_1_ASC_2_ASCQ_3_4,
block,
decodedSense.Value.SenseKey,
decodedSense.Value.ASC,
decodedSense.Value.ASCQ,
2022-03-06 13:29:38 +00:00
hexSense);
2023-10-03 22:57:50 +01:00
}
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
else
2020-07-13 18:54:41 +01:00
{
2022-03-06 13:29:38 +00:00
if(prettySense != null)
2020-07-13 18:54:41 +01:00
{
2024-05-01 04:05:22 +01:00
if(prettySense.StartsWith("SCSI SENSE: ", StringComparison.Ordinal)) prettySense = prettySense[12..];
2020-07-13 18:54:41 +01:00
2024-05-01 04:05:22 +01:00
if(prettySense.EndsWith('\n')) prettySense = prettySense[..^1];
2022-03-06 13:29:38 +00:00
prettySense = prettySense.Replace("\n", " - ");
_logSw.WriteLine(Localization.Core.SCSI_reading_LBA_0_error_1_2, block, hexSense, prettySense);
2022-03-06 13:29:38 +00:00
}
else
_logSw.WriteLine(Localization.Core.SCSI_reading_LBA_0_error_1, block, hexSense);
2022-03-06 13:29:38 +00:00
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
/// <summary>Register a SecureDigital / MultiMediaCard error after sending a command</summary>
/// <param name="command">Command</param>
/// <param name="osError"><c>true</c> if operating system returned an error status instead of the device</param>
/// <param name="errno">Operating system error number</param>
/// <param name="response">Response</param>
public void WriteLine(string command, bool osError, int errno, uint[] response)
{
if(osError)
{
_logSw.WriteLine(Localization.Core.SD_MMC_command_0_operating_system_error_1, command, errno);
2020-07-13 18:54:41 +01:00
_logSw.Flush();
2022-03-06 13:29:38 +00:00
return;
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
// TODO: Decode response
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(Localization.Core.SD_MMC_command_0_error_1,
command,
2022-03-06 13:29:38 +00:00
string.Join(" - ", response.Select(r => $"0x{r:X8}")));
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
}
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
/// <summary>Register a SecureDigital / MultiMediaCard error after trying to read</summary>
/// <param name="block">Starting block</param>
/// <param name="osError"><c>true</c> if operating system returned an error status instead of the device</param>
/// <param name="errno">Operating system error number</param>
/// <param name="byteAddressed">Byte addressed</param>
/// <param name="response">Response</param>
public void WriteLine(ulong block, bool osError, int errno, bool byteAddressed, uint[] response)
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
{
if(osError)
{
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(byteAddressed
? Localization.Core.SD_MMC_reading_LBA_0_byte_addressed_operating_system_error_1
: Localization.Core.SD_MMC_reading_LBA_0_block_addressed_operating_system_error_1,
block,
errno);
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
_logSw.Flush();
2020-07-13 18:54:41 +01:00
2022-03-06 13:29:38 +00:00
return;
2020-07-13 18:54:41 +01:00
}
2022-03-06 13:29:38 +00:00
2024-05-01 04:05:22 +01:00
_logSw.WriteLine(byteAddressed
? Localization.Core.SD_MMC_reading_LBA_0_byte_addressed_error_1
: Localization.Core.SD_MMC_reading_LBA_0_block_addressed_error_1,
block,
string.Join(" - ", response.Select(r => $"0x{r:X8}")));
2022-03-06 13:29:38 +00:00
throw new NotImplementedException();
2020-07-13 18:54:41 +01:00
}
2025-08-22 19:57:09 +01:00
public void WriteLine(string command, bool osError, int errno, ReadOnlySpan<byte> senseBuffer)
{
WriteLine(command, osError, errno, senseBuffer.ToArray());
}
2020-07-13 18:54:41 +01:00
}