diff options
Diffstat (limited to 'drivers/media/video/cx25840')
-rw-r--r-- | drivers/media/video/cx25840/cx25840-audio.c | 42 | ||||
-rw-r--r-- | drivers/media/video/cx25840/cx25840-core.c | 80 | ||||
-rw-r--r-- | drivers/media/video/cx25840/cx25840-firmware.c | 14 |
3 files changed, 63 insertions, 73 deletions
diff --git a/drivers/media/video/cx25840/cx25840-audio.c b/drivers/media/video/cx25840/cx25840-audio.c index d2faeaa79759..2f846f5e0f9f 100644 --- a/drivers/media/video/cx25840/cx25840-audio.c +++ b/drivers/media/video/cx25840/cx25840-audio.c | |||
@@ -45,12 +45,11 @@ static int set_audclk_freq(struct i2c_client *client, u32 freq) | |||
45 | } | 45 | } |
46 | 46 | ||
47 | if (!state->is_cx231xx) { | 47 | if (!state->is_cx231xx) { |
48 | /* VID_PLL and AUX_PLL */ | ||
49 | cx25840_write4(client, 0x108, 0x1006040f); | ||
48 | 50 | ||
49 | /* VID_PLL and AUX_PLL */ | 51 | /* AUX_PLL_FRAC */ |
50 | cx25840_write4(client, 0x108, 0x1006040f); | 52 | cx25840_write4(client, 0x110, 0x01bb39ee); |
51 | |||
52 | /* AUX_PLL_FRAC */ | ||
53 | cx25840_write4(client, 0x110, 0x01bb39ee); | ||
54 | } | 53 | } |
55 | 54 | ||
56 | if (state->is_cx25836) | 55 | if (state->is_cx25836) |
@@ -70,7 +69,6 @@ static int set_audclk_freq(struct i2c_client *client, u32 freq) | |||
70 | } | 69 | } |
71 | 70 | ||
72 | if (!state->is_cx231xx) { | 71 | if (!state->is_cx231xx) { |
73 | |||
74 | /* VID_PLL and AUX_PLL */ | 72 | /* VID_PLL and AUX_PLL */ |
75 | cx25840_write4(client, 0x108, 0x1009040f); | 73 | cx25840_write4(client, 0x108, 0x1009040f); |
76 | 74 | ||
@@ -95,12 +93,11 @@ static int set_audclk_freq(struct i2c_client *client, u32 freq) | |||
95 | } | 93 | } |
96 | 94 | ||
97 | if (!state->is_cx231xx) { | 95 | if (!state->is_cx231xx) { |
96 | /* VID_PLL and AUX_PLL */ | ||
97 | cx25840_write4(client, 0x108, 0x100a040f); | ||
98 | 98 | ||
99 | /* VID_PLL and AUX_PLL */ | 99 | /* AUX_PLL_FRAC */ |
100 | cx25840_write4(client, 0x108, 0x100a040f); | 100 | cx25840_write4(client, 0x110, 0x0098d6e5); |
101 | |||
102 | /* AUX_PLL_FRAC */ | ||
103 | cx25840_write4(client, 0x110, 0x0098d6e5); | ||
104 | } | 101 | } |
105 | 102 | ||
106 | if (state->is_cx25836) | 103 | if (state->is_cx25836) |
@@ -122,12 +119,11 @@ static int set_audclk_freq(struct i2c_client *client, u32 freq) | |||
122 | } | 119 | } |
123 | 120 | ||
124 | if (!state->is_cx231xx) { | 121 | if (!state->is_cx231xx) { |
122 | /* VID_PLL and AUX_PLL */ | ||
123 | cx25840_write4(client, 0x108, 0x1e08040f); | ||
125 | 124 | ||
126 | /* VID_PLL and AUX_PLL */ | 125 | /* AUX_PLL_FRAC */ |
127 | cx25840_write4(client, 0x108, 0x1e08040f); | 126 | cx25840_write4(client, 0x110, 0x012a0869); |
128 | |||
129 | /* AUX_PLL_FRAC */ | ||
130 | cx25840_write4(client, 0x110, 0x012a0869); | ||
131 | } | 127 | } |
132 | 128 | ||
133 | if (state->is_cx25836) | 129 | if (state->is_cx25836) |
@@ -154,12 +150,11 @@ static int set_audclk_freq(struct i2c_client *client, u32 freq) | |||
154 | 150 | ||
155 | 151 | ||
156 | if (!state->is_cx231xx) { | 152 | if (!state->is_cx231xx) { |
153 | /* VID_PLL and AUX_PLL */ | ||
154 | cx25840_write4(client, 0x108, 0x1809040f); | ||
157 | 155 | ||
158 | /* VID_PLL and AUX_PLL */ | 156 | /* AUX_PLL_FRAC */ |
159 | cx25840_write4(client, 0x108, 0x1809040f); | 157 | cx25840_write4(client, 0x110, 0x00ec6bd6); |
160 | |||
161 | /* AUX_PLL_FRAC */ | ||
162 | cx25840_write4(client, 0x110, 0x00ec6bd6); | ||
163 | } | 158 | } |
164 | 159 | ||
165 | if (state->is_cx25836) | 160 | if (state->is_cx25836) |
@@ -247,10 +242,9 @@ void cx25840_audio_set_path(struct i2c_client *client) | |||
247 | /* deassert soft reset */ | 242 | /* deassert soft reset */ |
248 | cx25840_and_or(client, 0x810, ~0x1, 0x00); | 243 | cx25840_and_or(client, 0x810, ~0x1, 0x00); |
249 | 244 | ||
250 | if (state->is_cx23885 || state->is_cx231xx) { | 245 | /* Ensure the controller is running when we exit */ |
251 | /* Ensure the controller is running when we exit */ | 246 | if (state->is_cx23885 || state->is_cx231xx) |
252 | cx25840_and_or(client, 0x803, ~0x10, 0x10); | 247 | cx25840_and_or(client, 0x803, ~0x10, 0x10); |
253 | } | ||
254 | } | 248 | } |
255 | 249 | ||
256 | static int get_volume(struct i2c_client *client) | 250 | static int get_volume(struct i2c_client *client) |
diff --git a/drivers/media/video/cx25840/cx25840-core.c b/drivers/media/video/cx25840/cx25840-core.c index 9108f74c0f71..a6d9bdbe7a9d 100644 --- a/drivers/media/video/cx25840/cx25840-core.c +++ b/drivers/media/video/cx25840/cx25840-core.c | |||
@@ -374,15 +374,12 @@ static void cx231xx_initialize(struct i2c_client *client) | |||
374 | /* DIF Src phase inc */ | 374 | /* DIF Src phase inc */ |
375 | cx25840_write4(client, 0x340, 0x0df7df83); | 375 | cx25840_write4(client, 0x340, 0x0df7df83); |
376 | 376 | ||
377 | |||
378 | /* Luma */ | 377 | /* Luma */ |
379 | cx25840_write4(client, 0x414, 0x00107d12); | 378 | cx25840_write4(client, 0x414, 0x00107d12); |
380 | 379 | ||
381 | /* Chroma */ | 380 | /* Chroma */ |
382 | cx25840_write4(client, 0x420, 0x3d008282); | 381 | cx25840_write4(client, 0x420, 0x3d008282); |
383 | 382 | ||
384 | |||
385 | |||
386 | /* ADC2 input select */ | 383 | /* ADC2 input select */ |
387 | cx25840_write(client, 0x102, 0x10); | 384 | cx25840_write(client, 0x102, 0x10); |
388 | 385 | ||
@@ -395,7 +392,6 @@ static void cx231xx_initialize(struct i2c_client *client) | |||
395 | /* White crush, Chroma AGC & Chroma Killer enabled */ | 392 | /* White crush, Chroma AGC & Chroma Killer enabled */ |
396 | cx25840_write(client, 0x401, 0xe8); | 393 | cx25840_write(client, 0x401, 0xe8); |
397 | 394 | ||
398 | |||
399 | /* Do the firmware load in a work handler to prevent. | 395 | /* Do the firmware load in a work handler to prevent. |
400 | Otherwise the kernel is blocked waiting for the | 396 | Otherwise the kernel is blocked waiting for the |
401 | bit-banging i2c interface to finish uploading the | 397 | bit-banging i2c interface to finish uploading the |
@@ -489,42 +485,42 @@ void cx25840_std_setup(struct i2c_client *client) | |||
489 | } | 485 | } |
490 | 486 | ||
491 | /* DEBUG: Displays configured PLL frequency */ | 487 | /* DEBUG: Displays configured PLL frequency */ |
492 | if (!state->is_cx231xx) { | 488 | if (!state->is_cx231xx) { |
493 | pll_int = cx25840_read(client, 0x108); | 489 | pll_int = cx25840_read(client, 0x108); |
494 | pll_frac = cx25840_read4(client, 0x10c) & 0x1ffffff; | 490 | pll_frac = cx25840_read4(client, 0x10c) & 0x1ffffff; |
495 | pll_post = cx25840_read(client, 0x109); | 491 | pll_post = cx25840_read(client, 0x109); |
496 | v4l_dbg(1, cx25840_debug, client, | ||
497 | "PLL regs = int: %u, frac: %u, post: %u\n", | ||
498 | pll_int, pll_frac, pll_post); | ||
499 | |||
500 | if (pll_post) { | ||
501 | int fin, fsc; | ||
502 | int pll = (28636363L * ((((u64)pll_int) << 25L) + pll_frac)) >> 25L; | ||
503 | |||
504 | pll /= pll_post; | ||
505 | v4l_dbg(1, cx25840_debug, client, "PLL = %d.%06d MHz\n", | ||
506 | pll / 1000000, pll % 1000000); | ||
507 | v4l_dbg(1, cx25840_debug, client, "PLL/8 = %d.%06d MHz\n", | ||
508 | pll / 8000000, (pll / 8) % 1000000); | ||
509 | |||
510 | fin = ((u64)src_decimation * pll) >> 12; | ||
511 | v4l_dbg(1, cx25840_debug, client, | ||
512 | "ADC Sampling freq = %d.%06d MHz\n", | ||
513 | fin / 1000000, fin % 1000000); | ||
514 | |||
515 | fsc = (((u64)sc) * pll) >> 24L; | ||
516 | v4l_dbg(1, cx25840_debug, client, | 492 | v4l_dbg(1, cx25840_debug, client, |
517 | "Chroma sub-carrier freq = %d.%06d MHz\n", | 493 | "PLL regs = int: %u, frac: %u, post: %u\n", |
518 | fsc / 1000000, fsc % 1000000); | 494 | pll_int, pll_frac, pll_post); |
519 | 495 | ||
520 | v4l_dbg(1, cx25840_debug, client, "hblank %i, hactive %i, " | 496 | if (pll_post) { |
521 | "vblank %i, vactive %i, vblank656 %i, src_dec %i, " | 497 | int fin, fsc; |
522 | "burst 0x%02x, luma_lpf %i, uv_lpf %i, comb 0x%02x, " | 498 | int pll = (28636363L * ((((u64)pll_int) << 25L) + pll_frac)) >> 25L; |
523 | "sc 0x%06x\n", | 499 | |
524 | hblank, hactive, vblank, vactive, vblank656, | 500 | pll /= pll_post; |
525 | src_decimation, burst, luma_lpf, uv_lpf, comb, sc); | 501 | v4l_dbg(1, cx25840_debug, client, "PLL = %d.%06d MHz\n", |
502 | pll / 1000000, pll % 1000000); | ||
503 | v4l_dbg(1, cx25840_debug, client, "PLL/8 = %d.%06d MHz\n", | ||
504 | pll / 8000000, (pll / 8) % 1000000); | ||
505 | |||
506 | fin = ((u64)src_decimation * pll) >> 12; | ||
507 | v4l_dbg(1, cx25840_debug, client, | ||
508 | "ADC Sampling freq = %d.%06d MHz\n", | ||
509 | fin / 1000000, fin % 1000000); | ||
510 | |||
511 | fsc = (((u64)sc) * pll) >> 24L; | ||
512 | v4l_dbg(1, cx25840_debug, client, | ||
513 | "Chroma sub-carrier freq = %d.%06d MHz\n", | ||
514 | fsc / 1000000, fsc % 1000000); | ||
515 | |||
516 | v4l_dbg(1, cx25840_debug, client, "hblank %i, hactive %i, " | ||
517 | "vblank %i, vactive %i, vblank656 %i, src_dec %i, " | ||
518 | "burst 0x%02x, luma_lpf %i, uv_lpf %i, comb 0x%02x, " | ||
519 | "sc 0x%06x\n", | ||
520 | hblank, hactive, vblank, vactive, vblank656, | ||
521 | src_decimation, burst, luma_lpf, uv_lpf, comb, sc); | ||
522 | } | ||
526 | } | 523 | } |
527 | } | ||
528 | 524 | ||
529 | /* Sets horizontal blanking delay and active lines */ | 525 | /* Sets horizontal blanking delay and active lines */ |
530 | cx25840_write(client, 0x470, hblank); | 526 | cx25840_write(client, 0x470, hblank); |
@@ -809,7 +805,7 @@ static int set_v4lstd(struct i2c_client *client) | |||
809 | 805 | ||
810 | static int cx25840_s_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) | 806 | static int cx25840_s_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) |
811 | { | 807 | { |
812 | struct cx25840_state *state = to_state(sd); | 808 | struct cx25840_state *state = to_state(sd); |
813 | struct i2c_client *client = v4l2_get_subdevdata(sd); | 809 | struct i2c_client *client = v4l2_get_subdevdata(sd); |
814 | 810 | ||
815 | switch (ctrl->id) { | 811 | switch (ctrl->id) { |
@@ -876,7 +872,7 @@ static int cx25840_s_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) | |||
876 | 872 | ||
877 | static int cx25840_g_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) | 873 | static int cx25840_g_ctrl(struct v4l2_subdev *sd, struct v4l2_control *ctrl) |
878 | { | 874 | { |
879 | struct cx25840_state *state = to_state(sd); | 875 | struct cx25840_state *state = to_state(sd); |
880 | struct i2c_client *client = v4l2_get_subdevdata(sd); | 876 | struct i2c_client *client = v4l2_get_subdevdata(sd); |
881 | 877 | ||
882 | switch (ctrl->id) { | 878 | switch (ctrl->id) { |
@@ -1208,7 +1204,7 @@ static int cx25840_init(struct v4l2_subdev *sd, u32 val) | |||
1208 | cx25836_initialize(client); | 1204 | cx25836_initialize(client); |
1209 | else if (state->is_cx23885) | 1205 | else if (state->is_cx23885) |
1210 | cx23885_initialize(client); | 1206 | cx23885_initialize(client); |
1211 | else if (state->is_cx231xx) | 1207 | else if (state->is_cx231xx) |
1212 | cx231xx_initialize(client); | 1208 | cx231xx_initialize(client); |
1213 | else | 1209 | else |
1214 | cx25840_initialize(client); | 1210 | cx25840_initialize(client); |
@@ -1567,7 +1563,7 @@ static int cx25840_probe(struct i2c_client *client, | |||
1567 | state->c = client; | 1563 | state->c = client; |
1568 | state->is_cx25836 = ((device_id & 0xff00) == 0x8300); | 1564 | state->is_cx25836 = ((device_id & 0xff00) == 0x8300); |
1569 | state->is_cx23885 = (device_id == 0x0000) || (device_id == 0x1313); | 1565 | state->is_cx23885 = (device_id == 0x0000) || (device_id == 0x1313); |
1570 | state->is_cx231xx = (device_id == 0x5A3E); | 1566 | state->is_cx231xx = (device_id == 0x5a3e); |
1571 | state->vid_input = CX25840_COMPOSITE7; | 1567 | state->vid_input = CX25840_COMPOSITE7; |
1572 | state->aud_input = CX25840_AUDIO8; | 1568 | state->aud_input = CX25840_AUDIO8; |
1573 | state->audclk_freq = 48000; | 1569 | state->audclk_freq = 48000; |
diff --git a/drivers/media/video/cx25840/cx25840-firmware.c b/drivers/media/video/cx25840/cx25840-firmware.c index 1a5f7d0ead41..0df53b0d75d9 100644 --- a/drivers/media/video/cx25840/cx25840-firmware.c +++ b/drivers/media/video/cx25840/cx25840-firmware.c | |||
@@ -97,17 +97,17 @@ int cx25840_loadfw(struct i2c_client *client) | |||
97 | u8 buffer[FWSEND]; | 97 | u8 buffer[FWSEND]; |
98 | const u8 *ptr; | 98 | const u8 *ptr; |
99 | int size, retval; | 99 | int size, retval; |
100 | int MAX_BUF_SIZE = FWSEND; | 100 | int MAX_BUF_SIZE = FWSEND; |
101 | 101 | ||
102 | if (state->is_cx23885) | 102 | if (state->is_cx23885) |
103 | firmware = FWFILE_CX23885; | 103 | firmware = FWFILE_CX23885; |
104 | else if ( state->is_cx231xx) | 104 | else if (state->is_cx231xx) |
105 | firmware = FWFILE_CX231XX; | 105 | firmware = FWFILE_CX231XX; |
106 | 106 | ||
107 | if( (state->is_cx231xx) && MAX_BUF_SIZE > 16) { | 107 | if ((state->is_cx231xx) && MAX_BUF_SIZE > 16) { |
108 | printk(" Firmware download size changed to 16 bytes max length\n"); | 108 | v4l_err(client, " Firmware download size changed to 16 bytes max length\n"); |
109 | MAX_BUF_SIZE = 16; /* cx231xx cannot accept more than 16 bytes at a time */ | 109 | MAX_BUF_SIZE = 16; /* cx231xx cannot accept more than 16 bytes at a time */ |
110 | } | 110 | } |
111 | 111 | ||
112 | if (request_firmware(&fw, firmware, FWDEV(client)) != 0) { | 112 | if (request_firmware(&fw, firmware, FWDEV(client)) != 0) { |
113 | v4l_err(client, "unable to open firmware %s\n", firmware); | 113 | v4l_err(client, "unable to open firmware %s\n", firmware); |