[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <d9def9db0705280821w241ac9bcn36ece053969fa124@mail.gmail.com>
Date: Mon, 28 May 2007 17:21:29 +0200
From: "Markus Rechberger" <mrechberger@...il.com>
To: "Jiri Slaby" <jirislaby@...il.com>
Cc: "Andrew Morton" <akpm@...ux-foundation.org>,
linux-kernel@...r.kernel.org,
"Mauro Carvalho Chehab" <mchehab@...radead.org>,
video4linux-list@...hat.com
Subject: Re: [PATCH 1/1] V4L: stk11xx, add a new webcam driver
On 5/24/07, Jiri Slaby <jirislaby@...il.com> wrote:
> On 5/24/07, Markus Rechberger <mrechberger@...il.com> wrote:
> > Hi Jiri,
> >
> > On 5/24/07, Jiri Slaby <jirislaby@...il.com> wrote:
> > > Well, no objections on v4l list, try to merge it. Any further comments
> will
> > > be
> > > appreciated.
> > >
> > > --
> > >
> > > stk11xx, add a new webcam driver
> > >
> > > Cc: Mauro Carvalho Chehab <mchehab@...radead.org>
> > > Signed-off-by: Jiri Slaby <jirislaby@...il.com>
> > >
> [...]
> > > +/*
> > > + * Bayer conversion
> > > + */
> > > +
> > > +#define STK11XX_AVG2(x,y) (u8)(((int)x + (int)y) / 2)
> > > +#define STK11XX_AVG4(a,b,c,d) (u8)(((int)a + (int)b + (int)c + (int)d)
> / 4)
> > > +
> > > +static void stk11xx_bayer_to_rgb(u8 *rgb, const u8 *bayer,
> > > + const int width, const int height)
> >
> > hmm.. this is probably to support xawtv/tvtime?
> > It would be better to do that in userspace, but the argument which
> > seems to be against it is that userspace applications often don't
> > support bayer.
>
> Exactly. This would make the webcam driver unusable. Another one,
> which awaits RGB is camstream, which also I use. After moving all
> major used userspace apps to something like pwlib, this may be wiped
> out.
>
> > > +{
> > > + unsigned int x, y, nwidth, nheight;
> > > +
> > > + nheight = height / factor;
> > > + nwidth = width / factor;
> > > +
> > > + for (y = 0; y < nheight; y++) {
> > > + for (x = 0; x < nwidth; x++) {
> > > + /* R */
> > > + out[y * nwidth * 3 + x * 3 + 0] =
> > > + in[y * factor * width * 3 + x * factor * 3 +
> 0];
> > > + /* G */
> > > + out[y * nwidth * 3 + x * 3 + 1] =
> > > + in[y * factor * width * 3 + x * factor * 3 +
> 1];
> > > + /* B */
> > > + out[y * nwidth * 3 + x * 3 + 2] =
> > > + in[y * factor * width * 3 + x * factor * 3 +
> 2];
> > > + }
> > > + }
> > > +}
> > > +
> > > +static void stk11xx_correct_brightness(u8 *rgb, unsigned int width,
> > > + unsigned int height, int brightness)
> > > +{
> >
> > same here, why do you want to have that in kernelspace?
>
> not sure who from userspace can do this nowadays. Will check.
>
> > > +/*
> > > + * The configuration of device is composed of 12 steps.
> > > + * This function is called by the initialization process.
> > > + *
> > > + * We don't know the meaning of these steps! We only replay the USB
> log.
> > > + */
> > > +static int stk1135_configure_device(struct stk11xx *dev, int step)
> > > +{
> > > + int value;
> > > +
> > > + /* 0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
> > > + 10, 11, 12, 13 */
> > > +
> > > + const u8 values_001B[] = {
> > > + 0x0E, 0x03, 0x0E, 0x0E, 0x0E, 0x0E, 0x0E, 0x0E, 0x0E,
> 0x07,
> > > + 0x07, 0x07, 0x07, 0x07
> > > + };
> > > + const u8 values_001C[] = {
> > > + 0x06, 0x02, 0x46, 0x46, 0x46, 0x46, 0x46, 0x46, 0x06,
> 0x06,
> > > + 0x06, 0x06, 0x06, 0x07
> > > + };
> > > + const u8 values_0202[] = {
> > > + 0x1E, 0x0A, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E, 0x1E,
> 0x1E,
> > > + 0x1E, 0x1E, 0x1E, 0x1E
> > > + };
> > > + const u8 values_0110[] = {
> > > + 0x07, 0x00, 0x00, 0x00, 0x00, 0x3E, 0x3E, 0x00, 0x04,
> 0x00,
> > > + 0x00, 0x00, 0x00, 0x00
> > > + };
> > > + const u8 values_0112[] = {
> > > + 0x07, 0x00, 0x00, 0x00, 0x00, 0x09, 0x09, 0x00, 0x04,
> 0x00,
> > > + 0x00, 0x00, 0x00, 0x00
> > > + };
> > > + const u8 values_0114[] = {
> > > + 0x87, 0x80, 0x80, 0x80, 0x80, 0xBE, 0xBE, 0x80, 0x84,
> 0x80,
> > > + 0x80, 0x80, 0x80, 0x80
> > > + };
> > > + const u8 values_0116[] = {
> > > + 0xE7, 0xE0, 0xE0, 0xE0, 0xE0, 0xE9, 0xE9, 0xE0, 0xE4,
> 0xE0,
> > > + 0xE0, 0xE0, 0xE0, 0xE0
> > > + };
> > > + const u8 values_0100[] = {
> > > + 0x20, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x21, 0x23,
> 0x20,
> > > + 0x20, 0x20, 0x20, 0x20
> > > + };
> > > +
> > > + dev_dbg(&dev->udev->dev, "stk1135_configure_device: %d\n", step);
> > > +
> > > + stk11xx_write_registry(dev, 0x0000, 0x0024);
> > > + stk11xx_write_registry(dev, 0x0002, 0x0068);
> > > + stk11xx_write_registry(dev, 0x0003, 0x0080);
> > > + stk11xx_write_registry(dev, 0x0005, 0x0000);
> > > +
> > > + stk11xx_write_registry(dev, 0x0007, 0x0003);
> > > + stk11xx_write_registry(dev, 0x000d, 0x0000);
> > > + stk11xx_write_registry(dev, 0x000f, 0x0002);
> > > + stk11xx_write_registry(dev, 0x0300, 0x0012);
> > > + stk11xx_write_registry(dev, 0x0350, 0x0041);
> > > +
> > > + stk11xx_write_registry(dev, 0x0351, 0x0000);
> > > + stk11xx_write_registry(dev, 0x0352, 0x0000);
> > > + stk11xx_write_registry(dev, 0x0353, 0x0000);
> > > + stk11xx_write_registry(dev, 0x0018, 0x0010);
> > > + stk11xx_write_registry(dev, 0x0019, 0x0000);
> > > +
> > > + stk11xx_write_registry(dev, 0x001b, values_001B[step]);
> > > + stk11xx_write_registry(dev, 0x001c, values_001C[step]);
> > > + stk11xx_write_registry(dev, 0x0300, 0x0080);
> > > + stk11xx_write_registry(dev, 0x001a, 0x0004);
> > > + stk11xx_write_registry(dev, 0x0202, values_0202[step]);
> > > +
> > > + stk11xx_write_registry(dev, 0x0110, values_0110[step]);
> > > + stk11xx_write_registry(dev, 0x0111, 0x0000);
> > > + stk11xx_write_registry(dev, 0x0112, values_0112[step]);
> > > + stk11xx_write_registry(dev, 0x0113, 0x0000);
> > > + stk11xx_write_registry(dev, 0x0114, values_0114[step]);
> > > +
> >
> > if possible some error checking would be nice here, if you unplug the
> > device you'll rely on the underlying subsystem to handle your errors I
> > don't think that's a good way to go.
> > Did you test unplugging your device while it's in use with
> mplayer/xawtv/..?
>
> hmm, no. It's physically impossible -- it's built in. Is there any
> possibility of sw unplugging, e.g. writing something somewhere to
> /proc or /sys?
>
You can use the unbind option of the usb framework to disconnect the
driver while it's in use.
Your device driver should be listed in /sys/bus/usb/drivers, change
the directory into your driver's directory and list the files which
are in it.
It should show up a numeric symlink (like 4-1:1.0) which is linked to
the corresponding usb device, you can unbind it by echo'ing that name
into unbind eg.
$ echo -n 4-1:1.0 > unbind
Markus
> thanks,
> --
> http://www.fi.muni.cz/~xslaby/ Jiri Slaby
> faculty of informatics, masaryk university, brno, cz
> e-mail: jirislaby gmail com, gpg pubkey fingerprint:
> B674 9967 0407 CE62 ACC8 22A0 32CC 55C3 39D4 7A7E
>
--
Markus Rechberger
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists