On Fri, 19 Jun 2009, Andy Walls wrote:
On Fri, 2009-06-19 at 19:26 -0500, Theodore Kilgore wrote:
On Fri, 19 Jun 2009, Andy Walls wrote:
On Fri, 2009-06-19 at 12:47 -0500, Theodore Kilgore wrote:
On Fri, 19 Jun 2009, Andy Walls wrote:
On Thu, 2009-06-18 at 21:43 -0500, Theodore Kilgore wrote:
On Thu, 18 Jun 2009, Andy Walls wrote:
Interesting. To answer your question, I have no idea off the top of my
head. I do have what seems to be a similar camera. It is
Bus 005 Device 006: ID 0979:0371 Jeilin Technology Corp., Ltd
and the rest of the lsusb output looks quite similar. I do not know,
though, if it has any chance of working as a webcam. Somehow, the thought
never occurred to me back when I got the thing. I would have to hunt some
stuff down even to know if it is claimed to work as a webcam.
The packaging that mine came in claims "3-in-1":
digital video camcorder (with microphone)
digital camera
web cam
You did say that it comes up as a different USB device when it is a
webcam? You mean, a different product ID or so?
Yes
Look for this in the original lsusb output I provided
:
Webcam mode:
Bus 003 Device 005: ID 0979:0280 Jeilin Technology Corp., Ltd
Device Descriptor:
Oops, right you are. Blame it on my old eyes. They are the same age as the
rest of me, but sometimes they feel older.
And the upshot is that we may have the same camera, at least as a webcam,
perhaps with a different name. I finally made mine to work in webcam mode.
On mine, one has to press down a button labelled "DV" at the same time as
pressing down the button with the picture of a camera beside it, to turn
on the webcam mode. As opposed to just pressing the "camera" button to
turn on the camera to shoot a picture.
Ah, very nice. The secret handshake that only the manual (usually lost)
can tell you.
There is no longer any manual out there on the web. I looked.
OK. I have two steps to take:
1. Installing the driver and software on my sole remaining Windows
machine. It already has snoopy.
2. Getting the camera away from my daughter for more than 2 minutes.
It's like the thing is glued to her hand. :)
I hope that you can still manage to do these things. I did get a snoop log
of my own, but it would be nice to have some confirmation, too, that the
cameras really are acting the same way. That may look like a stupid thing
to say until one realizes that things which have the same USB
Vendor:Product number do _not_ necessarily act the same way.
Yes. I might need a little time. This weekend is Father's day, and I
got to go see family tomorrow and will be hosting more family on
Saturday evening and Sunday. I doubt I'll have time to look at this
before Sunday night (and by then I suspect I'll be drinking beer. :))
I did let gThumb import some files from my daughter's camera (Ireally
should have pulled them over myself from the "mass storage drive").
Easily done. No problem with that at all.
Here's how they ended up:
$ file *
00001.jpg: JPEG image data, EXIF standard 2.2
00002.jpg: JPEG image data, EXIF standard 2.2
00003.jpg: JPEG image data, EXIF standard 2.2
00004.avi: RIFF (little-endian) data, AVI, 320 x 240, 20.00 fps, video: Motion JPEG, audio: uncompressed PCM (mono, 8000 Hz)
00005.jpg: JPEG image data, EXIF standard 2.2
00006.jpg: JPEG image data, EXIF standard 2.2
00007.jpg: JPEG image data, EXIF standard 2.2
00008.jpg: JPEG image data, EXIF standard 2.2
00009.jpg: JPEG image data, EXIF standard 2.2
00010.jpg: JPEG image data, EXIF standard 2.2
All the photos were JPEGs and the movie was playable. Totem/gstreamer
did a much better job of playing back the audio in the movie than
mplayer. Surprising to me, but 8 ksps mono is just awful anyway.
Yes. The camera works perfectly in stilcam mode, as a mass storage device.
Just mount it and treat it like a thumb drive. I tried the sound today,
too, and the sound file is a .wav file. As far as my cam is concerned, I
already knew all of this, but the camera has been gathering dust since
2005. Oh, it is convenient to take on a trip. So that has happened a
couple of times. But otherwise it was not a very interesting camera. There
is no challenge in a mass storage camera so I more or less forgot about
it.
Well, here are some of the things I learned:
As a stillcam, it is confirmed that my cam is a standard mass storage
device, transparent SCSI, bulk. It uses outep 0x01 and inep 0x82 (the
first pair of endpoints).
As I said, I was aware of this but did not remember the details, so this
was all double-checking in order to clear up foggy memories.
Here it is as a mass storage device.
T: Bus=05 Lev=01 Prnt=01 Port=01 Cnt=01 Dev#= 2 Spd=12 MxCh= 0
D: Ver= 1.10 Cls=00(>ifc ) Sub=00 Prot=00 MxPS= 8 #Cfgs= 1
P: Vendor=0979 ProdID=0371 Rev= 1.00
S: Manufacturer=Jeilin
S: Product=USB 1.1 Device
S: SerialNumber=09790
^^^^^
So much for a unique serial number. I haven't checked mine yet, but I
bet it's the same.
Well, lots of devices leave the serial number blank. And sometimes one
even encounters an (otherwise standard) mass storage device for which the
Vendor and Product numbers have been left blank, too! Lots of weird stuff
goes on. Be surprised at nothing.
C:* #Ifs= 1 Cfg#= 1 Atr=80 MxPwr=500mA
I:* If#= 0 Alt= 0 #EPs= 4 Cls=08(stor.) Sub=06 Prot=50 Driver=usb-storage
E: Ad=01(O) Atr=02(Bulk) MxPS= 64 Ivl=0ms
E: Ad=82(I) Atr=02(Bulk) MxPS= 64 Ivl=0ms
E: Ad=03(O) Atr=02(Bulk) MxPS= 8 Ivl=0ms
E: Ad=84(I) Atr=02(Bulk) MxPS= 8 Ivl=0ms
and here it is as a webcam.
T: Bus=05 Lev=01 Prnt=01 Port=01 Cnt=01 Dev#= 16 Spd=12 MxCh= 0
D: Ver= 1.10 Cls=00(>ifc ) Sub=00 Prot=00 MxPS= 8 #Cfgs= 1
P: Vendor=0979 ProdID=0280 Rev= 1.00
S: Manufacturer=Jeilin
S: Product=USB 1.1 Device
C:* #Ifs= 1 Cfg#= 1 Atr=80 MxPwr=500mA
I:* If#= 0 Alt= 0 #EPs= 4 Cls=00(>ifc ) Sub=00 Prot=00 Driver=(none)
E: Ad=01(O) Atr=02(Bulk) MxPS= 64 Ivl=0ms
E: Ad=82(I) Atr=02(Bulk) MxPS= 64 Ivl=0ms
E: Ad=03(O) Atr=02(Bulk) MxPS= 8 Ivl=0ms
E: Ad=84(I) Atr=02(Bulk) MxPS= 8 Ivl=0ms
Now it is using the other pair of endpoints, 0x03 and 0x84.
Hmmmm. I wonder if we can use them anyway, without being connected in
"webcam" mode.
Nope. That was the previously mentioned bug in the Linux mass storage
driver. Namely the spec calls for using the first pair of endpoints
encountered. The bug consisted of the mass storage driver looking for the
last pair of endpoints encountered, instead. This was back around kernel
2.6.18 or so when the problem got fixed.
The second pair of endpoints appears to be very much disconnected in mass
storage mode. The attempt to use them will result only in a string of
error messages. How well I remember. As to whether the first pair can be
used in webcam mode, I clearly have not tried to use them, but I would
have strong doubts whether it is even worth trying. Even if they would
work, what on earth would they be good for?
There is a sequence of init commands
00000000: 71 81
00000000: 70 05
00000000: 95 70
00000000: 00 (all the 00 are responses)
00000000: 71 81
00000000: 70 04
00000000: 95 70
00000000: 00
00000000: 71 00
00000000: 70 08
00000000: 95 70
00000000: 00
00000000: 94 02
00000000: de 24
00000000: 94 02
00000000: dd f0
00000000: 94 02
00000000: e3 2c
00000000: 94 02
00000000: e4 00
00000000: 94 02
00000000: e5 00
00000000: e5 00
00000000: 94 02
00000000: e6 2c
00000000: 94 03
00000000: aa 00
00000000: 71 1e
00000000: 70 06
00000000: 71 80
00000000: 70 07
and then it starts to stream. The stream downloads 0x200 (512) bytes at a
time. It appears that there is an SOF marker consisting of
ff ff ff ff
followed by at least two zeroes. These seem to occur only at the
beginnings of some of the downloaded 0x200-sized blocks.
Given that the AVI file is 320x240 @ 20 fps Motion JPEG, maybe the
streaming mode uses something similar.
Assuming 6 bit RGB values at 320x240 @ 20 fps:
(320*240) * 24 bpp * 20 fps = 36.864 Mbps
Since this USB 1.1, I'm guessing the stream has to be compressed.
Sure looks that way. I took a closer look at the lines starting with ff ff
ff ff strings, and I found a couple more things. Here are several lines
from an extract from that snoop, consisting of what appear to be
consecutive SOF lines.
00000000: ff ff ff ff 00 00 1c 70 3c 00 0f 01 00 00 00 00
00000000: ff ff ff ff 00 00 34 59 1e 00 1b 06 00 00 00 00
00000000: ff ff ff ff 00 00 36 89 1e 00 1c 07 00 00 00 00
00000000: ff ff ff ff 00 00 35 fc 1e 00 1b 08 00 00 00 00
00000000: ff ff ff ff 00 00 35 84 1e 00 1b 09 00 00 00 00
The last non-zero byte is a frame counter. Presumably, the gap between the
01 and the 06 occurs because the camera was just then starting up and
things were a bit chaotic. The rest of the lines in the file are
completely consistent, counting consecutively from 09 to 49 (hex, of
course) at which point I killed the stream.
The byte previous to that one (reading downwards 0f 1b 1c 1b 1b ...) gives
the number of 0x200-byte blocks in that frame, before the next marker
comes along. So if we start from the frame labeled "06" then from there on
the frames are approximately the same size, but not identical. For example
the size of frame 06 is 0x1b*0x200. That is, 27*512 bytes.
I am not sure what the other numbers mean. Perhaps you have better guesses
than I do.
There is a closing sequence at the end which is similar to the init
sequence
00000000: 71 00
00000000: 70 09
00000000: 71 80
00000000: 70 05
It would be interesting to see your log file and to compare. I could also
send you this one if you are curious, but it is 5,760,902 bytes so I
should ask that if you want to see it then how to send it? Me, I suspect
that if you have one of similar size and bz2 it and send it to me as an
attachment, then it is not any problem.
You could send it to me via email (my ISP bounces *really* big incoming
emails but at least 6 MB email can make it through). However, without
the "source" of the image, it might be a little hard to decode the dump.
I was not pointing the camera at anything in particular. Unless perhaps at
the laptop screen? Not sure.
I was going to get a stream of:
1) a white sheet of paper
2) a blue sheet of paper
3) a red sheet of paper
4) a green sheet of paper
5) a black sheet of paper
6) a half-white, half black target with the regions separated vertically
7) a half-white, half black target with the regions separated diagonally
and maybe some other test patterns. There's no shortage of construction
paper, crayons, and colored markers in my house.
These are all good. Also I have found out it is sometimes helpful to point
a camera at a monitor screen, once I have learned to make raw files, and
to do things like xsetroot -solid c0/00/00 and then repeat for 00/c0/00
and again for 00/00/c0. and then take a picture of a "flag" by leaving a
white xterm sticking out into the picture in one corner.
Now, having found an excuse not to finish grading those papers today, I
will probably have to pay more concentrated attention to grading and
travel planning tomorrow. But do send the log along anyway if you can get
it done.
The most interesting tasks are the ones we're not required to do. :)
Very true. Mark Twain said that work is what we have to do and anything
we don't have to do is play.
I probably can't send logs until Monday, but I will when I get the
chance.
OK.
Theodore Kilgore
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html