[sane-devel] Slightly off topic: Anyone know anything about SCSI CD commands?

abel deuring adeuring at gmx.net
Tue Jan 6 08:55:33 UTC 2009


On 06.01.2009 00:24, kilgota at banach.math.auburn.edu wrote:
> Wishing everyone a prosperous, happy, and peaceful year 2009.
> 
> For a lark, I bought a rather worthless but very cheap gadget for myself 
> for Christmas. It is a very small digital picture frame which one can hang 
> on the key ring. The little book which came with it says that to use it, 
> one merely plugs it in on a computer running XP or Vista, and the app is 
> already installed which will communicate with it. I tried this, and it is 
> so. With the app, one can view JPEG images on the device, also move images 
> to/from, and delete what is on the device. Then, the device has a 
> primitive OS which will allow various things to be done, such as to 
> display the time instead of a picture. It also gets reported as an 
> external drive, with the information that it is "full" and AFAIK one 
> cannot access it directly.
> 
> I made one snoop log, which probably does not yet have the serious 
> information needed to continue with this thing. I spent most of my time 
> fighting Vista to get the log made.
> 
> So much for the background. What it is, is a Mass Storage Bulk Transport 
> device which comes up as a /dev/sg, not as a /dev/sd. So in other words it 
> is possible to talk to it with Mass Storage Bulk Transport, but one can 
> not mount it. In other words, similar to some audio CDs, or to some 
> scanners. In the forwarded message below, there is some report of the 
> results of various commands, and also a question at the end, about a 
> certain SCSI command with which I am not acquainted and can not seem to 
> find relevant documentation. I hope that someone can help me with the 
> question.
> 
> Theodore Kilgore
> 
> 
> ---------- Forwarded message ----------
> Date: Mon, 5 Jan 2009 12:57:13 -0600 (CST)
> From: kilgota at banach.math.auburn.edu
> To: Pete Zaitcev <zaitcev at redhat.com>
> Cc: usb-storage at lists.one-eyed-alien.net
> Subject: Re: [usb-storage] A keychain digital picture frame.
> 
> 
> 
> On Thu, 1 Jan 2009, Pete Zaitcev wrote:
> 
>> On Thu, 1 Jan 2009 21:34:00 -0600 (CST), kilgota at banach.math.auburn.edu 
>> wrote:
>>
>>> I successfully made a snoop log of one photo being moved over to the
>>> device. Indeed, it appears to be using Mass Storage Bulk Transport
>>> commands.
>> Try to eject the pseudo-CD on Linux, maybe the device will re-enumerate
>> itself then.
>>
>> -- Pete
>>
> 
> Well, as I mentioned earlier, the eject did not work. Therefore, I have done a 
> bit of looking through that log file. I have also gotten a copy of sg3-utils 
> and played with it a little bit.
> 
> One thing seems clear, that the device reports itself as a CD. The sectors are 
> 2048 bytes, and it uses READ_10 to read a sector, or sectors. Lots of fairly 
> routine stuff. Some selections:
> 
>      00000000: 55 53 42 43 c8 e6 95 84 08 00 00 00 80 00 0a 25
>      00000010: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
> 
> reports
> 
>      00000000: 00 01 e7 ff 00 00 08 00 (0x1e7ff sectors of size 0x800)
> 
> so I wonder if it has the off-by-one error. It would not make any difference 
> unless one were going to mount it, I suppose...
> 
> I do not know enough about this to understand the response to REQUEST_SENSE
> 
>      00000000: 55 53 42 43 88 d5 9f 84 12 00 00 00 80 00 0c 03
>      00000010: 00 00 00 12 00 00 00 00 00 00 00 00 00 00 00
> 
> which gets various responses. One of them is
> 
>      00000000: f0 00 02 00 00 00 00 0b 00 00 00 00 3a 00 00 00
>      00000010: 00 53
> 
> Windows keeps insisting on sending
> 
>      00000000: 55 53 42 43 28 3e 6e 84 20 00 00 00 80 00 0a 51
>      00000010: 00 00 00 00 00 00 00 20 00 00 00 00 00 00 00
> 
> which makes the device to throw a fit, and a reset is required. I think that 
> this has something to do with initializing RAID setup?
> 
> Now, scsi.h says the following one is READ_TOC:
> 
>      00000000: 55 53 42 43 88 2b 82 84 0c 00 00 00 80 00 0a 43
>      00000010: 00 01 00 00 00 00 00 0c 00 00 00 00 00 00 00
> 
> I do not understand what the response might be telling me, which is
> 
>      00000000: 00 0a 01 01 01 14 00 a0 00 00 00 00
> 
> though I do vaguely remember that the device claimed to have room for 45 
> images. The numbers strung out here do add up to that, which might or might not 
> be significant.
> 
> 
> Here is a sample of READ_10
> 
>      00000000: 55 53 42 43 c8 e6 95 84 00 08 00 00 80 00 0a 28
>      00000010: 00 00 00 00 19 00 00 01 00 00 00 00 00 00 00
> 
> (read one sector at 0x19)
> to which the reply begins with
> 
>      00000000: 5b 41 55 54 4f 52 55 4e 5d 0d 0a 49 43 4f 4e 3d
>                 A  u  t  o  r  u  n     i  c  o        O  P  E
>      00000010: 41 75 74 6f 72 75 6e 2e 69 63 6f 0d 0a 4f 50 45
>      00000020: 4e 3d 49 6d 61 67 65 56 69 65 77 65 72 34 2e 65
>                 x  e     -  C  O  P  Y  F  I  L  E
>      00000030: 78 65 20 2d 43 4f 50 59 46 49 4c 45 00 00 00 00
>      00000040: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
>      00000050: 00 00 00 (the rest of the sector is empty)
> 
> and then
> 
>      00000000: 55 53 42 43 08 00 5b 84 38 00 00 00 80 00 0c 12
>      00000010: 00 00 00 38 00 00 00 00 00 00 00 00 00 00 00
> 
> followed by a "reply" (my annotations, which could be partly wrong of course)
> 
> 05 means CDROM 0x80 means removable medium then 0s means scsi(?) and 02(?)
> 1f is something about extra length and then
> 
>                                         I  n  s  i  g  n  i  a
>      00000000: 05 80 02 02 1f 00 00 00 49 6e 73 69 67 6e 69 61
>                 N  S  -  D  K  U  Y  X  X  0  9
>      00000010: 4e 53 2d 44 4b 45 59 58 58 30 39 00 20 20 20 20
>                             t  e  n  x  d  s  k        E  Y  X
>      00000020: 00 20 20 20 74 65 6e 78 64 73 6b 00 00 45 59 58
>                 X  0  9
>      00000030: 58 30 39 00 20 20 20 20
> 
> 
> But then I got a bit of the way through the log file, and it came up with
> 
>      00000000: 55 53 42 43 08 00 5b 84 00 80 00 00 80 00 0c c1
>      00000010: 11 31 0f 30 01 80 00 00 00 00 00 00 00 00 00
> 
> to which the reply is a block, and then the command is repeated, apparently 
> with a different answer, then still a third time (at least).
> 
> I cannot find much information about the SCSI command 0xc1. What little I did 
> find would lead me to believe that, again, it has something to do with a CD. 
> Does anyone know where to learn more about this, or actually know the 
> information, to save the trouble of chasing it?

Just from memory (which, I must admit, is not very good) I'd say that
0xc1 is a vendor specific command. Have you had a look at the SCSI
drafts at t10.org, especially
http://www.t10.org/cgi-bin/ac.pl?t=f&f=s2-r10l.pdf ?

Abel



More information about the sane-devel mailing list