Alan Stern wrote: > On Tue, 10 Apr 2012, Norman Diamond wrote: > > Alan Stern wrote: >>> On Mon, 9 Apr 2012, Norman Diamond wrote: >>>> I suggest that quirk processing should only try to read 1 block, the last block which is asserted to exist, and decrement if the read fails due to non-existence. If the read fails for a different reason then the block exists and the count should not be decremented. >>> >>> I have tried to explain before that this is a very bad idea. Bridges that crash when attempting to read beyond the end of the device would become totally unusable. >> >> In cases where a bridge has been observed to crash when trying to read a SINGLE block which the bridge asserted to exist but which didn't actually exist, I agree that an aggressive quirk is needed. >> >> In cases where a bridge has been observed to crash when trying to read MULTIPLE blocks among which one block had a problem, there is no evidence yet to judge that my idea is very bad. Those bridges need to be tested again with single block reads, and need to be tested on reading the last block number which the bridge asserts to exist rather than attempting to read an existing bad block (by coincidence the two might be the same block, but not usually). > > It sounds like you are suggesting that we have a new quirk, something like TEST_CAPACITY. When this quirk is present, we could attempt to read the last block when the drive (or media) is first detected, thereby determining whether the reported capacity needs to be adjusted. Yes, that is what I've been suggesting for a while. But at this moment I might have a better suggestion, discussed below. Or it might be better to combine the two ideas. > The existing FIX_CAPACITY and CAPACITY_HEURISTICS quirk entries could be changed to TEST_CAPACITY as people report the results of their testing. However this would be a very slow process. FIX_CAPACITY will still be necessary in cases where a bridge is known to have both problems, always overreporting and crashing when tested for overreporting. I think these cases will be a small minority though. Now, I think that most of the existing FIX_CAPACITY cases probably should be changed to CAPACITY_HEURISTICS. This will be simpler and quicker, though not maximally accurate by itself. In drivers/scsi/sd.c, fix_capacity always causes a decrement but guess_capacity guesses an even number. So one thing to do for the Prolific bridge in unusual_devs.h is to use US_FL_CAPACITY_HEURISTICS instead of US_FL_FIX_CAPACITY. I also think that if the reported capacity is a multiple of 63 then it is very likely to be accurate and should not be decremented. Furthermore if the capacity is a multiple of 126 (i.e. even as in the current heuristic, and a multiple of 63) then US_FL_FIX_CAPACITY is almost certainly wrong. Of course that 63 is artificial but it is very common and the reason is well known. -- 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