Re: [PATCH resend 1/4] scsi/sr: add no_read_disc_info scsi_device flag

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

 



On Tue, Aug 03, 2010 at 10:14:48AM -0400, Alan Stern wrote:
> On Mon, 2 Aug 2010, Hans de Goede wrote:
> 
> > Hi,
> > 
> > On 07/28/2010 03:19 PM, James Bottomley wrote:
> > > On Fri, 2010-07-23 at 10:52 +0200, Hans de Goede wrote:
> > >> Some USB devices emulate a usb-mass-storage attached (scsi) cdrom device,
> > >> usually this fake cdrom contains the windows software for the device.
> > >> While working on supporting Appotech ax3003 based photoframes, which do
> > >> this I discovered that they will go of into lala land when ever they
> > >> see a READ_DISC_INFO scsi command.
> > >>
> > >> Thus this patch adds a scsi_device flag (which can then be set by the
> > >> usb-storage driver through an unsual-devs entry), to indicate this, and
> > >> makes the sr driver honor this flag.
> > >>
> > >> I know this sucks, but as discussed on linux-scsi list there is no other
> > >> way to make this device work properly.
> > >>
> > >> Looking at usb traces made under windows, windows never sends a
> > >> READ_DISC_INFO during normal interactions with a usb cdrom device. So as
> > >> this cdrom emulation thingie becomes more common we might see more of
> > >> this problem.
> > >
> > > So, I suppose we can do this.  I dislike threading device bugs like this
> > > up and down the stack.  The usb stor_control_thread already does some
> > > command filtering; if it just rejected this command and READ
> > > CAPACITY(16) on the flags, I think it would be far less code and the
> > > SCSI subsystem would just do the right thing.
> > >
> > > I'd actually like to hear from USB what they'd prefer to do.
> > >
> > 
> > I was sort of hoping that Alan Stern would reply to this, but maybe he is
> > on vacation?
> 
> No, I'm here.  I've been waiting to hear from Matt Dharm.  He's the 
> usb-storage maintainer, so it's his call.

Sorry, I've been travelling quite a lot lately.

> In general it's hard to know how command filtering at the usb-storage 
> level will interact with the higher SCSI layers.  In this case we have 
> James's assurance that it will be okay.

usb-storage is really just a command/data transport mechanism.  I've tried
to keep the command filtering to an absolute minimum.  In the past, we've
engaged in command filtering and it was a pretty big disaster in terms of
maintainance.

Basically, my theory for pushing this into the SCSI layers comes down to
these reasons:

1) A lot of these sorts of things only applies to one type of device or
another.  Either a specific type (CD-ROM, Random-Access, etc) or a specific
vendor.  It is much easier for SCSI layers to identify these devices than
usb-storage to do so.  In this specific case, we need to make a change only
to how CD-ROM devices work; usb-storage doesn't track the device type.

2) A lot of these bugs will re-appear in either sbp2 or UAS, both of which
use SCSI, so let's put all this in a common place rather than replicate it
multiple times.

3) With many of these things, what we are really trying to do is implement
some sort of sea-change in the command stream.  Consider devices which only
accept 6-byte commands instead of 10-byte commands.  Usb-storage could
intercept the 10-byte commands and either re-write all of them
(problematic, we've tried this before) or reject them in such a way as to
try to get the SCSI layers to generate the 6-byte variants (problematic, as
the SCSI folks could change their logic at any time, we've tried this
before).  It makes *way* more sense to just *tell* the SCSI layers what we
want, rather than do various forms of trickery to make it happen.

In short, after years of running around trying to make devices work, the
only reliable and maintainable way for doing this seems to be to make
commands originate correctly, rather than try to intercept the commands
in-flight and do some sort of fixup.

Matt

-- 
Matthew Dharm                              Home: mdharm-usb@xxxxxxxxxxxxxxxxxx 
Maintainer, Linux USB Mass Storage Driver

P:  Nine more messages in admin.policy.
M: I know, I'm typing as fast as I can!
					-- Pitr and Mike
User Friendly, 11/27/97

Attachment: pgpUfUFRstCZn.pgp
Description: PGP signature


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

  Powered by Linux