[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20130608171309.GA10180@dell.arpanet.local>
Date: Sat, 8 Jun 2013 19:13:09 +0200
From: Jon Arne Jørgensen <jonarne@...arne.no>
To: Hans Verkuil <hverkuil@...all.nl>
Cc: Jon Arne Jørgensen <jonarne@...arne.no>,
linux-media@...r.kernel.org, linux-kernel@...r.kernel.org,
mchehab@...hat.com, hans.verkuil@...co.com,
prabhakar.csengg@...il.com, g.liakhovetski@....de,
ezequiel.garcia@...e-electrons.com, timo.teras@....fi
Subject: Re: [RFC v2 2/2] saa7115: Remove gm7113c video_std register change
On Fri, Jun 07, 2013 at 11:01:06AM +0200, Hans Verkuil wrote:
> On Fri May 31 2013 13:40:26 Jon Arne Jørgensen wrote:
> > On video std change, the driver would disable the automatic field
> > detection on the gm7113c chip, and force either 50Hz or 60Hz.
> > Don't do this any more.
>
> Sorry, I'm not entirely sure what is happening here. Why would the gm7113c
> behave different in this respect compared to the saa7113?
>
> One thing to remember is that the chip should never get in a mode where
> switching from e.g. NTSC to PAL on the input would change the output timings
> to the bridge chip as well to PAL. Because that might cause DMA buffer
> overruns. So if the user calls S_STD, then the bridge should always be
> certain it gets whatever std was specified.
>
> I'm not sure whether this patch puts the gm7113c in such a mode, but if it
> does, then it should be redone.
>
> Regards,
>
> Hans
>
Ah, you are of course right.
The Somagic EasyCap which I use for testing is basicaly just forwarding the raw
data from the gm7113c chip as isochronous usb transfers to the computer.
Because of this I have to do lots of checks on the incomming data and
local buffers in the smi2021 driver.
I totaly forgot that the chip could be used in other configurations
where you would use DMA transfers. Then the forcing of the video std suddenly
makes sense. I guess I have to drop this part from the next version of
the patch.
Thank you for the review.
Best regards,
Jon Arne Jørgensen
> >
> > Signed-off-by: Jon Arne Jørgensen <jonarne@...arne.no>
> > ---
> > drivers/media/i2c/saa7115.c | 26 ++------------------------
> > 1 file changed, 2 insertions(+), 24 deletions(-)
> >
> > diff --git a/drivers/media/i2c/saa7115.c b/drivers/media/i2c/saa7115.c
> > index 4a52b4d..ba18e57 100644
> > --- a/drivers/media/i2c/saa7115.c
> > +++ b/drivers/media/i2c/saa7115.c
> > @@ -479,24 +479,6 @@ static const unsigned char saa7115_cfg_50hz_video[] = {
> >
> > /* ============== SAA7715 VIDEO templates (end) ======= */
> >
> > -/* ============== GM7113C VIDEO templates ============= */
> > -static const unsigned char gm7113c_cfg_60hz_video[] = {
> > - R_08_SYNC_CNTL, 0x68, /* 0xBO: auto detection, 0x68 = NTSC */
> > - R_0E_CHROMA_CNTL_1, 0x07, /* video autodetection is on */
> > -
> > - 0x00, 0x00
> > -};
> > -
> > -static const unsigned char gm7113c_cfg_50hz_video[] = {
> > - R_08_SYNC_CNTL, 0x28, /* 0x28 = PAL */
> > - R_0E_CHROMA_CNTL_1, 0x07,
> > -
> > - 0x00, 0x00
> > -};
> > -
> > -/* ============== GM7113C VIDEO templates (end) ======= */
> > -
> > -
> > static const unsigned char saa7115_cfg_vbi_on[] = {
> > R_80_GLOBAL_CNTL_1, 0x00, /* reset tasks */
> > R_88_POWER_SAVE_ADC_PORT_CNTL, 0xd0, /* reset scaler */
> > @@ -981,16 +963,12 @@ static void saa711x_set_v4lstd(struct v4l2_subdev *sd, v4l2_std_id std)
> > // This works for NTSC-M, SECAM-L and the 50Hz PAL variants.
> > if (std & V4L2_STD_525_60) {
> > v4l2_dbg(1, debug, sd, "decoder set standard 60 Hz\n");
> > - if (state->ident == V4L2_IDENT_GM7113C)
> > - saa711x_writeregs(sd, gm7113c_cfg_60hz_video);
> > - else
> > + if (state->ident != V4L2_IDENT_GM7113C)
> > saa711x_writeregs(sd, saa7115_cfg_60hz_video);
> > saa711x_set_size(sd, 720, 480);
> > } else {
> > v4l2_dbg(1, debug, sd, "decoder set standard 50 Hz\n");
> > - if (state->ident == V4L2_IDENT_GM7113C)
> > - saa711x_writeregs(sd, gm7113c_cfg_50hz_video);
> > - else
> > + if (state->ident != V4L2_IDENT_GM7113C)
> > saa711x_writeregs(sd, saa7115_cfg_50hz_video);
> > saa711x_set_size(sd, 720, 576);
> > }
> >
> --
> To unsubscribe from this list: send the line "unsubscribe linux-media" in
> the body of a message to majordomo@...r.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
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