Re: sd_mod or usb-storage fails to read a single good block (was: ehci_hcd fails to read a single good block)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, 30 Apr 2012, Norman Diamond wrote:

> Here you are modifying my proposal.  It is no problem to discuss your
> idea.  At first I thought your idea was better than mine, but on
> second thought, sorry, here's a problem.  Again it is because the
> broken and unbroken Prolific bridges are indistinguishable.  A
> Prolific bridge could be connected to a drive whose actual usable
> capacity is a multiple of 63, or it could be connected to a modern
> drive with emulated capacity that is even (in fact a multiple of 8)
> and not usually a multiple of 63.
> 
> Therefore I still favour my version.  If the bridge reports an even
> number then I want to believe it, if the bridge reports a multiple of
> 63 then I want to believe it, and if neither then I want to fall back
> on the existing heuristic which performs a decrement.

Hmmm.  What about when one of the broken bridges with an older drive
reports a number which is 1 larger than a multiple of 63 but also
happens to be even?  In that case your proposed heuristic would fail --
but then so would the existing heuristic, so we'd be no worse off than
we are now.

I still think your proposed heuristic should be handled separately from 
the existing one, so that it would not be applied in situations where 
we know the device is not a USB-(S)ATA bridge.

> > As for whether we need TEST_CAPACITY...� That is still highly
> > debatable.� If we did have it, which quirk entries would use it?� So
> > far the only candidate we have is your Prolific bridge, and even there
> > it seems that the divisible-by-63 heuristic would work just as well.
> 
> I wish I could get a broken Prolific bridge to test together with
> mine.  Anyway the divisible-by-63 heuristic would work better than
> the existing heuristic but it would not work as well as
> TEST_CAPACITY.  My proposed modified heursitic would usually work
> better than the existing heuristic but not as well as TEST_CAPACITY.

How do you know?  You haven't read through ten years' worth of email 
messages on this subject, have you?  You're going on the basis of your 
experience with _one_ bridge and a couple of drives.

By the way, have you tried connecting your bridge to a CD/DVD drive?  
I believe that some bridges are supposed to work with both regular
disks and optical drives, but I don't know if any of them mess up the
capacity of an optical disc.  Quite possibly not.

> By the way, a while back you asked what happens if I use sg_dd to try
> reading multiple blocks including the last existing block and some
> non-existing ones.  The answer seems to depend on the drive as well
> as the method of connection (USB-to-PATA vs. eSATA plus
> SATA-to-PATA).  With the drive that I've usually been using I think
> the drive hangs so we can't really figure out whether to blame the
> bridge.  With a different drive the drive reports the error but sg_dd
> and Linux drivers do something to retry so many times that after 30
> minutes I lost patience waiting for sg_dd to finish and report its
> error.

Indeed -- that's exactly the sort of thing which could happen with
TEST_CAPACITY.  It's one of the reasons I'm cautious about adding
TEST_CAPACITY and an example of why TEST_CAPACITY might not work as 
well as you think.

Alan Stern

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux