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@xxxxxxxxxx> > > --- > > 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@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- 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