/*
* setting PAL mode
*/
static void davinci_enc_set_pal(struct vid_enc_mode_info *mode_info)
{
enableDigitalOutput(0);
if (cpu_is_davinci_dm355()) {
dispc_reg_out(VENC_CLKCTL, 0x1);
dispc_reg_out(VENC_VIDCTL, 0);
/* DM350 Configure VDAC_CONFIG */
__raw_writel(0x0E21A6B6, IO_ADDRESS(DM3XX_VDAC_CONFIG));
} else if (cpu_is_davinci_dm365()) {
dispc_reg_out(VENC_VMOD,0x1043);//gjx 1:YCC8; 0: ;4:PAL; 3:Composite output enable.Video encoder enable.
dispc_reg_out(VENC_CLKCTL, 0x11); //gjx enable digital lcd clock;orignal:0x1
dispc_reg_out(VENC_VIDCTL, 0x6000); //gjx vclk pin output enable & vclk polarity inverse(6000)
dispc_reg_out(VENC_YCCCTL, 0x1); //gjx bt656
/* Set OSD clock and OSD Sync Adavance registers */
dispc_reg_out(VENC_OSDCLK0, 1); //gjx
dispc_reg_out(VENC_OSDCLK1, 2); //gjx
dispc_reg_out(VENC_VDPRO, 0x20);//XJX
__raw_writel(0x081141CF, IO_ADDRESS(DM3XX_VDAC_CONFIG));
} else {
/* to set VENC CLK DIV to 1 - final clock is 54 MHz */
dispc_reg_merge(VENC_VIDCTL, 0, 1 << 1);
/* Set REC656 Mode */
dispc_reg_out(VENC_YCCCTL, 0x1);
}
dispc_reg_merge(VENC_SYNCCTL, 1 << VENC_SYNCCTL_OVD_SHIFT,
VENC_SYNCCTL_OVD);
osd_write_left_margin(mode_info->left_margin);
/* PAL display shows shakiness in the OSD0 when
* this is set to upper margin. Need to bump it
* by 2 in the case of DM365
*/
if (cpu_is_davinci_dm365())
osd_write_upper_margin(mode_info->upper_margin + 2);
else
osd_write_upper_margin(mode_info->upper_margin);
dispc_reg_merge(VENC_VMOD, VENC_VMOD_VENC, VENC_VMOD_VENC);
dispc_reg_out(VENC_DACTST, 0x0);
}