Commit 0dd8be8c authored by Olimpiu Pascariu's avatar Olimpiu Pascariu Committed by Mauro Carvalho Chehab

V4L/DVB: cx25821: fix coding style issues in cx25821-medusa-video.c

Fixes up warnings and errors found by the checkpatch.pl tool on
cx25821-medusa-video.c
Signed-off-by: default avatarOlimpiu Pascariu <olimpiu.pascariu@gmail.com>
Acked-by: default avatarDan Carpenter <error27@gmail.com>
Cc: Palash Bandyopadhyay <palash.bandyopadhyay@conexant.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 1c614239
...@@ -24,11 +24,12 @@ ...@@ -24,11 +24,12 @@
#include "cx25821-medusa-video.h" #include "cx25821-medusa-video.h"
#include "cx25821-biffuncs.h" #include "cx25821-biffuncs.h"
///////////////////////////////////////////////////////////////////////////////////////// /*
//medusa_enable_bluefield_output() * medusa_enable_bluefield_output()
// *
// Enable the generation of blue filed output if no video * Enable the generation of blue filed output if no video
// *
*/
static void medusa_enable_bluefield_output(struct cx25821_dev *dev, int channel, static void medusa_enable_bluefield_output(struct cx25821_dev *dev, int channel,
int enable) int enable)
{ {
...@@ -73,15 +74,15 @@ static void medusa_enable_bluefield_output(struct cx25821_dev *dev, int channel, ...@@ -73,15 +74,15 @@ static void medusa_enable_bluefield_output(struct cx25821_dev *dev, int channel,
} }
value = cx25821_i2c_read(&dev->i2c_bus[0], out_ctrl, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], out_ctrl, &tmp);
value &= 0xFFFFFF7F; // clear BLUE_FIELD_EN value &= 0xFFFFFF7F; /* clear BLUE_FIELD_EN */
if (enable) if (enable)
value |= 0x00000080; // set BLUE_FIELD_EN value |= 0x00000080; /* set BLUE_FIELD_EN */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], out_ctrl, value); ret_val = cx25821_i2c_write(&dev->i2c_bus[0], out_ctrl, value);
value = cx25821_i2c_read(&dev->i2c_bus[0], out_ctrl_ns, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], out_ctrl_ns, &tmp);
value &= 0xFFFFFF7F; value &= 0xFFFFFF7F;
if (enable) if (enable)
value |= 0x00000080; // set BLUE_FIELD_EN value |= 0x00000080; /* set BLUE_FIELD_EN */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], out_ctrl_ns, value); ret_val = cx25821_i2c_write(&dev->i2c_bus[0], out_ctrl_ns, value);
} }
...@@ -95,17 +96,18 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev) ...@@ -95,17 +96,18 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev)
mutex_lock(&dev->lock); mutex_lock(&dev->lock);
for (i = 0; i < MAX_DECODERS; i++) { for (i = 0; i < MAX_DECODERS; i++) {
// set video format NTSC-M /* set video format NTSC-M */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], MODE_CTRL + (0x200 * i), cx25821_i2c_read(&dev->i2c_bus[0], MODE_CTRL + (0x200 * i),
&tmp); &tmp);
value &= 0xFFFFFFF0; value &= 0xFFFFFFF0;
value |= 0x10001; // enable the fast locking mode bit[16] /* enable the fast locking mode bit[16] */
value |= 0x10001;
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], MODE_CTRL + (0x200 * i), cx25821_i2c_write(&dev->i2c_bus[0], MODE_CTRL + (0x200 * i),
value); value);
// resolution NTSC 720x480 /* resolution NTSC 720x480 */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
HORIZ_TIM_CTRL + (0x200 * i), &tmp); HORIZ_TIM_CTRL + (0x200 * i), &tmp);
...@@ -119,17 +121,17 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev) ...@@ -119,17 +121,17 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev)
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
VERT_TIM_CTRL + (0x200 * i), &tmp); VERT_TIM_CTRL + (0x200 * i), &tmp);
value &= 0x00C00C00; value &= 0x00C00C00;
value |= 0x1C1E001A; // vblank_cnt + 2 to get camera ID value |= 0x1C1E001A; /* vblank_cnt + 2 to get camera ID */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
VERT_TIM_CTRL + (0x200 * i), value); VERT_TIM_CTRL + (0x200 * i), value);
// chroma subcarrier step size /* chroma subcarrier step size */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
SC_STEP_SIZE + (0x200 * i), 0x43E00000); SC_STEP_SIZE + (0x200 * i), 0x43E00000);
// enable VIP optional active /* enable VIP optional active */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
OUT_CTRL_NS + (0x200 * i), &tmp); OUT_CTRL_NS + (0x200 * i), &tmp);
...@@ -139,7 +141,7 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev) ...@@ -139,7 +141,7 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
OUT_CTRL_NS + (0x200 * i), value); OUT_CTRL_NS + (0x200 * i), value);
// enable VIP optional active (VIP_OPT_AL) for direct output. /* enable VIP optional active (VIP_OPT_AL) for direct output. */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], OUT_CTRL1 + (0x200 * i), cx25821_i2c_read(&dev->i2c_bus[0], OUT_CTRL1 + (0x200 * i),
&tmp); &tmp);
...@@ -149,19 +151,21 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev) ...@@ -149,19 +151,21 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], OUT_CTRL1 + (0x200 * i), cx25821_i2c_write(&dev->i2c_bus[0], OUT_CTRL1 + (0x200 * i),
value); value);
// clear VPRES_VERT_EN bit, fixes the chroma run away problem /*
// when the input switching rate < 16 fields * clear VPRES_VERT_EN bit, fixes the chroma run away problem
// * when the input switching rate < 16 fields
*/
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
MISC_TIM_CTRL + (0x200 * i), &tmp); MISC_TIM_CTRL + (0x200 * i), &tmp);
value = setBitAtPos(value, 14); // disable special play detection /* disable special play detection */
value = setBitAtPos(value, 14);
value = clearBitAtPos(value, 15); value = clearBitAtPos(value, 15);
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
MISC_TIM_CTRL + (0x200 * i), value); MISC_TIM_CTRL + (0x200 * i), value);
// set vbi_gate_en to 0 /* set vbi_gate_en to 0 */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], DFE_CTRL1 + (0x200 * i), cx25821_i2c_read(&dev->i2c_bus[0], DFE_CTRL1 + (0x200 * i),
&tmp); &tmp);
...@@ -170,12 +174,12 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev) ...@@ -170,12 +174,12 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], DFE_CTRL1 + (0x200 * i), cx25821_i2c_write(&dev->i2c_bus[0], DFE_CTRL1 + (0x200 * i),
value); value);
// Enable the generation of blue field output if no video /* Enable the generation of blue field output if no video */
medusa_enable_bluefield_output(dev, i, 1); medusa_enable_bluefield_output(dev, i, 1);
} }
for (i = 0; i < MAX_ENCODERS; i++) { for (i = 0; i < MAX_ENCODERS; i++) {
// NTSC hclock /* NTSC hclock */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
DENC_A_REG_1 + (0x100 * i), &tmp); DENC_A_REG_1 + (0x100 * i), &tmp);
...@@ -185,7 +189,7 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev) ...@@ -185,7 +189,7 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_1 + (0x100 * i), value); DENC_A_REG_1 + (0x100 * i), value);
// burst begin and burst end /* burst begin and burst end */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
DENC_A_REG_2 + (0x100 * i), &tmp); DENC_A_REG_2 + (0x100 * i), &tmp);
...@@ -204,7 +208,7 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev) ...@@ -204,7 +208,7 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_3 + (0x100 * i), value); DENC_A_REG_3 + (0x100 * i), value);
// set NTSC vblank, no phase alternation, 7.5 IRE pedestal /* set NTSC vblank, no phase alternation, 7.5 IRE pedestal */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
DENC_A_REG_4 + (0x100 * i), &tmp); DENC_A_REG_4 + (0x100 * i), &tmp);
...@@ -227,17 +231,19 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev) ...@@ -227,17 +231,19 @@ static int medusa_initialize_ntsc(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_6 + (0x100 * i), 0x009A89C1); DENC_A_REG_6 + (0x100 * i), 0x009A89C1);
// Subcarrier Increment /* Subcarrier Increment */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_7 + (0x100 * i), 0x21F07C1F); DENC_A_REG_7 + (0x100 * i), 0x21F07C1F);
} }
//set picture resolutions /* set picture resolutions */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], HSCALE_CTRL, 0x0); //0 - 720 /* 0 - 720 */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], VSCALE_CTRL, 0x0); //0 - 480 ret_val = cx25821_i2c_write(&dev->i2c_bus[0], HSCALE_CTRL, 0x0);
/* 0 - 480 */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], VSCALE_CTRL, 0x0);
// set Bypass input format to NTSC 525 lines /* set Bypass input format to NTSC 525 lines */
value = cx25821_i2c_read(&dev->i2c_bus[0], BYP_AB_CTRL, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], BYP_AB_CTRL, &tmp);
value |= 0x00080200; value |= 0x00080200;
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], BYP_AB_CTRL, value); ret_val = cx25821_i2c_write(&dev->i2c_bus[0], BYP_AB_CTRL, value);
...@@ -252,7 +258,7 @@ static int medusa_PALCombInit(struct cx25821_dev *dev, int dec) ...@@ -252,7 +258,7 @@ static int medusa_PALCombInit(struct cx25821_dev *dev, int dec)
int ret_val = -1; int ret_val = -1;
u32 value = 0, tmp = 0; u32 value = 0, tmp = 0;
// Setup for 2D threshold /* Setup for 2D threshold */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], COMB_2D_HFS_CFG + (0x200 * dec), cx25821_i2c_write(&dev->i2c_bus[0], COMB_2D_HFS_CFG + (0x200 * dec),
0x20002861); 0x20002861);
...@@ -263,7 +269,7 @@ static int medusa_PALCombInit(struct cx25821_dev *dev, int dec) ...@@ -263,7 +269,7 @@ static int medusa_PALCombInit(struct cx25821_dev *dev, int dec)
cx25821_i2c_write(&dev->i2c_bus[0], COMB_2D_LF_CFG + (0x200 * dec), cx25821_i2c_write(&dev->i2c_bus[0], COMB_2D_LF_CFG + (0x200 * dec),
0x200A1023); 0x200A1023);
// Setup flat chroma and luma thresholds /* Setup flat chroma and luma thresholds */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
COMB_FLAT_THRESH_CTRL + (0x200 * dec), &tmp); COMB_FLAT_THRESH_CTRL + (0x200 * dec), &tmp);
...@@ -272,12 +278,12 @@ static int medusa_PALCombInit(struct cx25821_dev *dev, int dec) ...@@ -272,12 +278,12 @@ static int medusa_PALCombInit(struct cx25821_dev *dev, int dec)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
COMB_FLAT_THRESH_CTRL + (0x200 * dec), value); COMB_FLAT_THRESH_CTRL + (0x200 * dec), value);
// set comb 2D blend /* set comb 2D blend */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], COMB_2D_BLEND + (0x200 * dec), cx25821_i2c_write(&dev->i2c_bus[0], COMB_2D_BLEND + (0x200 * dec),
0x210F0F0F); 0x210F0F0F);
// COMB MISC CONTROL /* COMB MISC CONTROL */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], COMB_MISC_CTRL + (0x200 * dec), cx25821_i2c_write(&dev->i2c_bus[0], COMB_MISC_CTRL + (0x200 * dec),
0x41120A7F); 0x41120A7F);
...@@ -295,17 +301,18 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -295,17 +301,18 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
mutex_lock(&dev->lock); mutex_lock(&dev->lock);
for (i = 0; i < MAX_DECODERS; i++) { for (i = 0; i < MAX_DECODERS; i++) {
// set video format PAL-BDGHI /* set video format PAL-BDGHI */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], MODE_CTRL + (0x200 * i), cx25821_i2c_read(&dev->i2c_bus[0], MODE_CTRL + (0x200 * i),
&tmp); &tmp);
value &= 0xFFFFFFF0; value &= 0xFFFFFFF0;
value |= 0x10004; // enable the fast locking mode bit[16] /* enable the fast locking mode bit[16] */
value |= 0x10004;
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], MODE_CTRL + (0x200 * i), cx25821_i2c_write(&dev->i2c_bus[0], MODE_CTRL + (0x200 * i),
value); value);
// resolution PAL 720x576 /* resolution PAL 720x576 */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
HORIZ_TIM_CTRL + (0x200 * i), &tmp); HORIZ_TIM_CTRL + (0x200 * i), &tmp);
...@@ -315,22 +322,22 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -315,22 +322,22 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
HORIZ_TIM_CTRL + (0x200 * i), value); HORIZ_TIM_CTRL + (0x200 * i), value);
// vblank656_cnt=x26, vactive_cnt=240h, vblank_cnt=x24 /* vblank656_cnt=x26, vactive_cnt=240h, vblank_cnt=x24 */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
VERT_TIM_CTRL + (0x200 * i), &tmp); VERT_TIM_CTRL + (0x200 * i), &tmp);
value &= 0x00C00C00; value &= 0x00C00C00;
value |= 0x28240026; // vblank_cnt + 2 to get camera ID value |= 0x28240026; /* vblank_cnt + 2 to get camera ID */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
VERT_TIM_CTRL + (0x200 * i), value); VERT_TIM_CTRL + (0x200 * i), value);
// chroma subcarrier step size /* chroma subcarrier step size */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
SC_STEP_SIZE + (0x200 * i), 0x5411E2D0); SC_STEP_SIZE + (0x200 * i), 0x5411E2D0);
// enable VIP optional active /* enable VIP optional active */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
OUT_CTRL_NS + (0x200 * i), &tmp); OUT_CTRL_NS + (0x200 * i), &tmp);
...@@ -340,7 +347,7 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -340,7 +347,7 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
OUT_CTRL_NS + (0x200 * i), value); OUT_CTRL_NS + (0x200 * i), value);
// enable VIP optional active (VIP_OPT_AL) for direct output. /* enable VIP optional active (VIP_OPT_AL) for direct output. */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], OUT_CTRL1 + (0x200 * i), cx25821_i2c_read(&dev->i2c_bus[0], OUT_CTRL1 + (0x200 * i),
&tmp); &tmp);
...@@ -350,18 +357,21 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -350,18 +357,21 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], OUT_CTRL1 + (0x200 * i), cx25821_i2c_write(&dev->i2c_bus[0], OUT_CTRL1 + (0x200 * i),
value); value);
// clear VPRES_VERT_EN bit, fixes the chroma run away problem /*
// when the input switching rate < 16 fields * clear VPRES_VERT_EN bit, fixes the chroma run away problem
* when the input switching rate < 16 fields
*/
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
MISC_TIM_CTRL + (0x200 * i), &tmp); MISC_TIM_CTRL + (0x200 * i), &tmp);
value = setBitAtPos(value, 14); // disable special play detection /* disable special play detection */
value = setBitAtPos(value, 14);
value = clearBitAtPos(value, 15); value = clearBitAtPos(value, 15);
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
MISC_TIM_CTRL + (0x200 * i), value); MISC_TIM_CTRL + (0x200 * i), value);
// set vbi_gate_en to 0 /* set vbi_gate_en to 0 */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], DFE_CTRL1 + (0x200 * i), cx25821_i2c_read(&dev->i2c_bus[0], DFE_CTRL1 + (0x200 * i),
&tmp); &tmp);
...@@ -372,12 +382,12 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -372,12 +382,12 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
medusa_PALCombInit(dev, i); medusa_PALCombInit(dev, i);
// Enable the generation of blue field output if no video /* Enable the generation of blue field output if no video */
medusa_enable_bluefield_output(dev, i, 1); medusa_enable_bluefield_output(dev, i, 1);
} }
for (i = 0; i < MAX_ENCODERS; i++) { for (i = 0; i < MAX_ENCODERS; i++) {
// PAL hclock /* PAL hclock */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
DENC_A_REG_1 + (0x100 * i), &tmp); DENC_A_REG_1 + (0x100 * i), &tmp);
...@@ -387,7 +397,7 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -387,7 +397,7 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_1 + (0x100 * i), value); DENC_A_REG_1 + (0x100 * i), value);
// burst begin and burst end /* burst begin and burst end */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
DENC_A_REG_2 + (0x100 * i), &tmp); DENC_A_REG_2 + (0x100 * i), &tmp);
...@@ -397,7 +407,7 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -397,7 +407,7 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_2 + (0x100 * i), value); DENC_A_REG_2 + (0x100 * i), value);
// hblank and vactive /* hblank and vactive */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
DENC_A_REG_3 + (0x100 * i), &tmp); DENC_A_REG_3 + (0x100 * i), &tmp);
...@@ -407,7 +417,7 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -407,7 +417,7 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_3 + (0x100 * i), value); DENC_A_REG_3 + (0x100 * i), value);
// set PAL vblank, phase alternation, 0 IRE pedestal /* set PAL vblank, phase alternation, 0 IRE pedestal */
value = value =
cx25821_i2c_read(&dev->i2c_bus[0], cx25821_i2c_read(&dev->i2c_bus[0],
DENC_A_REG_4 + (0x100 * i), &tmp); DENC_A_REG_4 + (0x100 * i), &tmp);
...@@ -430,17 +440,19 @@ static int medusa_initialize_pal(struct cx25821_dev *dev) ...@@ -430,17 +440,19 @@ static int medusa_initialize_pal(struct cx25821_dev *dev)
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_6 + (0x100 * i), 0x00A493CF); DENC_A_REG_6 + (0x100 * i), 0x00A493CF);
// Subcarrier Increment /* Subcarrier Increment */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
DENC_A_REG_7 + (0x100 * i), 0x2A098ACB); DENC_A_REG_7 + (0x100 * i), 0x2A098ACB);
} }
//set picture resolutions /* set picture resolutions */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], HSCALE_CTRL, 0x0); //0 - 720 /* 0 - 720 */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], VSCALE_CTRL, 0x0); //0 - 576 ret_val = cx25821_i2c_write(&dev->i2c_bus[0], HSCALE_CTRL, 0x0);
/* 0 - 576 */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], VSCALE_CTRL, 0x0);
// set Bypass input format to PAL 625 lines /* set Bypass input format to PAL 625 lines */
value = cx25821_i2c_read(&dev->i2c_bus[0], BYP_AB_CTRL, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], BYP_AB_CTRL, &tmp);
value &= 0xFFF7FDFF; value &= 0xFFF7FDFF;
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], BYP_AB_CTRL, value); ret_val = cx25821_i2c_write(&dev->i2c_bus[0], BYP_AB_CTRL, value);
...@@ -455,18 +467,17 @@ int medusa_set_videostandard(struct cx25821_dev *dev) ...@@ -455,18 +467,17 @@ int medusa_set_videostandard(struct cx25821_dev *dev)
int status = STATUS_SUCCESS; int status = STATUS_SUCCESS;
u32 value = 0, tmp = 0; u32 value = 0, tmp = 0;
if (dev->tvnorm & V4L2_STD_PAL_BG || dev->tvnorm & V4L2_STD_PAL_DK) { if (dev->tvnorm & V4L2_STD_PAL_BG || dev->tvnorm & V4L2_STD_PAL_DK)
status = medusa_initialize_pal(dev); status = medusa_initialize_pal(dev);
} else { else
status = medusa_initialize_ntsc(dev); status = medusa_initialize_ntsc(dev);
}
// Enable DENC_A output /* Enable DENC_A output */
value = cx25821_i2c_read(&dev->i2c_bus[0], DENC_A_REG_4, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], DENC_A_REG_4, &tmp);
value = setBitAtPos(value, 4); value = setBitAtPos(value, 4);
status = cx25821_i2c_write(&dev->i2c_bus[0], DENC_A_REG_4, value); status = cx25821_i2c_write(&dev->i2c_bus[0], DENC_A_REG_4, value);
// Enable DENC_B output /* Enable DENC_B output */
value = cx25821_i2c_read(&dev->i2c_bus[0], DENC_B_REG_4, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], DENC_B_REG_4, &tmp);
value = setBitAtPos(value, 4); value = setBitAtPos(value, 4);
status = cx25821_i2c_write(&dev->i2c_bus[0], DENC_B_REG_4, value); status = cx25821_i2c_write(&dev->i2c_bus[0], DENC_B_REG_4, value);
...@@ -486,10 +497,10 @@ void medusa_set_resolution(struct cx25821_dev *dev, int width, ...@@ -486,10 +497,10 @@ void medusa_set_resolution(struct cx25821_dev *dev, int width,
mutex_lock(&dev->lock); mutex_lock(&dev->lock);
// validate the width - cannot be negative /* validate the width - cannot be negative */
if (width > MAX_WIDTH) { if (width > MAX_WIDTH) {
printk printk
("cx25821 %s() : width %d > MAX_WIDTH %d ! resetting to MAX_WIDTH \n", ("cx25821 %s() : width %d > MAX_WIDTH %d ! resetting to MAX_WIDTH\n",
__func__, width, MAX_WIDTH); __func__, width, MAX_WIDTH);
width = MAX_WIDTH; width = MAX_WIDTH;
} }
...@@ -523,14 +534,14 @@ void medusa_set_resolution(struct cx25821_dev *dev, int width, ...@@ -523,14 +534,14 @@ void medusa_set_resolution(struct cx25821_dev *dev, int width,
vscale = 0x1E00; vscale = 0x1E00;
break; break;
default: //720 default: /* 720 */
hscale = 0x0; hscale = 0x0;
vscale = 0x0; vscale = 0x0;
break; break;
} }
for (; decoder < decoder_count; decoder++) { for (; decoder < decoder_count; decoder++) {
// write scaling values for each decoder /* write scaling values for each decoder */
ret_val = ret_val =
cx25821_i2c_write(&dev->i2c_bus[0], cx25821_i2c_write(&dev->i2c_bus[0],
HSCALE_CTRL + (0x200 * decoder), hscale); HSCALE_CTRL + (0x200 * decoder), hscale);
...@@ -552,7 +563,7 @@ static void medusa_set_decoderduration(struct cx25821_dev *dev, int decoder, ...@@ -552,7 +563,7 @@ static void medusa_set_decoderduration(struct cx25821_dev *dev, int decoder,
mutex_lock(&dev->lock); mutex_lock(&dev->lock);
// no support /* no support */
if (decoder < VDEC_A && decoder > VDEC_H) { if (decoder < VDEC_A && decoder > VDEC_H) {
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
return; return;
...@@ -577,11 +588,10 @@ static void medusa_set_decoderduration(struct cx25821_dev *dev, int decoder, ...@@ -577,11 +588,10 @@ static void medusa_set_decoderduration(struct cx25821_dev *dev, int decoder,
_display_field_cnt[decoder] = duration; _display_field_cnt[decoder] = duration;
// update hardware /* update hardware */
fld_cnt = cx25821_i2c_read(&dev->i2c_bus[0], disp_cnt_reg, &tmp); fld_cnt = cx25821_i2c_read(&dev->i2c_bus[0], disp_cnt_reg, &tmp);
if (!(decoder % 2)) // EVEN decoder if (!(decoder % 2)) { /* EVEN decoder */
{
fld_cnt &= 0xFFFF0000; fld_cnt &= 0xFFFF0000;
fld_cnt |= duration; fld_cnt |= duration;
} else { } else {
...@@ -594,8 +604,7 @@ static void medusa_set_decoderduration(struct cx25821_dev *dev, int decoder, ...@@ -594,8 +604,7 @@ static void medusa_set_decoderduration(struct cx25821_dev *dev, int decoder,
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
} }
///////////////////////////////////////////////////////////////////////////////////////// /* Map to Medusa register setting */
// Map to Medusa register setting
static int mapM(int srcMin, static int mapM(int srcMin,
int srcMax, int srcVal, int dstMin, int dstMax, int *dstVal) int srcMax, int srcVal, int dstMin, int dstMax, int *dstVal)
{ {
...@@ -603,20 +612,21 @@ static int mapM(int srcMin, ...@@ -603,20 +612,21 @@ static int mapM(int srcMin,
int denominator; int denominator;
int quotient; int quotient;
if ((srcMin == srcMax) || (srcVal < srcMin) || (srcVal > srcMax)) { if ((srcMin == srcMax) || (srcVal < srcMin) || (srcVal > srcMax))
return -1; return -1;
} /*
// This is the overall expression used: * This is the overall expression used:
// *dstVal = (srcVal - srcMin)*(dstMax - dstMin) / (srcMax - srcMin) + dstMin; * *dstVal =
// but we need to account for rounding so below we use the modulus * (srcVal - srcMin)*(dstMax - dstMin) / (srcMax - srcMin) + dstMin;
// operator to find the remainder and increment if necessary. * but we need to account for rounding so below we use the modulus
* operator to find the remainder and increment if necessary.
*/
numerator = (srcVal - srcMin) * (dstMax - dstMin); numerator = (srcVal - srcMin) * (dstMax - dstMin);
denominator = srcMax - srcMin; denominator = srcMax - srcMin;
quotient = numerator / denominator; quotient = numerator / denominator;
if (2 * (numerator % denominator) >= denominator) { if (2 * (numerator % denominator) >= denominator)
quotient++; quotient++;
}
*dstVal = quotient + dstMin; *dstVal = quotient + dstMin;
...@@ -636,7 +646,6 @@ static unsigned long convert_to_twos(long numeric, unsigned long bits_len) ...@@ -636,7 +646,6 @@ static unsigned long convert_to_twos(long numeric, unsigned long bits_len)
} }
} }
/////////////////////////////////////////////////////////////////////////////////////////
int medusa_set_brightness(struct cx25821_dev *dev, int brightness, int decoder) int medusa_set_brightness(struct cx25821_dev *dev, int brightness, int decoder)
{ {
int ret_val = 0; int ret_val = 0;
...@@ -665,7 +674,6 @@ int medusa_set_brightness(struct cx25821_dev *dev, int brightness, int decoder) ...@@ -665,7 +674,6 @@ int medusa_set_brightness(struct cx25821_dev *dev, int brightness, int decoder)
return ret_val; return ret_val;
} }
/////////////////////////////////////////////////////////////////////////////////////////
int medusa_set_contrast(struct cx25821_dev *dev, int contrast, int decoder) int medusa_set_contrast(struct cx25821_dev *dev, int contrast, int decoder)
{ {
int ret_val = 0; int ret_val = 0;
...@@ -695,7 +703,6 @@ int medusa_set_contrast(struct cx25821_dev *dev, int contrast, int decoder) ...@@ -695,7 +703,6 @@ int medusa_set_contrast(struct cx25821_dev *dev, int contrast, int decoder)
return ret_val; return ret_val;
} }
/////////////////////////////////////////////////////////////////////////////////////////
int medusa_set_hue(struct cx25821_dev *dev, int hue, int decoder) int medusa_set_hue(struct cx25821_dev *dev, int hue, int decoder)
{ {
int ret_val = 0; int ret_val = 0;
...@@ -727,7 +734,6 @@ int medusa_set_hue(struct cx25821_dev *dev, int hue, int decoder) ...@@ -727,7 +734,6 @@ int medusa_set_hue(struct cx25821_dev *dev, int hue, int decoder)
return ret_val; return ret_val;
} }
/////////////////////////////////////////////////////////////////////////////////////////
int medusa_set_saturation(struct cx25821_dev *dev, int saturation, int decoder) int medusa_set_saturation(struct cx25821_dev *dev, int saturation, int decoder)
{ {
int ret_val = 0; int ret_val = 0;
...@@ -768,9 +774,8 @@ int medusa_set_saturation(struct cx25821_dev *dev, int saturation, int decoder) ...@@ -768,9 +774,8 @@ int medusa_set_saturation(struct cx25821_dev *dev, int saturation, int decoder)
return ret_val; return ret_val;
} }
///////////////////////////////////////////////////////////////////////////////////////// /* Program the display sequence and monitor output. */
// Program the display sequence and monitor output.
//
int medusa_video_init(struct cx25821_dev *dev) int medusa_video_init(struct cx25821_dev *dev)
{ {
u32 value = 0, tmp = 0; u32 value = 0, tmp = 0;
...@@ -781,7 +786,7 @@ int medusa_video_init(struct cx25821_dev *dev) ...@@ -781,7 +786,7 @@ int medusa_video_init(struct cx25821_dev *dev)
_num_decoders = dev->_max_num_decoders; _num_decoders = dev->_max_num_decoders;
// disable Auto source selection on all video decoders /* disable Auto source selection on all video decoders */
value = cx25821_i2c_read(&dev->i2c_bus[0], MON_A_CTRL, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], MON_A_CTRL, &tmp);
value &= 0xFFFFF0FF; value &= 0xFFFFF0FF;
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], MON_A_CTRL, value); ret_val = cx25821_i2c_write(&dev->i2c_bus[0], MON_A_CTRL, value);
...@@ -790,7 +795,7 @@ int medusa_video_init(struct cx25821_dev *dev) ...@@ -790,7 +795,7 @@ int medusa_video_init(struct cx25821_dev *dev)
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
return -EINVAL; return -EINVAL;
} }
// Turn off Master source switch enable /* Turn off Master source switch enable */
value = cx25821_i2c_read(&dev->i2c_bus[0], MON_A_CTRL, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], MON_A_CTRL, &tmp);
value &= 0xFFFFFFDF; value &= 0xFFFFFFDF;
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], MON_A_CTRL, value); ret_val = cx25821_i2c_write(&dev->i2c_bus[0], MON_A_CTRL, value);
...@@ -800,32 +805,31 @@ int medusa_video_init(struct cx25821_dev *dev) ...@@ -800,32 +805,31 @@ int medusa_video_init(struct cx25821_dev *dev)
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
for (i = 0; i < _num_decoders; i++) { for (i = 0; i < _num_decoders; i++)
medusa_set_decoderduration(dev, i, _display_field_cnt[i]); medusa_set_decoderduration(dev, i, _display_field_cnt[i]);
}
mutex_lock(&dev->lock); mutex_lock(&dev->lock);
// Select monitor as DENC A input, power up the DAC /* Select monitor as DENC A input, power up the DAC */
value = cx25821_i2c_read(&dev->i2c_bus[0], DENC_AB_CTRL, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], DENC_AB_CTRL, &tmp);
value &= 0xFF70FF70; value &= 0xFF70FF70;
value |= 0x00090008; // set en_active value |= 0x00090008; /* set en_active */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], DENC_AB_CTRL, value); ret_val = cx25821_i2c_write(&dev->i2c_bus[0], DENC_AB_CTRL, value);
if (ret_val < 0) { if (ret_val < 0) {
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
return -EINVAL; return -EINVAL;
} }
// enable input is VIP/656 /* enable input is VIP/656 */
value = cx25821_i2c_read(&dev->i2c_bus[0], BYP_AB_CTRL, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], BYP_AB_CTRL, &tmp);
value |= 0x00040100; // enable VIP value |= 0x00040100; /* enable VIP */
ret_val = cx25821_i2c_write(&dev->i2c_bus[0], BYP_AB_CTRL, value); ret_val = cx25821_i2c_write(&dev->i2c_bus[0], BYP_AB_CTRL, value);
if (ret_val < 0) { if (ret_val < 0) {
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
return -EINVAL; return -EINVAL;
} }
// select AFE clock to output mode /* select AFE clock to output mode */
value = cx25821_i2c_read(&dev->i2c_bus[0], AFE_AB_DIAG_CTRL, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], AFE_AB_DIAG_CTRL, &tmp);
value &= 0x83FFFFFF; value &= 0x83FFFFFF;
ret_val = ret_val =
...@@ -836,15 +840,20 @@ int medusa_video_init(struct cx25821_dev *dev) ...@@ -836,15 +840,20 @@ int medusa_video_init(struct cx25821_dev *dev)
mutex_unlock(&dev->lock); mutex_unlock(&dev->lock);
return -EINVAL; return -EINVAL;
} }
// Turn on all of the data out and control output pins. /* Turn on all of the data out and control output pins. */
value = cx25821_i2c_read(&dev->i2c_bus[0], PIN_OE_CTRL, &tmp); value = cx25821_i2c_read(&dev->i2c_bus[0], PIN_OE_CTRL, &tmp);
value &= 0xFEF0FE00; value &= 0xFEF0FE00;
if (_num_decoders == MAX_DECODERS) { if (_num_decoders == MAX_DECODERS) {
// Note: The octal board does not support control pins(bit16-19). /*
// These bits are ignored in the octal board. * Note: The octal board does not support control pins(bit16-19)
value |= 0x010001F8; // disable VDEC A-C port, default to Mobilygen Interface * These bits are ignored in the octal board.
*
* disable VDEC A-C port, default to Mobilygen Interface
*/
value |= 0x010001F8;
} else { } else {
value |= 0x010F0108; // disable VDEC A-C port, default to Mobilygen Interface /* disable VDEC A-C port, default to Mobilygen Interface */
value |= 0x010F0108;
} }
value |= 7; value |= 7;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment