mirror of
https://github.com/aaru-dps/Aaru.git
synced 2025-12-16 19:24:25 +00:00
Some SCSI devices get reset on incorrect commands, so retry up
to 5 device resets in media info and dumping.
This commit is contained in:
@@ -53,9 +53,11 @@ namespace DiscImageChef.Core.Devices.Dumping
|
|||||||
byte[] senseBuf = null;
|
byte[] senseBuf = null;
|
||||||
bool sense = false;
|
bool sense = false;
|
||||||
MediaType dskType = MediaType.Unknown;
|
MediaType dskType = MediaType.Unknown;
|
||||||
|
int resets = 0;
|
||||||
|
|
||||||
if(dev.IsRemovable)
|
if(dev.IsRemovable)
|
||||||
{
|
{
|
||||||
|
deviceGotReset:
|
||||||
sense = dev.ScsiTestUnitReady(out senseBuf, dev.Timeout, out double duration);
|
sense = dev.ScsiTestUnitReady(out senseBuf, dev.Timeout, out double duration);
|
||||||
if(sense)
|
if(sense)
|
||||||
{
|
{
|
||||||
@@ -63,6 +65,15 @@ namespace DiscImageChef.Core.Devices.Dumping
|
|||||||
if(decSense.HasValue)
|
if(decSense.HasValue)
|
||||||
{
|
{
|
||||||
dumpLog.WriteLine("Device not ready. Sense {0}h ASC {1:X2}h ASCQ {2:X2}h", decSense.Value.SenseKey, decSense.Value.ASC, decSense.Value.ASCQ);
|
dumpLog.WriteLine("Device not ready. Sense {0}h ASC {1:X2}h ASCQ {2:X2}h", decSense.Value.SenseKey, decSense.Value.ASC, decSense.Value.ASCQ);
|
||||||
|
|
||||||
|
// Just retry, for 5 times
|
||||||
|
if(decSense.Value.ASC == 0x29)
|
||||||
|
{
|
||||||
|
resets++;
|
||||||
|
if(resets < 5)
|
||||||
|
goto deviceGotReset;
|
||||||
|
}
|
||||||
|
|
||||||
if(decSense.Value.ASC == 0x3A)
|
if(decSense.Value.ASC == 0x3A)
|
||||||
{
|
{
|
||||||
int leftRetries = 5;
|
int leftRetries = 5;
|
||||||
|
|||||||
@@ -112,15 +112,25 @@ namespace DiscImageChef.Commands
|
|||||||
MediaType dskType = MediaType.Unknown;
|
MediaType dskType = MediaType.Unknown;
|
||||||
ulong blocks = 0;
|
ulong blocks = 0;
|
||||||
uint blockSize = 0;
|
uint blockSize = 0;
|
||||||
|
int resets = 0;
|
||||||
|
|
||||||
if(dev.IsRemovable)
|
if(dev.IsRemovable)
|
||||||
{
|
{
|
||||||
|
deviceGotReset:
|
||||||
sense = dev.ScsiTestUnitReady(out senseBuf, dev.Timeout, out duration);
|
sense = dev.ScsiTestUnitReady(out senseBuf, dev.Timeout, out duration);
|
||||||
if(sense)
|
if(sense)
|
||||||
{
|
{
|
||||||
Decoders.SCSI.FixedSense? decSense = Decoders.SCSI.Sense.DecodeFixed(senseBuf);
|
Decoders.SCSI.FixedSense? decSense = Decoders.SCSI.Sense.DecodeFixed(senseBuf);
|
||||||
if(decSense.HasValue)
|
if(decSense.HasValue)
|
||||||
{
|
{
|
||||||
|
// Just retry, for 5 times
|
||||||
|
if(decSense.Value.ASC == 0x29)
|
||||||
|
{
|
||||||
|
resets++;
|
||||||
|
if(resets < 5)
|
||||||
|
goto deviceGotReset;
|
||||||
|
}
|
||||||
|
|
||||||
if(decSense.Value.ASC == 0x3A)
|
if(decSense.Value.ASC == 0x3A)
|
||||||
{
|
{
|
||||||
int leftRetries = 5;
|
int leftRetries = 5;
|
||||||
|
|||||||
Reference in New Issue
Block a user