mirror of
https://github.com/aaru-dps/Aaru.Server.git
synced 2025-12-16 19:24:27 +00:00
Added information from SPC-5.
This commit is contained in:
@@ -1,3 +1,8 @@
|
|||||||
|
2015-10-30 Natalia Portillo <claunia@claunia.com>
|
||||||
|
|
||||||
|
* SCSI/Modes.cs:
|
||||||
|
Added information from SPC-5.
|
||||||
|
|
||||||
2015-10-30 Natalia Portillo <claunia@claunia.com>
|
2015-10-30 Natalia Portillo <claunia@claunia.com>
|
||||||
|
|
||||||
* SCSI/Modes.cs:
|
* SCSI/Modes.cs:
|
||||||
|
|||||||
@@ -1146,7 +1146,7 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
/// Control mode page
|
/// Control mode page
|
||||||
/// Page code 0x0A
|
/// Page code 0x0A
|
||||||
/// 8 bytes in SCSI-2
|
/// 8 bytes in SCSI-2
|
||||||
/// 12 bytes in SPC-1, SPC-2, SPC-3
|
/// 12 bytes in SPC-1, SPC-2, SPC-3, SPC-4, SPC-5
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public struct ModePage_0A
|
public struct ModePage_0A
|
||||||
{
|
{
|
||||||
@@ -1480,7 +1480,7 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Disconnect-reconnect page
|
/// Disconnect-reconnect page
|
||||||
/// Page code 0x02
|
/// Page code 0x02
|
||||||
/// 16 bytes in SCSI-2, SPC-1, SPC-2, SPC-3
|
/// 16 bytes in SCSI-2, SPC-1, SPC-2, SPC-3, SPC-4, SPC-5
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public struct ModePage_02
|
public struct ModePage_02
|
||||||
{
|
{
|
||||||
@@ -4048,7 +4048,7 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Informational exceptions control page
|
/// Informational exceptions control page
|
||||||
/// Page code 0x1C
|
/// Page code 0x1C
|
||||||
/// 12 bytes in SPC-1, SPC-2, SPC-3
|
/// 12 bytes in SPC-1, SPC-2, SPC-3, SPC-4
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public struct ModePage_1C
|
public struct ModePage_1C
|
||||||
{
|
{
|
||||||
@@ -4093,6 +4093,11 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
/// Warning reporting enabled
|
/// Warning reporting enabled
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public bool EWasc;
|
public bool EWasc;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enable reporting of background self-test errors
|
||||||
|
/// </summary>
|
||||||
|
public bool EBACKERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ModePage_1C? DecodeModePage_1C(byte[] pageResponse)
|
public static ModePage_1C? DecodeModePage_1C(byte[] pageResponse)
|
||||||
@@ -4117,9 +4122,9 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
decoded.PS |= (pageResponse[0] & 0x80) == 0x80;
|
decoded.PS |= (pageResponse[0] & 0x80) == 0x80;
|
||||||
|
|
||||||
decoded.Perf |= (pageResponse[2] & 0x80) == 0x80;
|
decoded.Perf |= (pageResponse[2] & 0x80) == 0x80;
|
||||||
decoded.DExcpt |= (pageResponse[2] & 0x80) == 0x80;
|
decoded.DExcpt |= (pageResponse[2] & 0x08) == 0x08;
|
||||||
decoded.Test |= (pageResponse[2] & 0x80) == 0x80;
|
decoded.Test |= (pageResponse[2] & 0x04) == 0x04;
|
||||||
decoded.LogErr |= (pageResponse[2] & 0x80) == 0x80;
|
decoded.LogErr |= (pageResponse[2] & 0x01) == 0x01;
|
||||||
|
|
||||||
decoded.MRIE = (byte)(pageResponse[3] & 0x0F);
|
decoded.MRIE = (byte)(pageResponse[3] & 0x0F);
|
||||||
|
|
||||||
@@ -4129,6 +4134,8 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
decoded.EBF |= (pageResponse[2] & 0x20) == 0x20;
|
decoded.EBF |= (pageResponse[2] & 0x20) == 0x20;
|
||||||
decoded.EWasc |= (pageResponse[2] & 0x10) == 0x10;
|
decoded.EWasc |= (pageResponse[2] & 0x10) == 0x10;
|
||||||
|
|
||||||
|
decoded.EBACKERR |= (pageResponse[2] & 0x02) == 0x02;
|
||||||
|
|
||||||
return decoded;
|
return decoded;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -4207,6 +4214,8 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
sb.AppendLine("\tWarning reporting is enabled");
|
sb.AppendLine("\tWarning reporting is enabled");
|
||||||
if (page.EBF)
|
if (page.EBF)
|
||||||
sb.AppendLine("\tBackground functions are enabled");
|
sb.AppendLine("\tBackground functions are enabled");
|
||||||
|
if (page.EBACKERR)
|
||||||
|
sb.AppendLine("\tDrive will report background self-test errors");
|
||||||
|
|
||||||
return sb.ToString();
|
return sb.ToString();
|
||||||
}
|
}
|
||||||
@@ -4216,7 +4225,8 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Power condition page
|
/// Power condition page
|
||||||
/// Page code 0x1A
|
/// Page code 0x1A
|
||||||
/// 12 bytes in SPC-1, SPC-2, SPC-3
|
/// 12 bytes in SPC-1, SPC-2, SPC-3, SPC-4
|
||||||
|
/// 40 bytes in SPC-5
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public struct ModePage_1A
|
public struct ModePage_1A
|
||||||
{
|
{
|
||||||
@@ -4240,6 +4250,38 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
/// Standby timer
|
/// Standby timer
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public uint StandbyTimer;
|
public uint StandbyTimer;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Interactions between background functions and power management
|
||||||
|
/// </summary>
|
||||||
|
public byte PM_BG_Precedence;
|
||||||
|
/// <summary>
|
||||||
|
/// Standby timer Y activated
|
||||||
|
/// </summary>
|
||||||
|
public bool Standby_Y;
|
||||||
|
/// <summary>
|
||||||
|
/// Idle timer B activated
|
||||||
|
/// </summary>
|
||||||
|
public bool Idle_B;
|
||||||
|
/// <summary>
|
||||||
|
/// Idle timer C activated
|
||||||
|
/// </summary>
|
||||||
|
public bool Idle_C;
|
||||||
|
/// <summary>
|
||||||
|
/// Idle timer B
|
||||||
|
/// </summary>
|
||||||
|
public uint IdleTimer_B;
|
||||||
|
/// <summary>
|
||||||
|
/// Idle timer C
|
||||||
|
/// </summary>
|
||||||
|
public uint IdleTimer_C;
|
||||||
|
/// <summary>
|
||||||
|
/// Standby timer Y
|
||||||
|
/// </summary>
|
||||||
|
public uint StandbyTimer_Y;
|
||||||
|
public byte CCF_Idle;
|
||||||
|
public byte CCF_Standby;
|
||||||
|
public byte CCF_Stopped;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ModePage_1A? DecodeModePage_1A(byte[] pageResponse)
|
public static ModePage_1A? DecodeModePage_1A(byte[] pageResponse)
|
||||||
@@ -4269,6 +4311,22 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
decoded.IdleTimer = (uint)((pageResponse[4] << 24) + (pageResponse[5] << 16) + (pageResponse[6] << 8) + pageResponse[7]);
|
decoded.IdleTimer = (uint)((pageResponse[4] << 24) + (pageResponse[5] << 16) + (pageResponse[6] << 8) + pageResponse[7]);
|
||||||
decoded.StandbyTimer = (uint)((pageResponse[8] << 24) + (pageResponse[9] << 16) + (pageResponse[10] << 8) + pageResponse[11]);
|
decoded.StandbyTimer = (uint)((pageResponse[8] << 24) + (pageResponse[9] << 16) + (pageResponse[10] << 8) + pageResponse[11]);
|
||||||
|
|
||||||
|
if (pageResponse.Length < 40)
|
||||||
|
return decoded;
|
||||||
|
|
||||||
|
decoded.PM_BG_Precedence = (byte)((pageResponse[2] & 0xC0) >> 6);
|
||||||
|
decoded.Standby_Y |= (pageResponse[2] & 0x01) == 0x01;
|
||||||
|
decoded.Idle_B |= (pageResponse[3] & 0x04) == 0x04;
|
||||||
|
decoded.Idle_C |= (pageResponse[3] & 0x08) == 0x08;
|
||||||
|
|
||||||
|
decoded.IdleTimer_B = (uint)((pageResponse[12] << 24) + (pageResponse[13] << 16) + (pageResponse[14] << 8) + pageResponse[15]);
|
||||||
|
decoded.IdleTimer_C = (uint)((pageResponse[16] << 24) + (pageResponse[17] << 16) + (pageResponse[18] << 8) + pageResponse[19]);
|
||||||
|
decoded.StandbyTimer_Y = (uint)((pageResponse[20] << 24) + (pageResponse[21] << 16) + (pageResponse[22] << 8) + pageResponse[23]);
|
||||||
|
|
||||||
|
decoded.CCF_Idle = (byte)((pageResponse[39] & 0xC0) >> 6);
|
||||||
|
decoded.CCF_Standby = (byte)((pageResponse[39] & 0x30) >> 4);
|
||||||
|
decoded.CCF_Stopped = (byte)((pageResponse[39] & 0x0C) >> 2);
|
||||||
|
|
||||||
return decoded;
|
return decoded;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -4290,16 +4348,43 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
if (page.PS)
|
if (page.PS)
|
||||||
sb.AppendLine("\tParameters can be saved");
|
sb.AppendLine("\tParameters can be saved");
|
||||||
|
|
||||||
if (page.Standby && page.StandbyTimer > 0)
|
if ((page.Standby && page.StandbyTimer > 0) ||
|
||||||
sb.AppendFormat("\tDrive will enter standby mode in {0} ms", page.StandbyTimer).AppendLine();
|
(page.Standby_Y && page.StandbyTimer_Y > 0))
|
||||||
|
{
|
||||||
|
if(page.Standby && page.StandbyTimer > 0)
|
||||||
|
sb.AppendFormat("\tStandby timer Z is set to {0} ms", page.StandbyTimer * 100).AppendLine();
|
||||||
|
if(page.Standby_Y && page.StandbyTimer_Y > 0)
|
||||||
|
sb.AppendFormat("\tStandby timer Y is set to {0} ms", page.StandbyTimer_Y * 100).AppendLine();
|
||||||
|
}
|
||||||
else
|
else
|
||||||
sb.AppendLine("\tDrive will not enter standy mode");
|
sb.AppendLine("\tDrive will not enter standy mode");
|
||||||
|
|
||||||
|
if ((page.Idle && page.IdleTimer > 0) ||
|
||||||
|
(page.Idle_B && page.IdleTimer_B > 0) ||
|
||||||
|
(page.Idle_C && page.IdleTimer_C > 0))
|
||||||
|
{
|
||||||
if(page.Idle && page.IdleTimer > 0)
|
if(page.Idle && page.IdleTimer > 0)
|
||||||
sb.AppendFormat("\tDrive will enter idle mode in {0} ms", page.StandbyTimer).AppendLine();
|
sb.AppendFormat("\tIdle timer A is set to {0} ms", page.IdleTimer * 100).AppendLine();
|
||||||
|
if(page.Idle_B && page.IdleTimer_B > 0)
|
||||||
|
sb.AppendFormat("\tIdle timer B is set to {0} ms", page.IdleTimer_B * 100).AppendLine();
|
||||||
|
if(page.Idle_C && page.IdleTimer_C > 0)
|
||||||
|
sb.AppendFormat("\tIdle timer C is set to {0} ms", page.IdleTimer_C * 100).AppendLine();
|
||||||
|
}
|
||||||
else
|
else
|
||||||
sb.AppendLine("\tDrive will not enter idle mode");
|
sb.AppendLine("\tDrive will not enter idle mode");
|
||||||
|
|
||||||
|
switch (page.PM_BG_Precedence)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
sb.AppendLine("\tPerforming background functions take precedence over maintaining low power conditions");
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
sb.AppendLine("\tMaintaining low power conditions take precedence over performing background functions");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
return sb.ToString();
|
return sb.ToString();
|
||||||
}
|
}
|
||||||
#endregion Mode Page 0x1A: Power condition page
|
#endregion Mode Page 0x1A: Power condition page
|
||||||
@@ -4309,7 +4394,7 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
/// Control Extension mode page
|
/// Control Extension mode page
|
||||||
/// Page code 0x0A
|
/// Page code 0x0A
|
||||||
/// Subpage code 0x01
|
/// Subpage code 0x01
|
||||||
/// 32 bytes in SPC-3
|
/// 32 bytes in SPC-3, SPC-4, SPC-5
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public struct ModePage_0A_S01
|
public struct ModePage_0A_S01
|
||||||
{
|
{
|
||||||
@@ -4333,6 +4418,15 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
/// Initial task priority
|
/// Initial task priority
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public byte InitialPriority;
|
public byte InitialPriority;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Device life control disabled
|
||||||
|
/// </summary>
|
||||||
|
public bool DLC;
|
||||||
|
/// <summary>
|
||||||
|
/// Maximum size of SENSE data in bytes
|
||||||
|
/// </summary>
|
||||||
|
public byte MaximumSenseLength;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ModePage_0A_S01? DecodeModePage_0A_S01(byte[] pageResponse)
|
public static ModePage_0A_S01? DecodeModePage_0A_S01(byte[] pageResponse)
|
||||||
@@ -4399,7 +4493,13 @@ namespace DiscImageChef.Decoders.SCSI
|
|||||||
if (page.IALUAE)
|
if (page.IALUAE)
|
||||||
sb.AppendLine("\tImplicit Asymmetric Logical Unit Access is enabled");
|
sb.AppendLine("\tImplicit Asymmetric Logical Unit Access is enabled");
|
||||||
|
|
||||||
sb.AppendFormat("\tInitial priority is {0}", page.InitialPriority);
|
sb.AppendFormat("\tInitial priority is {0}", page.InitialPriority).AppendLine();
|
||||||
|
|
||||||
|
if (page.DLC)
|
||||||
|
sb.AppendLine("\tDevice will not degrade performance to extend its life");
|
||||||
|
|
||||||
|
if (page.MaximumSenseLength > 0)
|
||||||
|
sb.AppendFormat("\tMaximum sense data would be {0} bytes", page.MaximumSenseLength).AppendLine();
|
||||||
|
|
||||||
return sb.ToString();
|
return sb.ToString();
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user