diff options
author | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-03-03 04:14:34 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2009-04-06 20:44:01 -0400 |
commit | 84b5dbf39ed2f51224841bbbf08439158d69d427 (patch) | |
tree | b24963462dc1ad93860645d8729d1ddfc6ce526e /drivers/media/video/cx231xx | |
parent | e0d3bafd02586cfde286c320f56906fd9fa8d256 (diff) |
V4L/DVB (10955): cx231xx: CodingStyle automatic fixes with Lindent
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/cx231xx')
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-audio.c | 255 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-avcore.c | 4383 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-cards.c | 976 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-conf-reg.h | 132 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-core.c | 1126 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-dvb.c | 264 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-i2c.c | 567 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-input.c | 24 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-reg.h | 59 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-vbi.c | 555 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-vbi.h | 26 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx-video.c | 1820 | ||||
-rw-r--r-- | drivers/media/video/cx231xx/cx231xx.h | 522 |
13 files changed, 5809 insertions, 4900 deletions
diff --git a/drivers/media/video/cx231xx/cx231xx-audio.c b/drivers/media/video/cx231xx/cx231xx-audio.c index e4335e2a4103..cee64879c4f0 100644 --- a/drivers/media/video/cx231xx/cx231xx-audio.c +++ b/drivers/media/video/cx231xx/cx231xx-audio.c | |||
@@ -58,21 +58,20 @@ static int cx231xx_isoc_audio_deinit(struct cx231xx *dev) | |||
58 | 58 | ||
59 | dprintk("Stopping isoc\n"); | 59 | dprintk("Stopping isoc\n"); |
60 | 60 | ||
61 | |||
62 | for (i = 0; i < CX231XX_AUDIO_BUFS; i++) { | 61 | for (i = 0; i < CX231XX_AUDIO_BUFS; i++) { |
63 | if(dev->adev.urb[i]) { | 62 | if (dev->adev.urb[i]) { |
64 | if (!irqs_disabled()) | 63 | if (!irqs_disabled()) |
65 | usb_kill_urb(dev->adev.urb[i]); | 64 | usb_kill_urb(dev->adev.urb[i]); |
66 | else | 65 | else |
67 | usb_unlink_urb(dev->adev.urb[i]); | 66 | usb_unlink_urb(dev->adev.urb[i]); |
68 | 67 | ||
69 | usb_free_urb(dev->adev.urb[i]); | 68 | usb_free_urb(dev->adev.urb[i]); |
70 | dev->adev.urb[i] = NULL; | 69 | dev->adev.urb[i] = NULL; |
71 | 70 | ||
72 | kfree(dev->adev.transfer_buffer[i]); | 71 | kfree(dev->adev.transfer_buffer[i]); |
73 | dev->adev.transfer_buffer[i] = NULL; | 72 | dev->adev.transfer_buffer[i] = NULL; |
74 | 73 | ||
75 | } | 74 | } |
76 | } | 75 | } |
77 | 76 | ||
78 | return 0; | 77 | return 0; |
@@ -80,27 +79,27 @@ static int cx231xx_isoc_audio_deinit(struct cx231xx *dev) | |||
80 | 79 | ||
81 | static void cx231xx_audio_isocirq(struct urb *urb) | 80 | static void cx231xx_audio_isocirq(struct urb *urb) |
82 | { | 81 | { |
83 | struct cx231xx *dev = urb->context; | 82 | struct cx231xx *dev = urb->context; |
84 | int i; | 83 | int i; |
85 | unsigned int oldptr; | 84 | unsigned int oldptr; |
86 | int period_elapsed = 0; | 85 | int period_elapsed = 0; |
87 | int status; | 86 | int status; |
88 | unsigned char *cp; | 87 | unsigned char *cp; |
89 | unsigned int stride; | 88 | unsigned int stride; |
90 | struct snd_pcm_substream *substream; | 89 | struct snd_pcm_substream *substream; |
91 | struct snd_pcm_runtime *runtime; | 90 | struct snd_pcm_runtime *runtime; |
92 | 91 | ||
93 | switch (urb->status) { | 92 | switch (urb->status) { |
94 | case 0: /* success */ | 93 | case 0: /* success */ |
95 | case -ETIMEDOUT: /* NAK */ | 94 | case -ETIMEDOUT: /* NAK */ |
96 | break; | 95 | break; |
97 | case -ECONNRESET: /* kill */ | 96 | case -ECONNRESET: /* kill */ |
98 | case -ENOENT: | 97 | case -ENOENT: |
99 | case -ESHUTDOWN: | 98 | case -ESHUTDOWN: |
100 | return; | 99 | return; |
101 | default: /* error */ | 100 | default: /* error */ |
102 | dprintk("urb completition error %d.\n", urb->status); | 101 | dprintk("urb completition error %d.\n", urb->status); |
103 | break; | 102 | break; |
104 | } | 103 | } |
105 | 104 | ||
106 | if (dev->adev.capture_pcm_substream) { | 105 | if (dev->adev.capture_pcm_substream) { |
@@ -145,7 +144,6 @@ static void cx231xx_audio_isocirq(struct urb *urb) | |||
145 | runtime->period_size; | 144 | runtime->period_size; |
146 | period_elapsed = 1; | 145 | period_elapsed = 1; |
147 | } | 146 | } |
148 | |||
149 | snd_pcm_stream_unlock(substream); | 147 | snd_pcm_stream_unlock(substream); |
150 | } | 148 | } |
151 | if (period_elapsed) | 149 | if (period_elapsed) |
@@ -156,19 +154,19 @@ static void cx231xx_audio_isocirq(struct urb *urb) | |||
156 | status = usb_submit_urb(urb, GFP_ATOMIC); | 154 | status = usb_submit_urb(urb, GFP_ATOMIC); |
157 | if (status < 0) { | 155 | if (status < 0) { |
158 | cx231xx_errdev("resubmit of audio urb failed (error=%i)\n", | 156 | cx231xx_errdev("resubmit of audio urb failed (error=%i)\n", |
159 | status); | 157 | status); |
160 | } | 158 | } |
161 | return; | 159 | return; |
162 | } | 160 | } |
163 | 161 | ||
164 | static int cx231xx_init_audio_isoc(struct cx231xx *dev) | 162 | static int cx231xx_init_audio_isoc(struct cx231xx *dev) |
165 | { | 163 | { |
166 | int i, errCode; | 164 | int i, errCode; |
167 | int sb_size; | 165 | int sb_size; |
168 | 166 | ||
169 | cx231xx_info("%s: Starting AUDIO transfers\n",__func__); | 167 | cx231xx_info("%s: Starting AUDIO transfers\n", __func__); |
170 | 168 | ||
171 | sb_size = CX231XX_NUM_AUDIO_PACKETS * dev->adev.max_pkt_size; | 169 | sb_size = CX231XX_NUM_AUDIO_PACKETS * dev->adev.max_pkt_size; |
172 | 170 | ||
173 | for (i = 0; i < CX231XX_AUDIO_BUFS; i++) { | 171 | for (i = 0; i < CX231XX_AUDIO_BUFS; i++) { |
174 | struct urb *urb; | 172 | struct urb *urb; |
@@ -191,7 +189,8 @@ static int cx231xx_init_audio_isoc(struct cx231xx *dev) | |||
191 | 189 | ||
192 | urb->dev = dev->udev; | 190 | urb->dev = dev->udev; |
193 | urb->context = dev; | 191 | urb->context = dev; |
194 | urb->pipe = usb_rcvisocpipe(dev->udev, dev->adev.end_point_addr); | 192 | urb->pipe = |
193 | usb_rcvisocpipe(dev->udev, dev->adev.end_point_addr); | ||
195 | urb->transfer_flags = URB_ISO_ASAP; | 194 | urb->transfer_flags = URB_ISO_ASAP; |
196 | urb->transfer_buffer = dev->adev.transfer_buffer[i]; | 195 | urb->transfer_buffer = dev->adev.transfer_buffer[i]; |
197 | urb->interval = 1; | 196 | urb->interval = 1; |
@@ -200,10 +199,9 @@ static int cx231xx_init_audio_isoc(struct cx231xx *dev) | |||
200 | urb->transfer_buffer_length = sb_size; | 199 | urb->transfer_buffer_length = sb_size; |
201 | 200 | ||
202 | for (j = k = 0; j < CX231XX_NUM_AUDIO_PACKETS; | 201 | for (j = k = 0; j < CX231XX_NUM_AUDIO_PACKETS; |
203 | j++, k += dev->adev.max_pkt_size) { | 202 | j++, k += dev->adev.max_pkt_size) { |
204 | urb->iso_frame_desc[j].offset = k; | 203 | urb->iso_frame_desc[j].offset = k; |
205 | urb->iso_frame_desc[j].length = | 204 | urb->iso_frame_desc[j].length = dev->adev.max_pkt_size; |
206 | dev->adev.max_pkt_size; | ||
207 | } | 205 | } |
208 | dev->adev.urb[i] = urb; | 206 | dev->adev.urb[i] = urb; |
209 | } | 207 | } |
@@ -221,11 +219,11 @@ static int cx231xx_init_audio_isoc(struct cx231xx *dev) | |||
221 | 219 | ||
222 | static int cx231xx_cmd(struct cx231xx *dev, int cmd, int arg) | 220 | static int cx231xx_cmd(struct cx231xx *dev, int cmd, int arg) |
223 | { | 221 | { |
224 | dprintk("%s transfer\n", (dev->adev.capture_stream == STREAM_ON)? | 222 | dprintk("%s transfer\n", (dev->adev.capture_stream == STREAM_ON) ? |
225 | "stop" : "start"); | 223 | "stop" : "start"); |
226 | 224 | ||
227 | switch (cmd) { | 225 | switch (cmd) { |
228 | case CX231XX_CAPTURE_STREAM_EN: | 226 | case CX231XX_CAPTURE_STREAM_EN: |
229 | if (dev->adev.capture_stream == STREAM_OFF && arg == 1) { | 227 | if (dev->adev.capture_stream == STREAM_OFF && arg == 1) { |
230 | dev->adev.capture_stream = STREAM_ON; | 228 | dev->adev.capture_stream = STREAM_ON; |
231 | cx231xx_init_audio_isoc(dev); | 229 | cx231xx_init_audio_isoc(dev); |
@@ -233,8 +231,8 @@ static int cx231xx_cmd(struct cx231xx *dev, int cmd, int arg) | |||
233 | dev->adev.capture_stream = STREAM_OFF; | 231 | dev->adev.capture_stream = STREAM_OFF; |
234 | cx231xx_isoc_audio_deinit(dev); | 232 | cx231xx_isoc_audio_deinit(dev); |
235 | } else { | 233 | } else { |
236 | cx231xx_errdev( "An underrun very likely occurred. " | 234 | cx231xx_errdev("An underrun very likely occurred. " |
237 | "Ignoring it.\n"); | 235 | "Ignoring it.\n"); |
238 | } | 236 | } |
239 | return 0; | 237 | return 0; |
240 | default: | 238 | default: |
@@ -265,9 +263,8 @@ static int snd_pcm_alloc_vmalloc_buffer(struct snd_pcm_substream *subs, | |||
265 | 263 | ||
266 | static struct snd_pcm_hardware snd_cx231xx_hw_capture = { | 264 | static struct snd_pcm_hardware snd_cx231xx_hw_capture = { |
267 | .info = SNDRV_PCM_INFO_BLOCK_TRANSFER | | 265 | .info = SNDRV_PCM_INFO_BLOCK_TRANSFER | |
268 | SNDRV_PCM_INFO_MMAP | | 266 | SNDRV_PCM_INFO_MMAP | |
269 | SNDRV_PCM_INFO_INTERLEAVED | | 267 | SNDRV_PCM_INFO_INTERLEAVED | SNDRV_PCM_INFO_MMAP_VALID, |
270 | SNDRV_PCM_INFO_MMAP_VALID, | ||
271 | 268 | ||
272 | .formats = SNDRV_PCM_FMTBIT_S16_LE, | 269 | .formats = SNDRV_PCM_FMTBIT_S16_LE, |
273 | 270 | ||
@@ -278,10 +275,10 @@ static struct snd_pcm_hardware snd_cx231xx_hw_capture = { | |||
278 | .channels_min = 2, | 275 | .channels_min = 2, |
279 | .channels_max = 2, | 276 | .channels_max = 2, |
280 | .buffer_bytes_max = 62720 * 8, /* just about the value in usbaudio.c */ | 277 | .buffer_bytes_max = 62720 * 8, /* just about the value in usbaudio.c */ |
281 | .period_bytes_min = 64, /* 12544/2, */ | 278 | .period_bytes_min = 64, /* 12544/2, */ |
282 | .period_bytes_max = 12544, | 279 | .period_bytes_max = 12544, |
283 | .periods_min = 2, | 280 | .periods_min = 2, |
284 | .periods_max = 98, /* 12544, */ | 281 | .periods_max = 98, /* 12544, */ |
285 | }; | 282 | }; |
286 | 283 | ||
287 | static int snd_cx231xx_capture_open(struct snd_pcm_substream *substream) | 284 | static int snd_cx231xx_capture_open(struct snd_pcm_substream *substream) |
@@ -294,29 +291,29 @@ static int snd_cx231xx_capture_open(struct snd_pcm_substream *substream) | |||
294 | 291 | ||
295 | if (!dev) { | 292 | if (!dev) { |
296 | cx231xx_errdev("BUG: cx231xx can't find device struct." | 293 | cx231xx_errdev("BUG: cx231xx can't find device struct." |
297 | " Can't proceed with open\n"); | 294 | " Can't proceed with open\n"); |
298 | return -ENODEV; | 295 | return -ENODEV; |
299 | } | 296 | } |
300 | 297 | ||
301 | /* Sets volume, mute, etc */ | 298 | /* Sets volume, mute, etc */ |
302 | dev->mute = 0; | 299 | dev->mute = 0; |
303 | 300 | ||
304 | /* set alternate setting for audio interface */ | 301 | /* set alternate setting for audio interface */ |
305 | ret = cx231xx_set_alt_setting(dev, INDEX_AUDIO, 1); /* 1 - 48000 samples per sec */ | 302 | ret = cx231xx_set_alt_setting(dev, INDEX_AUDIO, 1); /* 1 - 48000 samples per sec */ |
306 | if (ret < 0) { | 303 | if (ret < 0) { |
307 | cx231xx_errdev("failed to set alternate setting !\n"); | 304 | cx231xx_errdev("failed to set alternate setting !\n"); |
308 | 305 | ||
309 | return ret; | 306 | return ret; |
310 | } | 307 | } |
311 | 308 | ||
312 | /* inform hardware to start streaming */ | 309 | /* inform hardware to start streaming */ |
313 | ret = cx231xx_capture_start(dev, 1, Audio); | 310 | ret = cx231xx_capture_start(dev, 1, Audio); |
314 | 311 | ||
315 | runtime->hw = snd_cx231xx_hw_capture; | 312 | runtime->hw = snd_cx231xx_hw_capture; |
316 | 313 | ||
317 | mutex_lock(&dev->lock); | 314 | mutex_lock(&dev->lock); |
318 | dev->adev.users++; | 315 | dev->adev.users++; |
319 | mutex_unlock(&dev->lock); | 316 | mutex_unlock(&dev->lock); |
320 | 317 | ||
321 | snd_pcm_hw_constraint_integer(runtime, SNDRV_PCM_HW_PARAM_PERIODS); | 318 | snd_pcm_hw_constraint_integer(runtime, SNDRV_PCM_HW_PARAM_PERIODS); |
322 | dev->adev.capture_pcm_substream = substream; | 319 | dev->adev.capture_pcm_substream = substream; |
@@ -327,26 +324,25 @@ static int snd_cx231xx_capture_open(struct snd_pcm_substream *substream) | |||
327 | 324 | ||
328 | static int snd_cx231xx_pcm_close(struct snd_pcm_substream *substream) | 325 | static int snd_cx231xx_pcm_close(struct snd_pcm_substream *substream) |
329 | { | 326 | { |
330 | int ret; | 327 | int ret; |
331 | struct cx231xx *dev = snd_pcm_substream_chip(substream); | 328 | struct cx231xx *dev = snd_pcm_substream_chip(substream); |
332 | 329 | ||
333 | |||
334 | dprintk("closing device\n"); | 330 | dprintk("closing device\n"); |
335 | 331 | ||
336 | /* set alternate setting for audio interface */ | 332 | /* set alternate setting for audio interface */ |
337 | ret = cx231xx_set_alt_setting(dev, INDEX_AUDIO, 0); /* 1 - 48000 samples per sec */ | 333 | ret = cx231xx_set_alt_setting(dev, INDEX_AUDIO, 0); /* 1 - 48000 samples per sec */ |
338 | if (ret < 0) { | 334 | if (ret < 0) { |
339 | cx231xx_errdev("failed to set alternate setting !\n"); | 335 | cx231xx_errdev("failed to set alternate setting !\n"); |
340 | 336 | ||
341 | return ret; | 337 | return ret; |
342 | } | 338 | } |
343 | 339 | ||
344 | /* inform hardware to start streaming */ | 340 | /* inform hardware to start streaming */ |
345 | ret = cx231xx_capture_start(dev, 0, Audio); | 341 | ret = cx231xx_capture_start(dev, 0, Audio); |
346 | 342 | ||
347 | dev->mute = 1; | 343 | dev->mute = 1; |
348 | mutex_lock(&dev->lock); | 344 | mutex_lock(&dev->lock); |
349 | dev->adev.users--; | 345 | dev->adev.users--; |
350 | mutex_unlock(&dev->lock); | 346 | mutex_unlock(&dev->lock); |
351 | 347 | ||
352 | if (dev->adev.users == 0 && dev->adev.shutdown == 1) { | 348 | if (dev->adev.users == 0 && dev->adev.shutdown == 1) { |
@@ -360,7 +356,7 @@ static int snd_cx231xx_pcm_close(struct snd_pcm_substream *substream) | |||
360 | } | 356 | } |
361 | 357 | ||
362 | static int snd_cx231xx_hw_capture_params(struct snd_pcm_substream *substream, | 358 | static int snd_cx231xx_hw_capture_params(struct snd_pcm_substream *substream, |
363 | struct snd_pcm_hw_params *hw_params) | 359 | struct snd_pcm_hw_params *hw_params) |
364 | { | 360 | { |
365 | unsigned int channels, rate, format; | 361 | unsigned int channels, rate, format; |
366 | int ret; | 362 | int ret; |
@@ -368,7 +364,7 @@ static int snd_cx231xx_hw_capture_params(struct snd_pcm_substream *substream, | |||
368 | dprintk("Setting capture parameters\n"); | 364 | dprintk("Setting capture parameters\n"); |
369 | 365 | ||
370 | ret = snd_pcm_alloc_vmalloc_buffer(substream, | 366 | ret = snd_pcm_alloc_vmalloc_buffer(substream, |
371 | params_buffer_bytes(hw_params)); | 367 | params_buffer_bytes(hw_params)); |
372 | format = params_format(hw_params); | 368 | format = params_format(hw_params); |
373 | rate = params_rate(hw_params); | 369 | rate = params_rate(hw_params); |
374 | channels = params_channels(hw_params); | 370 | channels = params_channels(hw_params); |
@@ -397,45 +393,45 @@ static int snd_cx231xx_prepare(struct snd_pcm_substream *substream) | |||
397 | } | 393 | } |
398 | 394 | ||
399 | static int snd_cx231xx_capture_trigger(struct snd_pcm_substream *substream, | 395 | static int snd_cx231xx_capture_trigger(struct snd_pcm_substream *substream, |
400 | int cmd) | 396 | int cmd) |
401 | { | 397 | { |
402 | struct cx231xx *dev = snd_pcm_substream_chip(substream); | 398 | struct cx231xx *dev = snd_pcm_substream_chip(substream); |
403 | int retval; | 399 | int retval; |
404 | 400 | ||
401 | dprintk("Should %s capture\n", (cmd == SNDRV_PCM_TRIGGER_START) ? | ||
402 | "start" : "stop"); | ||
405 | 403 | ||
406 | dprintk("Should %s capture\n", (cmd == SNDRV_PCM_TRIGGER_START)? | 404 | spin_lock(&dev->adev.slock); |
407 | "start": "stop"); | ||
408 | |||
409 | spin_lock(&dev->adev.slock); | ||
410 | switch (cmd) { | 405 | switch (cmd) { |
411 | case SNDRV_PCM_TRIGGER_START: | 406 | case SNDRV_PCM_TRIGGER_START: |
412 | cx231xx_cmd(dev, CX231XX_CAPTURE_STREAM_EN, CX231XX_START_AUDIO); | 407 | cx231xx_cmd(dev, CX231XX_CAPTURE_STREAM_EN, |
408 | CX231XX_START_AUDIO); | ||
413 | retval = 0; | 409 | retval = 0; |
414 | break; | 410 | break; |
415 | case SNDRV_PCM_TRIGGER_STOP: | 411 | case SNDRV_PCM_TRIGGER_STOP: |
416 | cx231xx_cmd(dev, CX231XX_CAPTURE_STREAM_EN, CX231XX_STOP_AUDIO); | 412 | cx231xx_cmd(dev, CX231XX_CAPTURE_STREAM_EN, CX231XX_STOP_AUDIO); |
417 | retval = 0; | 413 | retval = 0; |
418 | break; | 414 | break; |
419 | default: | 415 | default: |
420 | retval = -EINVAL; | 416 | retval = -EINVAL; |
421 | } | 417 | } |
422 | 418 | ||
423 | spin_unlock(&dev->adev.slock); | 419 | spin_unlock(&dev->adev.slock); |
424 | return retval; | 420 | return retval; |
425 | } | 421 | } |
426 | 422 | ||
427 | static snd_pcm_uframes_t snd_cx231xx_capture_pointer(struct snd_pcm_substream | 423 | static snd_pcm_uframes_t snd_cx231xx_capture_pointer(struct snd_pcm_substream |
428 | *substream) | 424 | *substream) |
429 | { | 425 | { |
430 | struct cx231xx *dev; | 426 | struct cx231xx *dev; |
431 | unsigned long flags; | 427 | unsigned long flags; |
432 | snd_pcm_uframes_t hwptr_done; | 428 | snd_pcm_uframes_t hwptr_done; |
433 | 429 | ||
434 | dev = snd_pcm_substream_chip(substream); | 430 | dev = snd_pcm_substream_chip(substream); |
435 | 431 | ||
436 | spin_lock_irqsave(&dev->adev.slock, flags); | 432 | spin_lock_irqsave(&dev->adev.slock, flags); |
437 | hwptr_done = dev->adev.hwptr_done_capture; | 433 | hwptr_done = dev->adev.hwptr_done_capture; |
438 | spin_unlock_irqrestore(&dev->adev.slock, flags); | 434 | spin_unlock_irqrestore(&dev->adev.slock, flags); |
439 | 435 | ||
440 | return hwptr_done; | 436 | return hwptr_done; |
441 | } | 437 | } |
@@ -449,26 +445,26 @@ static struct page *snd_pcm_get_vmalloc_page(struct snd_pcm_substream *subs, | |||
449 | } | 445 | } |
450 | 446 | ||
451 | static struct snd_pcm_ops snd_cx231xx_pcm_capture = { | 447 | static struct snd_pcm_ops snd_cx231xx_pcm_capture = { |
452 | .open = snd_cx231xx_capture_open, | 448 | .open = snd_cx231xx_capture_open, |
453 | .close = snd_cx231xx_pcm_close, | 449 | .close = snd_cx231xx_pcm_close, |
454 | .ioctl = snd_pcm_lib_ioctl, | 450 | .ioctl = snd_pcm_lib_ioctl, |
455 | .hw_params = snd_cx231xx_hw_capture_params, | 451 | .hw_params = snd_cx231xx_hw_capture_params, |
456 | .hw_free = snd_cx231xx_hw_capture_free, | 452 | .hw_free = snd_cx231xx_hw_capture_free, |
457 | .prepare = snd_cx231xx_prepare, | 453 | .prepare = snd_cx231xx_prepare, |
458 | .trigger = snd_cx231xx_capture_trigger, | 454 | .trigger = snd_cx231xx_capture_trigger, |
459 | .pointer = snd_cx231xx_capture_pointer, | 455 | .pointer = snd_cx231xx_capture_pointer, |
460 | .page = snd_pcm_get_vmalloc_page, | 456 | .page = snd_pcm_get_vmalloc_page, |
461 | }; | 457 | }; |
462 | 458 | ||
463 | static int cx231xx_audio_init(struct cx231xx *dev) | 459 | static int cx231xx_audio_init(struct cx231xx *dev) |
464 | { | 460 | { |
465 | struct cx231xx_audio *adev = &dev->adev; | 461 | struct cx231xx_audio *adev = &dev->adev; |
466 | struct snd_pcm *pcm; | 462 | struct snd_pcm *pcm; |
467 | struct snd_card *card; | 463 | struct snd_card *card; |
468 | static int devnr; | 464 | static int devnr; |
469 | int err; | 465 | int err; |
470 | struct usb_interface *uif; | 466 | struct usb_interface *uif; |
471 | int i, isoc_pipe = 0; | 467 | int i, isoc_pipe = 0; |
472 | 468 | ||
473 | if (dev->has_alsa_audio != 1) { | 469 | if (dev->has_alsa_audio != 1) { |
474 | /* This device does not support the extension (in this case | 470 | /* This device does not support the extension (in this case |
@@ -478,7 +474,7 @@ static int cx231xx_audio_init(struct cx231xx *dev) | |||
478 | } | 474 | } |
479 | 475 | ||
480 | cx231xx_info("cx231xx-audio.c: probing for cx231xx " | 476 | cx231xx_info("cx231xx-audio.c: probing for cx231xx " |
481 | "non standard usbaudio\n"); | 477 | "non standard usbaudio\n"); |
482 | 478 | ||
483 | card = snd_card_new(index[devnr], "Cx231xx Audio", THIS_MODULE, 0); | 479 | card = snd_card_new(index[devnr], "Cx231xx Audio", THIS_MODULE, 0); |
484 | if (card == NULL) { | 480 | if (card == NULL) { |
@@ -492,7 +488,8 @@ static int cx231xx_audio_init(struct cx231xx *dev) | |||
492 | return err; | 488 | return err; |
493 | } | 489 | } |
494 | 490 | ||
495 | snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_cx231xx_pcm_capture); | 491 | snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, |
492 | &snd_cx231xx_pcm_capture); | ||
496 | pcm->info_flags = 0; | 493 | pcm->info_flags = 0; |
497 | pcm->private_data = dev; | 494 | pcm->private_data = dev; |
498 | strcpy(pcm->name, "Conexant cx231xx Capture"); | 495 | strcpy(pcm->name, "Conexant cx231xx Capture"); |
@@ -508,29 +505,35 @@ static int cx231xx_audio_init(struct cx231xx *dev) | |||
508 | adev->sndcard = card; | 505 | adev->sndcard = card; |
509 | adev->udev = dev->udev; | 506 | adev->udev = dev->udev; |
510 | 507 | ||
511 | /* compute alternate max packet sizes for Audio */ | 508 | /* compute alternate max packet sizes for Audio */ |
512 | uif = dev->udev->actconfig->interface[dev->current_pcb_config.hs_config_info[0].interface_info.audio_index+1]; | 509 | uif = |
510 | dev->udev->actconfig->interface[dev->current_pcb_config. | ||
511 | hs_config_info[0].interface_info. | ||
512 | audio_index + 1]; | ||
513 | 513 | ||
514 | adev->end_point_addr = le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc.bEndpointAddress); | 514 | adev->end_point_addr = |
515 | le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc. | ||
516 | bEndpointAddress); | ||
515 | 517 | ||
516 | adev->num_alt = uif->num_altsetting; | 518 | adev->num_alt = uif->num_altsetting; |
517 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", adev->end_point_addr, | 519 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", |
518 | adev->num_alt); | 520 | adev->end_point_addr, adev->num_alt); |
519 | adev->alt_max_pkt_size = kmalloc(32 * adev->num_alt, GFP_KERNEL); | 521 | adev->alt_max_pkt_size = kmalloc(32 * adev->num_alt, GFP_KERNEL); |
520 | 522 | ||
521 | if (adev->alt_max_pkt_size == NULL) { | 523 | if (adev->alt_max_pkt_size == NULL) { |
522 | cx231xx_errdev("out of memory!\n"); | 524 | cx231xx_errdev("out of memory!\n"); |
523 | return -ENOMEM; | 525 | return -ENOMEM; |
524 | } | 526 | } |
525 | 527 | ||
526 | for (i = 0; i < adev->num_alt ; i++) { | 528 | for (i = 0; i < adev->num_alt; i++) { |
527 | u16 tmp = le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].desc. | 529 | u16 tmp = |
528 | wMaxPacketSize); | 530 | le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].desc. |
529 | adev->alt_max_pkt_size[i] = | 531 | wMaxPacketSize); |
530 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); | 532 | adev->alt_max_pkt_size[i] = |
531 | cx231xx_info("Alternate setting %i, max size= %i\n", i, | 533 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); |
532 | adev->alt_max_pkt_size[i]); | 534 | cx231xx_info("Alternate setting %i, max size= %i\n", i, |
533 | } | 535 | adev->alt_max_pkt_size[i]); |
536 | } | ||
534 | 537 | ||
535 | return 0; | 538 | return 0; |
536 | } | 539 | } |
@@ -549,7 +552,7 @@ static int cx231xx_audio_fini(struct cx231xx *dev) | |||
549 | 552 | ||
550 | if (dev->adev.sndcard) { | 553 | if (dev->adev.sndcard) { |
551 | snd_card_free(dev->adev.sndcard); | 554 | snd_card_free(dev->adev.sndcard); |
552 | kfree(dev->adev.alt_max_pkt_size); | 555 | kfree(dev->adev.alt_max_pkt_size); |
553 | dev->adev.sndcard = NULL; | 556 | dev->adev.sndcard = NULL; |
554 | } | 557 | } |
555 | 558 | ||
@@ -557,7 +560,7 @@ static int cx231xx_audio_fini(struct cx231xx *dev) | |||
557 | } | 560 | } |
558 | 561 | ||
559 | static struct cx231xx_ops audio_ops = { | 562 | static struct cx231xx_ops audio_ops = { |
560 | .id = CX231XX_AUDIO, | 563 | .id = CX231XX_AUDIO, |
561 | .name = "Cx231xx Audio Extension", | 564 | .name = "Cx231xx Audio Extension", |
562 | .init = cx231xx_audio_init, | 565 | .init = cx231xx_audio_init, |
563 | .fini = cx231xx_audio_fini, | 566 | .fini = cx231xx_audio_fini, |
diff --git a/drivers/media/video/cx231xx/cx231xx-avcore.c b/drivers/media/video/cx231xx/cx231xx-avcore.c index b5597337966f..3c09b9473843 100644 --- a/drivers/media/video/cx231xx/cx231xx-avcore.c +++ b/drivers/media/video/cx231xx/cx231xx-avcore.c | |||
@@ -38,115 +38,180 @@ | |||
38 | 38 | ||
39 | #include "cx231xx.h" | 39 | #include "cx231xx.h" |
40 | 40 | ||
41 | |||
42 | /************************************************************************************* | 41 | /************************************************************************************* |
43 | * C O L I B R I - B L O C K C O N T R O L functions * | 42 | * C O L I B R I - B L O C K C O N T R O L functions * |
44 | *************************************************************************************/ | 43 | *************************************************************************************/ |
45 | int cx231xx_colibri_init_super_block(struct cx231xx *dev, u32 ref_count) | 44 | int cx231xx_colibri_init_super_block(struct cx231xx *dev, u32 ref_count) |
46 | { | 45 | { |
47 | int status = 0; | 46 | int status = 0; |
48 | u8 temp = 0; | 47 | u8 temp = 0; |
49 | u32 colibri_power_status = 0; | 48 | u32 colibri_power_status = 0; |
50 | int i = 0; | 49 | int i = 0; |
51 | 50 | ||
52 | /* super block initialize */ | 51 | /* super block initialize */ |
53 | temp = (u8)(ref_count & 0xff); | 52 | temp = (u8) (ref_count & 0xff); |
54 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE2, 2, temp, 1); | 53 | status = |
55 | 54 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE2, | |
56 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE2, 2, &colibri_power_status, 1); | 55 | 2, temp, 1); |
57 | 56 | ||
58 | temp = (u8)((ref_count & 0x300) >> 8); | 57 | status = |
59 | temp |= 0x40; | 58 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE2, 2, |
60 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE1, 2, temp, 1); | 59 | &colibri_power_status, 1); |
61 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_PLL2, 2, 0x0f, 1); | 60 | |
62 | 61 | temp = (u8) ((ref_count & 0x300) >> 8); | |
63 | /* enable pll */ | 62 | temp |= 0x40; |
64 | while(colibri_power_status != 0x18) | 63 | status = |
65 | { | 64 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE1, |
66 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_PWRDN, 2, 0x18, 1); | 65 | 2, temp, 1); |
67 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_PWRDN, 2, &colibri_power_status, 1); | 66 | status = |
68 | colibri_power_status &= 0xff; | 67 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_PLL2, 2, |
69 | if(status < 0) { | 68 | 0x0f, 1); |
70 | cx231xx_info(": Init Super Block failed in sending/receiving cmds\n"); | 69 | |
71 | break; | 70 | /* enable pll */ |
72 | } | 71 | while (colibri_power_status != 0x18) { |
73 | i++; | 72 | status = |
74 | if( i == 10) { | 73 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
75 | cx231xx_info(": Init Super Block force break in loop !!!!\n"); | 74 | SUP_BLK_PWRDN, 2, 0x18, 1); |
76 | status = -1; | 75 | status = |
77 | break; | 76 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
78 | } | 77 | SUP_BLK_PWRDN, 2, |
79 | } | 78 | &colibri_power_status, 1); |
80 | 79 | colibri_power_status &= 0xff; | |
81 | if(status < 0 ) | 80 | if (status < 0) { |
82 | return status; | 81 | cx231xx_info |
83 | 82 | (": Init Super Block failed in sending/receiving cmds\n"); | |
84 | /* start tuning filter */ | 83 | break; |
85 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE3, 2, 0x40, 1); | 84 | } |
86 | msleep(5); | 85 | i++; |
87 | 86 | if (i == 10) { | |
88 | /* exit tuning */ | 87 | cx231xx_info |
89 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE3, 2, 0x00, 1); | 88 | (": Init Super Block force break in loop !!!!\n"); |
90 | 89 | status = -1; | |
91 | return status; | 90 | break; |
91 | } | ||
92 | } | ||
93 | |||
94 | if (status < 0) | ||
95 | return status; | ||
96 | |||
97 | /* start tuning filter */ | ||
98 | status = | ||
99 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE3, | ||
100 | 2, 0x40, 1); | ||
101 | msleep(5); | ||
102 | |||
103 | /* exit tuning */ | ||
104 | status = | ||
105 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, SUP_BLK_TUNE3, | ||
106 | 2, 0x00, 1); | ||
107 | |||
108 | return status; | ||
92 | } | 109 | } |
93 | 110 | ||
94 | int cx231xx_colibri_init_channels(struct cx231xx *dev) | 111 | int cx231xx_colibri_init_channels(struct cx231xx *dev) |
95 | { | 112 | { |
96 | int status = 0; | 113 | int status = 0; |
97 | 114 | ||
98 | /* power up all 3 channels, clear pd_buffer */ | 115 | /* power up all 3 channels, clear pd_buffer */ |
99 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_PWRDN_CLAMP_CH1, 2, 0x00, 1); | 116 | status = |
100 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_PWRDN_CLAMP_CH2, 2, 0x00, 1); | 117 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
101 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_PWRDN_CLAMP_CH3, 2, 0x00, 1); | 118 | ADC_PWRDN_CLAMP_CH1, 2, 0x00, 1); |
102 | 119 | status = | |
103 | /* Enable quantizer calibration */ | 120 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
104 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_COM_QUANT, 2, 0x02, 1); | 121 | ADC_PWRDN_CLAMP_CH2, 2, 0x00, 1); |
105 | 122 | status = | |
106 | /* channel initialize, force modulator (fb) reset */ | 123 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
107 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_FB_FRCRST_CH1, 2, 0x17, 1); | 124 | ADC_PWRDN_CLAMP_CH3, 2, 0x00, 1); |
108 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_FB_FRCRST_CH2, 2, 0x17, 1); | 125 | |
109 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_FB_FRCRST_CH3, 2, 0x17, 1); | 126 | /* Enable quantizer calibration */ |
110 | 127 | status = | |
111 | /* start quantilizer calibration */ | 128 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_COM_QUANT, |
112 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_CAL_ATEST_CH1, 2, 0x10, 1); | 129 | 2, 0x02, 1); |
113 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_CAL_ATEST_CH2, 2, 0x10, 1); | 130 | |
114 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_CAL_ATEST_CH3, 2, 0x10, 1); | 131 | /* channel initialize, force modulator (fb) reset */ |
115 | msleep(5); | 132 | status = |
116 | 133 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | |
117 | /* exit modulator (fb) reset */ | 134 | ADC_FB_FRCRST_CH1, 2, 0x17, 1); |
118 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_FB_FRCRST_CH1, 2, 0x07, 1); | 135 | status = |
119 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_FB_FRCRST_CH2, 2, 0x07, 1); | 136 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
120 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_FB_FRCRST_CH3, 2, 0x07, 1); | 137 | ADC_FB_FRCRST_CH2, 2, 0x17, 1); |
121 | 138 | status = | |
122 | /* enable the pre_clamp in each channel for single-ended input */ | 139 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
123 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_NTF_PRECLMP_EN_CH1, 2, 0xf0, 1); | 140 | ADC_FB_FRCRST_CH3, 2, 0x17, 1); |
124 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_NTF_PRECLMP_EN_CH2, 2, 0xf0, 1); | 141 | |
125 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_NTF_PRECLMP_EN_CH3, 2, 0xf0, 1); | 142 | /* start quantilizer calibration */ |
126 | 143 | status = | |
127 | /* use diode instead of resistor, so set term_en to 0, res_en to 0 */ | 144 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
128 | status = cx231xx_reg_mask_write(dev, Colibri_DEVICE_ADDRESS, 8, ADC_QGAIN_RES_TRM_CH1, 3, 7, 0x00); | 145 | ADC_CAL_ATEST_CH1, 2, 0x10, 1); |
129 | status = cx231xx_reg_mask_write(dev, Colibri_DEVICE_ADDRESS, 8, ADC_QGAIN_RES_TRM_CH2, 3, 7, 0x00); | 146 | status = |
130 | status = cx231xx_reg_mask_write(dev, Colibri_DEVICE_ADDRESS, 8, ADC_QGAIN_RES_TRM_CH3, 3, 7, 0x00); | 147 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
131 | 148 | ADC_CAL_ATEST_CH2, 2, 0x10, 1); | |
132 | /* dynamic element matching off */ | 149 | status = |
133 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_DCSERVO_DEM_CH1, 2, 0x03, 1); | 150 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
134 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_DCSERVO_DEM_CH2, 2, 0x03, 1); | 151 | ADC_CAL_ATEST_CH3, 2, 0x10, 1); |
135 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_DCSERVO_DEM_CH3, 2, 0x03, 1); | 152 | msleep(5); |
136 | 153 | ||
137 | return status; | 154 | /* exit modulator (fb) reset */ |
155 | status = | ||
156 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
157 | ADC_FB_FRCRST_CH1, 2, 0x07, 1); | ||
158 | status = | ||
159 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
160 | ADC_FB_FRCRST_CH2, 2, 0x07, 1); | ||
161 | status = | ||
162 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
163 | ADC_FB_FRCRST_CH3, 2, 0x07, 1); | ||
164 | |||
165 | /* enable the pre_clamp in each channel for single-ended input */ | ||
166 | status = | ||
167 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
168 | ADC_NTF_PRECLMP_EN_CH1, 2, 0xf0, 1); | ||
169 | status = | ||
170 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
171 | ADC_NTF_PRECLMP_EN_CH2, 2, 0xf0, 1); | ||
172 | status = | ||
173 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
174 | ADC_NTF_PRECLMP_EN_CH3, 2, 0xf0, 1); | ||
175 | |||
176 | /* use diode instead of resistor, so set term_en to 0, res_en to 0 */ | ||
177 | status = | ||
178 | cx231xx_reg_mask_write(dev, Colibri_DEVICE_ADDRESS, 8, | ||
179 | ADC_QGAIN_RES_TRM_CH1, 3, 7, 0x00); | ||
180 | status = | ||
181 | cx231xx_reg_mask_write(dev, Colibri_DEVICE_ADDRESS, 8, | ||
182 | ADC_QGAIN_RES_TRM_CH2, 3, 7, 0x00); | ||
183 | status = | ||
184 | cx231xx_reg_mask_write(dev, Colibri_DEVICE_ADDRESS, 8, | ||
185 | ADC_QGAIN_RES_TRM_CH3, 3, 7, 0x00); | ||
186 | |||
187 | /* dynamic element matching off */ | ||
188 | status = | ||
189 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
190 | ADC_DCSERVO_DEM_CH1, 2, 0x03, 1); | ||
191 | status = | ||
192 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
193 | ADC_DCSERVO_DEM_CH2, 2, 0x03, 1); | ||
194 | status = | ||
195 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
196 | ADC_DCSERVO_DEM_CH3, 2, 0x03, 1); | ||
197 | |||
198 | return status; | ||
138 | } | 199 | } |
139 | 200 | ||
140 | int cx231xx_colibri_setup_AFE_for_baseband(struct cx231xx *dev) | 201 | int cx231xx_colibri_setup_AFE_for_baseband(struct cx231xx *dev) |
141 | { | 202 | { |
142 | u32 c_value = 0; | 203 | u32 c_value = 0; |
143 | int status = 0; | 204 | int status = 0; |
144 | 205 | ||
145 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_PWRDN_CLAMP_CH2, 2, &c_value, 1); | 206 | status = |
146 | c_value &= (~(0x50)); | 207 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
147 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_PWRDN_CLAMP_CH2, 2, c_value, 1); | 208 | ADC_PWRDN_CLAMP_CH2, 2, &c_value, 1); |
209 | c_value &= (~(0x50)); | ||
210 | status = | ||
211 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
212 | ADC_PWRDN_CLAMP_CH2, 2, c_value, 1); | ||
148 | 213 | ||
149 | return status; | 214 | return status; |
150 | } | 215 | } |
151 | 216 | ||
152 | /* | 217 | /* |
@@ -157,559 +222,802 @@ int cx231xx_colibri_setup_AFE_for_baseband(struct cx231xx *dev) | |||
157 | */ | 222 | */ |
158 | int cx231xx_colibri_set_input_mux(struct cx231xx *dev, u32 input_mux) | 223 | int cx231xx_colibri_set_input_mux(struct cx231xx *dev, u32 input_mux) |
159 | { | 224 | { |
160 | u8 ch1_setting = (u8)input_mux; | 225 | u8 ch1_setting = (u8) input_mux; |
161 | u8 ch2_setting = (u8)(input_mux >> 8); | 226 | u8 ch2_setting = (u8) (input_mux >> 8); |
162 | u8 ch3_setting = (u8)(input_mux >> 16); | 227 | u8 ch3_setting = (u8) (input_mux >> 16); |
163 | int status = 0; | 228 | int status = 0; |
164 | u32 value = 0; | 229 | u32 value = 0; |
165 | 230 | ||
166 | if(ch1_setting != 0) | 231 | if (ch1_setting != 0) { |
167 | { | 232 | status = |
168 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_INPUT_CH1, 2, &value, 1); | 233 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
169 | value &= (!INPUT_SEL_MASK); | 234 | ADC_INPUT_CH1, 2, &value, 1); |
170 | value |= (ch1_setting-1)<<4; | 235 | value &= (!INPUT_SEL_MASK); |
171 | value &= 0xff; | 236 | value |= (ch1_setting - 1) << 4; |
172 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_INPUT_CH1, 2, value, 1); | 237 | value &= 0xff; |
173 | } | 238 | status = |
174 | 239 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | |
175 | if(ch2_setting != 0) | 240 | ADC_INPUT_CH1, 2, value, 1); |
176 | { | 241 | } |
177 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_INPUT_CH2, 2, &value, 1); | 242 | |
178 | value &= (!INPUT_SEL_MASK); | 243 | if (ch2_setting != 0) { |
179 | value |= (ch2_setting-1)<<4; | 244 | status = |
180 | value &= 0xff; | 245 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
181 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_INPUT_CH2, 2, value, 1); | 246 | ADC_INPUT_CH2, 2, &value, 1); |
182 | } | 247 | value &= (!INPUT_SEL_MASK); |
183 | 248 | value |= (ch2_setting - 1) << 4; | |
184 | /* For ch3_setting, the value to put in the register is 7 less than the input number */ | 249 | value &= 0xff; |
185 | if(ch3_setting != 0) | 250 | status = |
186 | { | 251 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
187 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_INPUT_CH3, 2, &value, 1); | 252 | ADC_INPUT_CH2, 2, value, 1); |
188 | value &= (!INPUT_SEL_MASK); | 253 | } |
189 | value |= (ch3_setting-1)<<4; | 254 | |
190 | value &= 0xff; | 255 | /* For ch3_setting, the value to put in the register is 7 less than the input number */ |
191 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_INPUT_CH3, 2, value, 1); | 256 | if (ch3_setting != 0) { |
192 | } | 257 | status = |
193 | 258 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | |
194 | return status; | 259 | ADC_INPUT_CH3, 2, &value, 1); |
260 | value &= (!INPUT_SEL_MASK); | ||
261 | value |= (ch3_setting - 1) << 4; | ||
262 | value &= 0xff; | ||
263 | status = | ||
264 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
265 | ADC_INPUT_CH3, 2, value, 1); | ||
266 | } | ||
267 | |||
268 | return status; | ||
195 | } | 269 | } |
196 | 270 | ||
197 | int cx231xx_colibri_set_mode(struct cx231xx *dev, enum AFE_MODE mode) | 271 | int cx231xx_colibri_set_mode(struct cx231xx *dev, enum AFE_MODE mode) |
198 | { | 272 | { |
199 | int status = 0; | 273 | int status = 0; |
200 | 274 | ||
201 | switch(mode) { | 275 | switch (mode) { |
202 | case AFE_MODE_LOW_IF: | 276 | case AFE_MODE_LOW_IF: |
203 | /* SetupAFEforLowIF(); */ | 277 | /* SetupAFEforLowIF(); */ |
204 | break; | 278 | break; |
205 | case AFE_MODE_BASEBAND: | 279 | case AFE_MODE_BASEBAND: |
206 | status = cx231xx_colibri_setup_AFE_for_baseband(dev); | 280 | status = cx231xx_colibri_setup_AFE_for_baseband(dev); |
207 | break; | 281 | break; |
208 | case AFE_MODE_EU_HI_IF: | 282 | case AFE_MODE_EU_HI_IF: |
209 | /* SetupAFEforEuHiIF(); */ | 283 | /* SetupAFEforEuHiIF(); */ |
210 | break; | 284 | break; |
211 | case AFE_MODE_US_HI_IF: | 285 | case AFE_MODE_US_HI_IF: |
212 | /* SetupAFEforUsHiIF(); */ | 286 | /* SetupAFEforUsHiIF(); */ |
213 | break; | 287 | break; |
214 | case AFE_MODE_JAPAN_HI_IF: | 288 | case AFE_MODE_JAPAN_HI_IF: |
215 | /* SetupAFEforJapanHiIF(); */ | 289 | /* SetupAFEforJapanHiIF(); */ |
216 | break; | 290 | break; |
217 | } | 291 | } |
218 | 292 | ||
219 | if((mode != dev->colibri_mode) && (dev->video_input == CX231XX_VMUX_TELEVISION)) { | 293 | if ((mode != dev->colibri_mode) |
220 | status = cx231xx_colibri_adjust_ref_count(dev, CX231XX_VMUX_TELEVISION); | 294 | && (dev->video_input == CX231XX_VMUX_TELEVISION)) { |
221 | } | 295 | status = |
222 | 296 | cx231xx_colibri_adjust_ref_count(dev, | |
223 | dev->colibri_mode = mode; | 297 | CX231XX_VMUX_TELEVISION); |
224 | 298 | } | |
225 | return status; | 299 | |
300 | dev->colibri_mode = mode; | ||
301 | |||
302 | return status; | ||
226 | } | 303 | } |
227 | 304 | ||
228 | /* For power saving in the EVK */ | 305 | /* For power saving in the EVK */ |
229 | int cx231xx_colibri_update_power_control(struct cx231xx *dev, AV_MODE avmode) | 306 | int cx231xx_colibri_update_power_control(struct cx231xx *dev, AV_MODE avmode) |
230 | { | 307 | { |
231 | u32 colibri_power_status = 0; | 308 | u32 colibri_power_status = 0; |
232 | int status = 0; | 309 | int status = 0; |
233 | 310 | ||
234 | switch (dev->model) { | 311 | switch (dev->model) { |
235 | case CX231XX_BOARD_CNXT_RDE_250: | 312 | case CX231XX_BOARD_CNXT_RDE_250: |
236 | case CX231XX_BOARD_CNXT_RDU_250: | 313 | case CX231XX_BOARD_CNXT_RDU_250: |
237 | 314 | ||
238 | if(avmode==POLARIS_AVMODE_ANALOGT_TV) | 315 | if (avmode == POLARIS_AVMODE_ANALOGT_TV) { |
239 | { | 316 | while (colibri_power_status != 0x18) { |
240 | while(colibri_power_status != 0x18) { | 317 | status = |
241 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 318 | cx231xx_write_i2c_data(dev, |
242 | SUP_BLK_PWRDN, 2, 0x18, 1); | 319 | Colibri_DEVICE_ADDRESS, |
243 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 320 | SUP_BLK_PWRDN, 2, |
244 | SUP_BLK_PWRDN, 2, &colibri_power_status, 1); | 321 | 0x18, 1); |
245 | if(status < 0 ) | 322 | status = |
246 | break; | 323 | cx231xx_read_i2c_data(dev, |
247 | } | 324 | Colibri_DEVICE_ADDRESS, |
248 | 325 | SUP_BLK_PWRDN, 2, | |
249 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 326 | &colibri_power_status, |
250 | ADC_PWRDN_CLAMP_CH1, 2, 0x00, 1); | 327 | 1); |
251 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 328 | if (status < 0) |
252 | ADC_PWRDN_CLAMP_CH2, 2, 0x00, 1); | 329 | break; |
253 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 330 | } |
254 | ADC_PWRDN_CLAMP_CH3, 2, 0x00, 1); | 331 | |
255 | } | 332 | status = |
256 | else if(avmode==POLARIS_AVMODE_DIGITAL) { | 333 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
257 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 334 | ADC_PWRDN_CLAMP_CH1, 2, 0x00, |
258 | ADC_PWRDN_CLAMP_CH1, 2, 0x70, 1); | 335 | 1); |
259 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 336 | status = |
260 | ADC_PWRDN_CLAMP_CH2, 2, 0x70, 1); | 337 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
261 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 338 | ADC_PWRDN_CLAMP_CH2, 2, 0x00, |
262 | ADC_PWRDN_CLAMP_CH3, 2, 0x70, 1); | 339 | 1); |
263 | 340 | status = | |
264 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 341 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
265 | SUP_BLK_PWRDN, 2, &colibri_power_status, 1); | 342 | ADC_PWRDN_CLAMP_CH3, 2, 0x00, |
266 | colibri_power_status |=0x07; | 343 | 1); |
267 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 344 | } else if (avmode == POLARIS_AVMODE_DIGITAL) { |
268 | SUP_BLK_PWRDN, 2, colibri_power_status, 1); | 345 | status = |
269 | } | 346 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
270 | else if(avmode==POLARIS_AVMODE_ENXTERNAL_AV) { | 347 | ADC_PWRDN_CLAMP_CH1, 2, 0x70, |
271 | 348 | 1); | |
272 | while(colibri_power_status != 0x18) { | 349 | status = |
273 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 350 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
274 | SUP_BLK_PWRDN, 2, 0x18, 1); | 351 | ADC_PWRDN_CLAMP_CH2, 2, 0x70, |
275 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 352 | 1); |
276 | SUP_BLK_PWRDN, 2, &colibri_power_status, 1); | 353 | status = |
277 | if(status < 0 ) | 354 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
278 | break; | 355 | ADC_PWRDN_CLAMP_CH3, 2, 0x70, |
279 | } | 356 | 1); |
280 | 357 | ||
281 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 358 | status = |
282 | ADC_PWRDN_CLAMP_CH1, 2, 0x00, 1); | 359 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
283 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 360 | SUP_BLK_PWRDN, 2, |
284 | ADC_PWRDN_CLAMP_CH2, 2, 0x00, 1); | 361 | &colibri_power_status, 1); |
285 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 362 | colibri_power_status |= 0x07; |
286 | ADC_PWRDN_CLAMP_CH3, 2, 0x00, 1); | 363 | status = |
287 | } | 364 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
288 | else { | 365 | SUP_BLK_PWRDN, 2, |
289 | cx231xx_info("Invalid AV mode input\n"); | 366 | colibri_power_status, 1); |
290 | status = -1; | 367 | } else if (avmode == POLARIS_AVMODE_ENXTERNAL_AV) { |
291 | } | 368 | |
292 | break; | 369 | while (colibri_power_status != 0x18) { |
293 | default: | 370 | status = |
294 | if(avmode==POLARIS_AVMODE_ANALOGT_TV) | 371 | cx231xx_write_i2c_data(dev, |
295 | { | 372 | Colibri_DEVICE_ADDRESS, |
296 | while(colibri_power_status != 0x18) { | 373 | SUP_BLK_PWRDN, 2, |
297 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 374 | 0x18, 1); |
298 | SUP_BLK_PWRDN, 2, 0x18, 1); | 375 | status = |
299 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 376 | cx231xx_read_i2c_data(dev, |
300 | SUP_BLK_PWRDN, 2, &colibri_power_status, 1); | 377 | Colibri_DEVICE_ADDRESS, |
301 | if(status < 0 ) | 378 | SUP_BLK_PWRDN, 2, |
302 | break; | 379 | &colibri_power_status, |
303 | } | 380 | 1); |
304 | 381 | if (status < 0) | |
305 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 382 | break; |
306 | ADC_PWRDN_CLAMP_CH1, 2, 0x40, 1); | 383 | } |
307 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 384 | |
308 | ADC_PWRDN_CLAMP_CH2, 2, 0x40, 1); | 385 | status = |
309 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 386 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
310 | ADC_PWRDN_CLAMP_CH3, 2, 0x00, 1); | 387 | ADC_PWRDN_CLAMP_CH1, 2, 0x00, |
311 | } | 388 | 1); |
312 | else if(avmode==POLARIS_AVMODE_DIGITAL) { | 389 | status = |
313 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 390 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
314 | ADC_PWRDN_CLAMP_CH1, 2, 0x70, 1); | 391 | ADC_PWRDN_CLAMP_CH2, 2, 0x00, |
315 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 392 | 1); |
316 | ADC_PWRDN_CLAMP_CH2, 2, 0x70, 1); | 393 | status = |
317 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 394 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
318 | ADC_PWRDN_CLAMP_CH3, 2, 0x70, 1); | 395 | ADC_PWRDN_CLAMP_CH3, 2, 0x00, |
319 | 396 | 1); | |
320 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 397 | } else { |
321 | SUP_BLK_PWRDN, 2, &colibri_power_status, 1); | 398 | cx231xx_info("Invalid AV mode input\n"); |
322 | colibri_power_status |=0x07; | 399 | status = -1; |
323 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 400 | } |
324 | SUP_BLK_PWRDN, 2, colibri_power_status, 1); | 401 | break; |
325 | } | 402 | default: |
326 | else if(avmode==POLARIS_AVMODE_ENXTERNAL_AV) { | 403 | if (avmode == POLARIS_AVMODE_ANALOGT_TV) { |
327 | while(colibri_power_status != 0x18) { | 404 | while (colibri_power_status != 0x18) { |
328 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 405 | status = |
329 | SUP_BLK_PWRDN, 2, 0x18, 1); | 406 | cx231xx_write_i2c_data(dev, |
330 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 407 | Colibri_DEVICE_ADDRESS, |
331 | SUP_BLK_PWRDN, 2, &colibri_power_status, 1); | 408 | SUP_BLK_PWRDN, 2, |
332 | if(status < 0 ) | 409 | 0x18, 1); |
333 | break; | 410 | status = |
334 | } | 411 | cx231xx_read_i2c_data(dev, |
335 | 412 | Colibri_DEVICE_ADDRESS, | |
336 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 413 | SUP_BLK_PWRDN, 2, |
337 | ADC_PWRDN_CLAMP_CH1, 2, 0x00, 1); | 414 | &colibri_power_status, |
338 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 415 | 1); |
339 | ADC_PWRDN_CLAMP_CH2, 2, 0x00, 1); | 416 | if (status < 0) |
340 | status = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 417 | break; |
341 | ADC_PWRDN_CLAMP_CH3, 2, 0x40, 1); | 418 | } |
342 | } | 419 | |
343 | else { | 420 | status = |
344 | cx231xx_info("Invalid AV mode input\n"); | 421 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
345 | status = -1; | 422 | ADC_PWRDN_CLAMP_CH1, 2, 0x40, |
346 | } | 423 | 1); |
347 | } /* switch */ | 424 | status = |
348 | 425 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | |
349 | return status; | 426 | ADC_PWRDN_CLAMP_CH2, 2, 0x40, |
427 | 1); | ||
428 | status = | ||
429 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
430 | ADC_PWRDN_CLAMP_CH3, 2, 0x00, | ||
431 | 1); | ||
432 | } else if (avmode == POLARIS_AVMODE_DIGITAL) { | ||
433 | status = | ||
434 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
435 | ADC_PWRDN_CLAMP_CH1, 2, 0x70, | ||
436 | 1); | ||
437 | status = | ||
438 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
439 | ADC_PWRDN_CLAMP_CH2, 2, 0x70, | ||
440 | 1); | ||
441 | status = | ||
442 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
443 | ADC_PWRDN_CLAMP_CH3, 2, 0x70, | ||
444 | 1); | ||
445 | |||
446 | status = | ||
447 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
448 | SUP_BLK_PWRDN, 2, | ||
449 | &colibri_power_status, 1); | ||
450 | colibri_power_status |= 0x07; | ||
451 | status = | ||
452 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
453 | SUP_BLK_PWRDN, 2, | ||
454 | colibri_power_status, 1); | ||
455 | } else if (avmode == POLARIS_AVMODE_ENXTERNAL_AV) { | ||
456 | while (colibri_power_status != 0x18) { | ||
457 | status = | ||
458 | cx231xx_write_i2c_data(dev, | ||
459 | Colibri_DEVICE_ADDRESS, | ||
460 | SUP_BLK_PWRDN, 2, | ||
461 | 0x18, 1); | ||
462 | status = | ||
463 | cx231xx_read_i2c_data(dev, | ||
464 | Colibri_DEVICE_ADDRESS, | ||
465 | SUP_BLK_PWRDN, 2, | ||
466 | &colibri_power_status, | ||
467 | 1); | ||
468 | if (status < 0) | ||
469 | break; | ||
470 | } | ||
471 | |||
472 | status = | ||
473 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
474 | ADC_PWRDN_CLAMP_CH1, 2, 0x00, | ||
475 | 1); | ||
476 | status = | ||
477 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
478 | ADC_PWRDN_CLAMP_CH2, 2, 0x00, | ||
479 | 1); | ||
480 | status = | ||
481 | cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, | ||
482 | ADC_PWRDN_CLAMP_CH3, 2, 0x40, | ||
483 | 1); | ||
484 | } else { | ||
485 | cx231xx_info("Invalid AV mode input\n"); | ||
486 | status = -1; | ||
487 | } | ||
488 | } /* switch */ | ||
489 | |||
490 | return status; | ||
350 | } | 491 | } |
351 | 492 | ||
352 | int cx231xx_colibri_adjust_ref_count(struct cx231xx *dev, u32 video_input) | 493 | int cx231xx_colibri_adjust_ref_count(struct cx231xx *dev, u32 video_input) |
353 | { | 494 | { |
354 | u32 input_mode = 0; | 495 | u32 input_mode = 0; |
355 | u32 ntf_mode = 0; | 496 | u32 ntf_mode = 0; |
356 | int status = 0; | 497 | int status = 0; |
357 | 498 | ||
358 | dev->video_input = video_input; | 499 | dev->video_input = video_input; |
359 | 500 | ||
360 | if(video_input == CX231XX_VMUX_TELEVISION) { | 501 | if (video_input == CX231XX_VMUX_TELEVISION) { |
361 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_INPUT_CH3, 2, &input_mode, 1); | 502 | status = |
362 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 503 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
363 | ADC_NTF_PRECLMP_EN_CH3, 2, &ntf_mode, 1); | 504 | ADC_INPUT_CH3, 2, &input_mode, 1); |
364 | } | 505 | status = |
365 | else { | 506 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
366 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, ADC_INPUT_CH1, 2, &input_mode, 1); | 507 | ADC_NTF_PRECLMP_EN_CH3, 2, &ntf_mode, |
367 | status = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | 508 | 1); |
368 | ADC_NTF_PRECLMP_EN_CH1, 2, &ntf_mode, 1); | 509 | } else { |
369 | } | 510 | status = |
370 | 511 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, | |
371 | input_mode = (ntf_mode & 0x3) | ((input_mode & 0x6) << 1); | 512 | ADC_INPUT_CH1, 2, &input_mode, 1); |
372 | 513 | status = | |
373 | switch(input_mode) | 514 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
374 | { | 515 | ADC_NTF_PRECLMP_EN_CH1, 2, &ntf_mode, |
375 | case SINGLE_ENDED: | 516 | 1); |
376 | dev->colibri_ref_count = 0x23C; | 517 | } |
377 | break; | ||
378 | case LOW_IF: | ||
379 | dev->colibri_ref_count = 0x24C; | ||
380 | break; | ||
381 | case EU_IF: | ||
382 | dev->colibri_ref_count = 0x258; | ||
383 | break; | ||
384 | case US_IF: | ||
385 | dev->colibri_ref_count = 0x260; | ||
386 | break; | ||
387 | default: | ||
388 | break; | ||
389 | } | ||
390 | |||
391 | status = cx231xx_colibri_init_super_block(dev, dev->colibri_ref_count); | ||
392 | |||
393 | return status; | ||
394 | } | ||
395 | 518 | ||
519 | input_mode = (ntf_mode & 0x3) | ((input_mode & 0x6) << 1); | ||
520 | |||
521 | switch (input_mode) { | ||
522 | case SINGLE_ENDED: | ||
523 | dev->colibri_ref_count = 0x23C; | ||
524 | break; | ||
525 | case LOW_IF: | ||
526 | dev->colibri_ref_count = 0x24C; | ||
527 | break; | ||
528 | case EU_IF: | ||
529 | dev->colibri_ref_count = 0x258; | ||
530 | break; | ||
531 | case US_IF: | ||
532 | dev->colibri_ref_count = 0x260; | ||
533 | break; | ||
534 | default: | ||
535 | break; | ||
536 | } | ||
537 | |||
538 | status = cx231xx_colibri_init_super_block(dev, dev->colibri_ref_count); | ||
396 | 539 | ||
540 | return status; | ||
541 | } | ||
397 | 542 | ||
398 | /************************************************************************************* | 543 | /************************************************************************************* |
399 | * V I D E O / A U D I O D E C O D E R C O N T R O L functions * | 544 | * V I D E O / A U D I O D E C O D E R C O N T R O L functions * |
400 | *************************************************************************************/ | 545 | *************************************************************************************/ |
401 | int cx231xx_set_video_input_mux(struct cx231xx *dev, u8 input) | 546 | int cx231xx_set_video_input_mux(struct cx231xx *dev, u8 input) |
402 | { | 547 | { |
403 | int status = 0; | 548 | int status = 0; |
404 | 549 | ||
405 | switch(INPUT(input)->type) { | 550 | switch (INPUT(input)->type) { |
406 | case CX231XX_VMUX_COMPOSITE1: | 551 | case CX231XX_VMUX_COMPOSITE1: |
407 | case CX231XX_VMUX_SVIDEO: | 552 | case CX231XX_VMUX_SVIDEO: |
408 | if((dev->current_pcb_config.type == USB_BUS_POWER) && | 553 | if ((dev->current_pcb_config.type == USB_BUS_POWER) && |
409 | (dev->power_mode != POLARIS_AVMODE_ENXTERNAL_AV)) { | 554 | (dev->power_mode != POLARIS_AVMODE_ENXTERNAL_AV)) { |
410 | status = cx231xx_set_power_mode(dev, POLARIS_AVMODE_ENXTERNAL_AV); /* External AV */ | 555 | status = cx231xx_set_power_mode(dev, POLARIS_AVMODE_ENXTERNAL_AV); /* External AV */ |
411 | if (status < 0) { | 556 | if (status < 0) { |
412 | cx231xx_errdev("%s: cx231xx_set_power_mode : Failed to set Power - errCode [%d]!\n", | 557 | cx231xx_errdev |
413 | __func__, status); | 558 | ("%s: cx231xx_set_power_mode : Failed to set Power - errCode [%d]!\n", |
414 | return status; | 559 | __func__, status); |
415 | } | 560 | return status; |
416 | } | 561 | } |
417 | status = cx231xx_set_decoder_video_input(dev, INPUT(input)->type, INPUT(input)->vmux); | 562 | } |
418 | break; | 563 | status = |
419 | case CX231XX_VMUX_TELEVISION: | 564 | cx231xx_set_decoder_video_input(dev, INPUT(input)->type, |
420 | case CX231XX_VMUX_CABLE: | 565 | INPUT(input)->vmux); |
421 | if((dev->current_pcb_config.type == USB_BUS_POWER) && | 566 | break; |
422 | (dev->power_mode != POLARIS_AVMODE_ANALOGT_TV)) { | 567 | case CX231XX_VMUX_TELEVISION: |
423 | status = cx231xx_set_power_mode(dev, POLARIS_AVMODE_ANALOGT_TV); /* Tuner */ | 568 | case CX231XX_VMUX_CABLE: |
424 | if (status < 0) { | 569 | if ((dev->current_pcb_config.type == USB_BUS_POWER) && |
425 | cx231xx_errdev("%s: cx231xx_set_power_mode : Failed to set Power - errCode [%d]!\n", | 570 | (dev->power_mode != POLARIS_AVMODE_ANALOGT_TV)) { |
426 | __func__, status); | 571 | status = cx231xx_set_power_mode(dev, POLARIS_AVMODE_ANALOGT_TV); /* Tuner */ |
427 | return status; | 572 | if (status < 0) { |
428 | } | 573 | cx231xx_errdev |
429 | } | 574 | ("%s: cx231xx_set_power_mode : Failed to set Power - errCode [%d]!\n", |
430 | status = cx231xx_set_decoder_video_input(dev, CX231XX_VMUX_COMPOSITE1, INPUT(input)->vmux); | 575 | __func__, status); |
431 | break; | 576 | return status; |
432 | default: | 577 | } |
433 | cx231xx_errdev("%s: cx231xx_set_power_mode : Unknown Input %d !\n", | 578 | } |
434 | __func__, INPUT(input)->type); | 579 | status = |
435 | break; | 580 | cx231xx_set_decoder_video_input(dev, |
436 | } | 581 | CX231XX_VMUX_COMPOSITE1, |
437 | 582 | INPUT(input)->vmux); | |
438 | /* save the selection */ | 583 | break; |
439 | dev->video_input = input; | 584 | default: |
440 | 585 | cx231xx_errdev | |
441 | return status; | 586 | ("%s: cx231xx_set_power_mode : Unknown Input %d !\n", |
587 | __func__, INPUT(input)->type); | ||
588 | break; | ||
589 | } | ||
590 | |||
591 | /* save the selection */ | ||
592 | dev->video_input = input; | ||
593 | |||
594 | return status; | ||
442 | } | 595 | } |
443 | 596 | ||
444 | int cx231xx_set_decoder_video_input(struct cx231xx *dev, u8 pin_type, u8 input) | 597 | int cx231xx_set_decoder_video_input(struct cx231xx *dev, u8 pin_type, u8 input) |
445 | { | 598 | { |
446 | int status = 0; | 599 | int status = 0; |
447 | u32 value = 0; | 600 | u32 value = 0; |
448 | 601 | ||
449 | if(pin_type != dev->video_input) { | 602 | if (pin_type != dev->video_input) { |
450 | status = cx231xx_colibri_adjust_ref_count(dev, pin_type); | 603 | status = cx231xx_colibri_adjust_ref_count(dev, pin_type); |
451 | if(status < 0 ) { | 604 | if (status < 0) { |
452 | cx231xx_errdev("%s: cx231xx_colibri_adjust_ref_count :Failed to set Colibri input mux - errCode [%d]!\n", | 605 | cx231xx_errdev |
453 | __func__, status); | 606 | ("%s: cx231xx_colibri_adjust_ref_count :Failed to set Colibri input mux - errCode [%d]!\n", |
454 | return status; | 607 | __func__, status); |
455 | } | 608 | return status; |
456 | } | 609 | } |
457 | 610 | } | |
458 | /* call colibri block to set video inputs */ | ||
459 | status = cx231xx_colibri_set_input_mux(dev, input); | ||
460 | if(status < 0 ) { | ||
461 | cx231xx_errdev("%s: cx231xx_colibri_set_input_mux :Failed to set Colibri input mux - errCode [%d]!\n", | ||
462 | __func__, status); | ||
463 | return status; | ||
464 | } | ||
465 | |||
466 | switch(pin_type) { | ||
467 | case CX231XX_VMUX_COMPOSITE1: | ||
468 | { | ||
469 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, &value, 4); | ||
470 | value |= (0<<13)|(1<<4); | ||
471 | value &= ~(1<<5); | ||
472 | |||
473 | value &= (~(0x1FF8000)); /* set [24:23] [22:15] to 0 */ | ||
474 | value |= 0x1000000; /* set FUNC_MODE[24:23] = 2 IF_MOD[22:15] = 0 */ | ||
475 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, value, 4); | ||
476 | |||
477 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, OUT_CTRL1, 2, &value, 4); | ||
478 | value |= (1<<7); | ||
479 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, OUT_CTRL1, 2, value, 4); | ||
480 | |||
481 | /* Set vip 1.1 output mode */ | ||
482 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
483 | OUT_CTRL1, FLD_OUT_MODE, OUT_MODE_VIP11); | ||
484 | |||
485 | /* Tell DIF object to go to baseband mode */ | ||
486 | status = cx231xx_dif_set_standard(dev, DIF_USE_BASEBAND); | ||
487 | if (status < 0) { | ||
488 | cx231xx_errdev("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | ||
489 | __func__, status); | ||
490 | return status; | ||
491 | } | ||
492 | |||
493 | /* Read the DFE_CTRL1 register */ | ||
494 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, &value, 4); | ||
495 | |||
496 | /* enable the VBI_GATE_EN */ | ||
497 | value |= FLD_VBI_GATE_EN; | ||
498 | |||
499 | /* Enable the auto-VGA enable */ | ||
500 | value |= FLD_VGA_AUTO_EN; | ||
501 | |||
502 | /* Write it back */ | ||
503 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, value, 4); | ||
504 | |||
505 | /* Disable auto config of registers */ | ||
506 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
507 | MODE_CTRL, FLD_ACFG_DIS, cx231xx_set_field(FLD_ACFG_DIS, 1)); | ||
508 | |||
509 | /* Set CVBS input mode */ | ||
510 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
511 | MODE_CTRL, FLD_INPUT_MODE, | ||
512 | cx231xx_set_field(FLD_INPUT_MODE, INPUT_MODE_CVBS_0)); | ||
513 | } | ||
514 | break; | ||
515 | case CX231XX_VMUX_SVIDEO: | ||
516 | { | ||
517 | /* Disable the use of DIF */ | ||
518 | |||
519 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, &value, 4); | ||
520 | |||
521 | value &= (~(0x1FF8000)); /* set [24:23] [22:15] to 0 */ | ||
522 | value |= 0x1000010; /* set FUNC_MODE[24:23] = 2 | ||
523 | IF_MOD[22:15] = 0 DCR_BYP_CH2[4:4] = 1; */ | ||
524 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, value, 4); | ||
525 | |||
526 | /* Tell DIF object to go to baseband mode */ | ||
527 | status = cx231xx_dif_set_standard(dev, DIF_USE_BASEBAND); | ||
528 | if (status < 0) { | ||
529 | cx231xx_errdev("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | ||
530 | __func__, status); | ||
531 | return status; | ||
532 | } | ||
533 | |||
534 | /* Read the DFE_CTRL1 register */ | ||
535 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, &value, 4); | ||
536 | |||
537 | /* enable the VBI_GATE_EN */ | ||
538 | value |= FLD_VBI_GATE_EN; | ||
539 | |||
540 | /* Enable the auto-VGA enable */ | ||
541 | value |= FLD_VGA_AUTO_EN; | ||
542 | |||
543 | /* Write it back */ | ||
544 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, value, 4); | ||
545 | |||
546 | /* Disable auto config of registers */ | ||
547 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
548 | MODE_CTRL, FLD_ACFG_DIS, cx231xx_set_field(FLD_ACFG_DIS, 1)); | ||
549 | |||
550 | /* Set YC input mode */ | ||
551 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
552 | MODE_CTRL, FLD_INPUT_MODE, | ||
553 | cx231xx_set_field(FLD_INPUT_MODE, INPUT_MODE_YC_1)); | ||
554 | |||
555 | /* Chroma to ADC2 */ | ||
556 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, &value, 4); | ||
557 | value |= FLD_CHROMA_IN_SEL; /* set the chroma in select */ | ||
558 | |||
559 | /* Clear VGA_SEL_CH2 and VGA_SEL_CH3 (bits 7 and 8) This sets them to use video | ||
560 | rather than audio. Only one of the two will be in use. */ | ||
561 | value &= ~(FLD_VGA_SEL_CH2 | FLD_VGA_SEL_CH3); | ||
562 | |||
563 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, value, 4); | ||
564 | |||
565 | status = cx231xx_colibri_set_mode(dev, AFE_MODE_BASEBAND); | ||
566 | } | ||
567 | break; | ||
568 | case CX231XX_VMUX_TELEVISION: | ||
569 | case CX231XX_VMUX_CABLE: | ||
570 | default: | ||
571 | { | ||
572 | switch(dev->model) { | ||
573 | case CX231XX_BOARD_CNXT_RDE_250: | ||
574 | case CX231XX_BOARD_CNXT_RDU_250: | ||
575 | { | ||
576 | /* Disable the use of DIF */ | ||
577 | |||
578 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, &value, 4); | ||
579 | value |= (0<<13)|(1<<4); | ||
580 | value &= ~(1<<5); | ||
581 | |||
582 | value &= (~(0x1FF8000)); /* set [24:23] [22:15] to 0 */ | ||
583 | value |= 0x1000000; /* set FUNC_MODE[24:23] = 2 IF_MOD[22:15] = 0 */ | ||
584 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, value, 4); | ||
585 | |||
586 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, OUT_CTRL1, 2, &value, 4); | ||
587 | value |= (1<<7); | ||
588 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, OUT_CTRL1, 2, value, 4); | ||
589 | |||
590 | /* Set vip 1.1 output mode */ | ||
591 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
592 | OUT_CTRL1, FLD_OUT_MODE, OUT_MODE_VIP11); | ||
593 | |||
594 | /* Tell DIF object to go to baseband mode */ | ||
595 | status = cx231xx_dif_set_standard(dev, DIF_USE_BASEBAND); | ||
596 | if (status < 0) { | ||
597 | cx231xx_errdev("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | ||
598 | __func__, status); | ||
599 | return status; | ||
600 | } | ||
601 | |||
602 | /* Read the DFE_CTRL1 register */ | ||
603 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, &value, 4); | ||
604 | |||
605 | /* enable the VBI_GATE_EN */ | ||
606 | value |= FLD_VBI_GATE_EN; | ||
607 | |||
608 | /* Enable the auto-VGA enable */ | ||
609 | value |= FLD_VGA_AUTO_EN; | ||
610 | |||
611 | /* Write it back */ | ||
612 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, value, 4); | ||
613 | |||
614 | /* Disable auto config of registers */ | ||
615 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
616 | MODE_CTRL, FLD_ACFG_DIS, cx231xx_set_field(FLD_ACFG_DIS, 1)); | ||
617 | |||
618 | /* Set CVBS input mode */ | ||
619 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
620 | MODE_CTRL, FLD_INPUT_MODE, | ||
621 | cx231xx_set_field(FLD_INPUT_MODE, INPUT_MODE_CVBS_0)); | ||
622 | } | ||
623 | break; | ||
624 | default: | ||
625 | { | ||
626 | /* Enable the DIF for the tuner */ | ||
627 | |||
628 | /* Reinitialize the DIF */ | ||
629 | status = cx231xx_dif_set_standard(dev, dev->norm); | ||
630 | if (status < 0) { | ||
631 | cx231xx_errdev("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | ||
632 | __func__, status); | ||
633 | return status; | ||
634 | } | ||
635 | |||
636 | /* Make sure bypass is cleared */ | ||
637 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_MISC_CTRL, 2, &value, 4); | ||
638 | |||
639 | /* Clear the bypass bit */ | ||
640 | value &= ~FLD_DIF_DIF_BYPASS; | ||
641 | |||
642 | /* Enable the use of the DIF block */ | ||
643 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_MISC_CTRL, 2, value, 4); | ||
644 | |||
645 | /* Read the DFE_CTRL1 register */ | ||
646 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, &value, 4); | ||
647 | |||
648 | /* Disable the VBI_GATE_EN */ | ||
649 | value &= ~FLD_VBI_GATE_EN; | ||
650 | |||
651 | /* Enable the auto-VGA enable, AGC, and set the skip count to 2 */ | ||
652 | value |= FLD_VGA_AUTO_EN | FLD_AGC_AUTO_EN | 0x00200000; | ||
653 | |||
654 | /* Write it back */ | ||
655 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, value, 4); | ||
656 | |||
657 | /* Wait 15 ms */ | ||
658 | msleep(1); | ||
659 | |||
660 | /* Disable the auto-VGA enable AGC */ | ||
661 | value &= ~(FLD_VGA_AUTO_EN); | ||
662 | |||
663 | /* Write it back */ | ||
664 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL1, 2, value, 4); | ||
665 | |||
666 | /* Enable Polaris B0 AGC output */ | ||
667 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PIN_CTRL, 2, &value, 4); | ||
668 | value |=(FLD_OEF_AGC_RF)|(FLD_OEF_AGC_IFVGA)|(FLD_OEF_AGC_IF); | ||
669 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PIN_CTRL, 2, value, 4); | ||
670 | |||
671 | /* Set vip 1.1 output mode */ | ||
672 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
673 | OUT_CTRL1, FLD_OUT_MODE, OUT_MODE_VIP11); | ||
674 | |||
675 | /* Disable auto config of registers */ | ||
676 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
677 | MODE_CTRL, FLD_ACFG_DIS, cx231xx_set_field(FLD_ACFG_DIS, 1)); | ||
678 | |||
679 | /* Set CVBS input mode */ | ||
680 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
681 | MODE_CTRL, FLD_INPUT_MODE, | ||
682 | cx231xx_set_field(FLD_INPUT_MODE, INPUT_MODE_CVBS_0)); | ||
683 | |||
684 | /* Set some bits in AFE_CTRL so that channel 2 or 3 is ready to receive audio */ | ||
685 | /* Clear clamp for channels 2 and 3 (bit 16-17) */ | ||
686 | /* Clear droop comp (bit 19-20) */ | ||
687 | /* Set VGA_SEL (for audio control) (bit 7-8) */ | ||
688 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, &value, 4); | ||
689 | |||
690 | value |= FLD_VGA_SEL_CH3 | FLD_VGA_SEL_CH2; | ||
691 | |||
692 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AFE_CTRL, 2, value, 4); | ||
693 | } | ||
694 | break; | ||
695 | |||
696 | } | ||
697 | } | ||
698 | break; | ||
699 | } | ||
700 | 611 | ||
701 | /* Set raw VBI mode */ | 612 | /* call colibri block to set video inputs */ |
702 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 613 | status = cx231xx_colibri_set_input_mux(dev, input); |
703 | OUT_CTRL1, FLD_VBIHACTRAW_EN, | 614 | if (status < 0) { |
704 | cx231xx_set_field(FLD_VBIHACTRAW_EN, 1)); | 615 | cx231xx_errdev |
705 | 616 | ("%s: cx231xx_colibri_set_input_mux :Failed to set Colibri input mux - errCode [%d]!\n", | |
706 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, OUT_CTRL1, 2, &value, 4); | 617 | __func__, status); |
707 | if(value & 0x02) { | 618 | return status; |
708 | value |=(1<<19); | 619 | } |
709 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, OUT_CTRL1, 2, value, 4); | 620 | |
710 | } | 621 | switch (pin_type) { |
711 | 622 | case CX231XX_VMUX_COMPOSITE1: | |
712 | return status; | 623 | { |
624 | status = | ||
625 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
626 | AFE_CTRL, 2, &value, 4); | ||
627 | value |= (0 << 13) | (1 << 4); | ||
628 | value &= ~(1 << 5); | ||
629 | |||
630 | value &= (~(0x1FF8000)); /* set [24:23] [22:15] to 0 */ | ||
631 | value |= 0x1000000; /* set FUNC_MODE[24:23] = 2 IF_MOD[22:15] = 0 */ | ||
632 | status = | ||
633 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
634 | AFE_CTRL, 2, value, 4); | ||
635 | |||
636 | status = | ||
637 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
638 | OUT_CTRL1, 2, &value, 4); | ||
639 | value |= (1 << 7); | ||
640 | status = | ||
641 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
642 | OUT_CTRL1, 2, value, 4); | ||
643 | |||
644 | /* Set vip 1.1 output mode */ | ||
645 | status = | ||
646 | cx231xx_read_modify_write_i2c_dword(dev, | ||
647 | HAMMERHEAD_I2C_ADDRESS, | ||
648 | OUT_CTRL1, | ||
649 | FLD_OUT_MODE, | ||
650 | OUT_MODE_VIP11); | ||
651 | |||
652 | /* Tell DIF object to go to baseband mode */ | ||
653 | status = | ||
654 | cx231xx_dif_set_standard(dev, DIF_USE_BASEBAND); | ||
655 | if (status < 0) { | ||
656 | cx231xx_errdev | ||
657 | ("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | ||
658 | __func__, status); | ||
659 | return status; | ||
660 | } | ||
661 | |||
662 | /* Read the DFE_CTRL1 register */ | ||
663 | status = | ||
664 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
665 | DFE_CTRL1, 2, &value, 4); | ||
666 | |||
667 | /* enable the VBI_GATE_EN */ | ||
668 | value |= FLD_VBI_GATE_EN; | ||
669 | |||
670 | /* Enable the auto-VGA enable */ | ||
671 | value |= FLD_VGA_AUTO_EN; | ||
672 | |||
673 | /* Write it back */ | ||
674 | status = | ||
675 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
676 | DFE_CTRL1, 2, value, 4); | ||
677 | |||
678 | /* Disable auto config of registers */ | ||
679 | status = | ||
680 | cx231xx_read_modify_write_i2c_dword(dev, | ||
681 | HAMMERHEAD_I2C_ADDRESS, | ||
682 | MODE_CTRL, | ||
683 | FLD_ACFG_DIS, | ||
684 | cx231xx_set_field | ||
685 | (FLD_ACFG_DIS, | ||
686 | 1)); | ||
687 | |||
688 | /* Set CVBS input mode */ | ||
689 | status = | ||
690 | cx231xx_read_modify_write_i2c_dword(dev, | ||
691 | HAMMERHEAD_I2C_ADDRESS, | ||
692 | MODE_CTRL, | ||
693 | FLD_INPUT_MODE, | ||
694 | cx231xx_set_field | ||
695 | (FLD_INPUT_MODE, | ||
696 | INPUT_MODE_CVBS_0)); | ||
697 | } | ||
698 | break; | ||
699 | case CX231XX_VMUX_SVIDEO: | ||
700 | { | ||
701 | /* Disable the use of DIF */ | ||
702 | |||
703 | status = | ||
704 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
705 | AFE_CTRL, 2, &value, 4); | ||
706 | |||
707 | value &= (~(0x1FF8000)); /* set [24:23] [22:15] to 0 */ | ||
708 | value |= 0x1000010; /* set FUNC_MODE[24:23] = 2 | ||
709 | IF_MOD[22:15] = 0 DCR_BYP_CH2[4:4] = 1; */ | ||
710 | status = | ||
711 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
712 | AFE_CTRL, 2, value, 4); | ||
713 | |||
714 | /* Tell DIF object to go to baseband mode */ | ||
715 | status = | ||
716 | cx231xx_dif_set_standard(dev, DIF_USE_BASEBAND); | ||
717 | if (status < 0) { | ||
718 | cx231xx_errdev | ||
719 | ("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | ||
720 | __func__, status); | ||
721 | return status; | ||
722 | } | ||
723 | |||
724 | /* Read the DFE_CTRL1 register */ | ||
725 | status = | ||
726 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
727 | DFE_CTRL1, 2, &value, 4); | ||
728 | |||
729 | /* enable the VBI_GATE_EN */ | ||
730 | value |= FLD_VBI_GATE_EN; | ||
731 | |||
732 | /* Enable the auto-VGA enable */ | ||
733 | value |= FLD_VGA_AUTO_EN; | ||
734 | |||
735 | /* Write it back */ | ||
736 | status = | ||
737 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
738 | DFE_CTRL1, 2, value, 4); | ||
739 | |||
740 | /* Disable auto config of registers */ | ||
741 | status = | ||
742 | cx231xx_read_modify_write_i2c_dword(dev, | ||
743 | HAMMERHEAD_I2C_ADDRESS, | ||
744 | MODE_CTRL, | ||
745 | FLD_ACFG_DIS, | ||
746 | cx231xx_set_field | ||
747 | (FLD_ACFG_DIS, | ||
748 | 1)); | ||
749 | |||
750 | /* Set YC input mode */ | ||
751 | status = | ||
752 | cx231xx_read_modify_write_i2c_dword(dev, | ||
753 | HAMMERHEAD_I2C_ADDRESS, | ||
754 | MODE_CTRL, | ||
755 | FLD_INPUT_MODE, | ||
756 | cx231xx_set_field | ||
757 | (FLD_INPUT_MODE, | ||
758 | INPUT_MODE_YC_1)); | ||
759 | |||
760 | /* Chroma to ADC2 */ | ||
761 | status = | ||
762 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
763 | AFE_CTRL, 2, &value, 4); | ||
764 | value |= FLD_CHROMA_IN_SEL; /* set the chroma in select */ | ||
765 | |||
766 | /* Clear VGA_SEL_CH2 and VGA_SEL_CH3 (bits 7 and 8) This sets them to use video | ||
767 | rather than audio. Only one of the two will be in use. */ | ||
768 | value &= ~(FLD_VGA_SEL_CH2 | FLD_VGA_SEL_CH3); | ||
769 | |||
770 | status = | ||
771 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
772 | AFE_CTRL, 2, value, 4); | ||
773 | |||
774 | status = | ||
775 | cx231xx_colibri_set_mode(dev, AFE_MODE_BASEBAND); | ||
776 | } | ||
777 | break; | ||
778 | case CX231XX_VMUX_TELEVISION: | ||
779 | case CX231XX_VMUX_CABLE: | ||
780 | default: | ||
781 | { | ||
782 | switch (dev->model) { | ||
783 | case CX231XX_BOARD_CNXT_RDE_250: | ||
784 | case CX231XX_BOARD_CNXT_RDU_250: | ||
785 | { | ||
786 | /* Disable the use of DIF */ | ||
787 | |||
788 | status = | ||
789 | cx231xx_read_i2c_data(dev, | ||
790 | HAMMERHEAD_I2C_ADDRESS, | ||
791 | AFE_CTRL, 2, | ||
792 | &value, 4); | ||
793 | value |= (0 << 13) | (1 << 4); | ||
794 | value &= ~(1 << 5); | ||
795 | |||
796 | value &= (~(0x1FF8000)); /* set [24:23] [22:15] to 0 */ | ||
797 | value |= 0x1000000; /* set FUNC_MODE[24:23] = 2 IF_MOD[22:15] = 0 */ | ||
798 | status = | ||
799 | cx231xx_write_i2c_data(dev, | ||
800 | HAMMERHEAD_I2C_ADDRESS, | ||
801 | AFE_CTRL, 2, | ||
802 | value, 4); | ||
803 | |||
804 | status = | ||
805 | cx231xx_read_i2c_data(dev, | ||
806 | HAMMERHEAD_I2C_ADDRESS, | ||
807 | OUT_CTRL1, 2, | ||
808 | &value, 4); | ||
809 | value |= (1 << 7); | ||
810 | status = | ||
811 | cx231xx_write_i2c_data(dev, | ||
812 | HAMMERHEAD_I2C_ADDRESS, | ||
813 | OUT_CTRL1, 2, | ||
814 | value, 4); | ||
815 | |||
816 | /* Set vip 1.1 output mode */ | ||
817 | status = | ||
818 | cx231xx_read_modify_write_i2c_dword | ||
819 | (dev, HAMMERHEAD_I2C_ADDRESS, | ||
820 | OUT_CTRL1, FLD_OUT_MODE, | ||
821 | OUT_MODE_VIP11); | ||
822 | |||
823 | /* Tell DIF object to go to baseband mode */ | ||
824 | status = | ||
825 | cx231xx_dif_set_standard(dev, | ||
826 | DIF_USE_BASEBAND); | ||
827 | if (status < 0) { | ||
828 | cx231xx_errdev | ||
829 | ("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | ||
830 | __func__, status); | ||
831 | return status; | ||
832 | } | ||
833 | |||
834 | /* Read the DFE_CTRL1 register */ | ||
835 | status = | ||
836 | cx231xx_read_i2c_data(dev, | ||
837 | HAMMERHEAD_I2C_ADDRESS, | ||
838 | DFE_CTRL1, 2, | ||
839 | &value, 4); | ||
840 | |||
841 | /* enable the VBI_GATE_EN */ | ||
842 | value |= FLD_VBI_GATE_EN; | ||
843 | |||
844 | /* Enable the auto-VGA enable */ | ||
845 | value |= FLD_VGA_AUTO_EN; | ||
846 | |||
847 | /* Write it back */ | ||
848 | status = | ||
849 | cx231xx_write_i2c_data(dev, | ||
850 | HAMMERHEAD_I2C_ADDRESS, | ||
851 | DFE_CTRL1, 2, | ||
852 | value, 4); | ||
853 | |||
854 | /* Disable auto config of registers */ | ||
855 | status = | ||
856 | cx231xx_read_modify_write_i2c_dword | ||
857 | (dev, HAMMERHEAD_I2C_ADDRESS, | ||
858 | MODE_CTRL, FLD_ACFG_DIS, | ||
859 | cx231xx_set_field(FLD_ACFG_DIS, | ||
860 | 1)); | ||
861 | |||
862 | /* Set CVBS input mode */ | ||
863 | status = | ||
864 | cx231xx_read_modify_write_i2c_dword | ||
865 | (dev, HAMMERHEAD_I2C_ADDRESS, | ||
866 | MODE_CTRL, FLD_INPUT_MODE, | ||
867 | cx231xx_set_field(FLD_INPUT_MODE, | ||
868 | INPUT_MODE_CVBS_0)); | ||
869 | } | ||
870 | break; | ||
871 | default: | ||
872 | { | ||
873 | /* Enable the DIF for the tuner */ | ||
874 | |||
875 | /* Reinitialize the DIF */ | ||
876 | status = | ||
877 | cx231xx_dif_set_standard(dev, | ||
878 | dev->norm); | ||
879 | if (status < 0) { | ||
880 | cx231xx_errdev | ||
881 | ("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | ||
882 | __func__, status); | ||
883 | return status; | ||
884 | } | ||
885 | |||
886 | /* Make sure bypass is cleared */ | ||
887 | status = | ||
888 | cx231xx_read_i2c_data(dev, | ||
889 | HAMMERHEAD_I2C_ADDRESS, | ||
890 | DIF_MISC_CTRL, | ||
891 | 2, &value, 4); | ||
892 | |||
893 | /* Clear the bypass bit */ | ||
894 | value &= ~FLD_DIF_DIF_BYPASS; | ||
895 | |||
896 | /* Enable the use of the DIF block */ | ||
897 | status = | ||
898 | cx231xx_write_i2c_data(dev, | ||
899 | HAMMERHEAD_I2C_ADDRESS, | ||
900 | DIF_MISC_CTRL, | ||
901 | 2, value, 4); | ||
902 | |||
903 | /* Read the DFE_CTRL1 register */ | ||
904 | status = | ||
905 | cx231xx_read_i2c_data(dev, | ||
906 | HAMMERHEAD_I2C_ADDRESS, | ||
907 | DFE_CTRL1, 2, | ||
908 | &value, 4); | ||
909 | |||
910 | /* Disable the VBI_GATE_EN */ | ||
911 | value &= ~FLD_VBI_GATE_EN; | ||
912 | |||
913 | /* Enable the auto-VGA enable, AGC, and set the skip count to 2 */ | ||
914 | value |= | ||
915 | FLD_VGA_AUTO_EN | FLD_AGC_AUTO_EN | | ||
916 | 0x00200000; | ||
917 | |||
918 | /* Write it back */ | ||
919 | status = | ||
920 | cx231xx_write_i2c_data(dev, | ||
921 | HAMMERHEAD_I2C_ADDRESS, | ||
922 | DFE_CTRL1, 2, | ||
923 | value, 4); | ||
924 | |||
925 | /* Wait 15 ms */ | ||
926 | msleep(1); | ||
927 | |||
928 | /* Disable the auto-VGA enable AGC */ | ||
929 | value &= ~(FLD_VGA_AUTO_EN); | ||
930 | |||
931 | /* Write it back */ | ||
932 | status = | ||
933 | cx231xx_write_i2c_data(dev, | ||
934 | HAMMERHEAD_I2C_ADDRESS, | ||
935 | DFE_CTRL1, 2, | ||
936 | value, 4); | ||
937 | |||
938 | /* Enable Polaris B0 AGC output */ | ||
939 | status = | ||
940 | cx231xx_read_i2c_data(dev, | ||
941 | HAMMERHEAD_I2C_ADDRESS, | ||
942 | PIN_CTRL, 2, | ||
943 | &value, 4); | ||
944 | value |= | ||
945 | (FLD_OEF_AGC_RF) | | ||
946 | (FLD_OEF_AGC_IFVGA) | | ||
947 | (FLD_OEF_AGC_IF); | ||
948 | status = | ||
949 | cx231xx_write_i2c_data(dev, | ||
950 | HAMMERHEAD_I2C_ADDRESS, | ||
951 | PIN_CTRL, 2, | ||
952 | value, 4); | ||
953 | |||
954 | /* Set vip 1.1 output mode */ | ||
955 | status = | ||
956 | cx231xx_read_modify_write_i2c_dword | ||
957 | (dev, HAMMERHEAD_I2C_ADDRESS, | ||
958 | OUT_CTRL1, FLD_OUT_MODE, | ||
959 | OUT_MODE_VIP11); | ||
960 | |||
961 | /* Disable auto config of registers */ | ||
962 | status = | ||
963 | cx231xx_read_modify_write_i2c_dword | ||
964 | (dev, HAMMERHEAD_I2C_ADDRESS, | ||
965 | MODE_CTRL, FLD_ACFG_DIS, | ||
966 | cx231xx_set_field(FLD_ACFG_DIS, | ||
967 | 1)); | ||
968 | |||
969 | /* Set CVBS input mode */ | ||
970 | status = | ||
971 | cx231xx_read_modify_write_i2c_dword | ||
972 | (dev, HAMMERHEAD_I2C_ADDRESS, | ||
973 | MODE_CTRL, FLD_INPUT_MODE, | ||
974 | cx231xx_set_field(FLD_INPUT_MODE, | ||
975 | INPUT_MODE_CVBS_0)); | ||
976 | |||
977 | /* Set some bits in AFE_CTRL so that channel 2 or 3 is ready to receive audio */ | ||
978 | /* Clear clamp for channels 2 and 3 (bit 16-17) */ | ||
979 | /* Clear droop comp (bit 19-20) */ | ||
980 | /* Set VGA_SEL (for audio control) (bit 7-8) */ | ||
981 | status = | ||
982 | cx231xx_read_i2c_data(dev, | ||
983 | HAMMERHEAD_I2C_ADDRESS, | ||
984 | AFE_CTRL, 2, | ||
985 | &value, 4); | ||
986 | |||
987 | value |= | ||
988 | FLD_VGA_SEL_CH3 | FLD_VGA_SEL_CH2; | ||
989 | |||
990 | status = | ||
991 | cx231xx_write_i2c_data(dev, | ||
992 | HAMMERHEAD_I2C_ADDRESS, | ||
993 | AFE_CTRL, 2, | ||
994 | value, 4); | ||
995 | } | ||
996 | break; | ||
997 | |||
998 | } | ||
999 | } | ||
1000 | break; | ||
1001 | } | ||
1002 | |||
1003 | /* Set raw VBI mode */ | ||
1004 | status = | ||
1005 | cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1006 | OUT_CTRL1, FLD_VBIHACTRAW_EN, | ||
1007 | cx231xx_set_field | ||
1008 | (FLD_VBIHACTRAW_EN, 1)); | ||
1009 | |||
1010 | status = | ||
1011 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, OUT_CTRL1, 2, | ||
1012 | &value, 4); | ||
1013 | if (value & 0x02) { | ||
1014 | value |= (1 << 19); | ||
1015 | status = | ||
1016 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1017 | OUT_CTRL1, 2, value, 4); | ||
1018 | } | ||
1019 | |||
1020 | return status; | ||
713 | } | 1021 | } |
714 | 1022 | ||
715 | /* | 1023 | /* |
@@ -718,207 +1026,310 @@ int cx231xx_set_decoder_video_input(struct cx231xx *dev, u8 pin_type, u8 input) | |||
718 | */ | 1026 | */ |
719 | int cx231xx_do_mode_ctrl_overrides(struct cx231xx *dev) | 1027 | int cx231xx_do_mode_ctrl_overrides(struct cx231xx *dev) |
720 | { | 1028 | { |
721 | int status = 0; | 1029 | int status = 0; |
722 | 1030 | ||
723 | cx231xx_info("do_mode_ctrl_overrides : 0x%x\n", (unsigned int)dev->norm); | 1031 | cx231xx_info("do_mode_ctrl_overrides : 0x%x\n", |
724 | 1032 | (unsigned int)dev->norm); | |
725 | /* Change the DFE_CTRL3 bp_percent to fix flagging */ | 1033 | |
726 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL3, 2, 0xCD3F0280, 4); | 1034 | /* Change the DFE_CTRL3 bp_percent to fix flagging */ |
727 | 1035 | status = | |
728 | if( dev->norm & (V4L2_STD_NTSC_M | V4L2_STD_NTSC_M_JP | V4L2_STD_PAL_M) ) { | 1036 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DFE_CTRL3, 2, |
729 | cx231xx_info("do_mode_ctrl_overrides NTSC\n"); | 1037 | 0xCD3F0280, 4); |
730 | 1038 | ||
731 | /* Move the close caption lines out of active video, adjust the active video start point */ | 1039 | if (dev->norm & (V4L2_STD_NTSC_M | V4L2_STD_NTSC_M_JP | V4L2_STD_PAL_M)) { |
732 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1040 | cx231xx_info("do_mode_ctrl_overrides NTSC\n"); |
733 | VERT_TIM_CTRL, FLD_VBLANK_CNT,0x18); | 1041 | |
734 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1042 | /* Move the close caption lines out of active video, adjust the active video start point */ |
735 | VERT_TIM_CTRL, FLD_VACTIVE_CNT,0x1E6000); | 1043 | status = |
736 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1044 | cx231xx_read_modify_write_i2c_dword(dev, |
737 | VERT_TIM_CTRL, FLD_V656BLANK_CNT,0x1E000000); | 1045 | HAMMERHEAD_I2C_ADDRESS, |
738 | 1046 | VERT_TIM_CTRL, | |
739 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1047 | FLD_VBLANK_CNT, 0x18); |
740 | HORIZ_TIM_CTRL, FLD_HBLANK_CNT, | 1048 | status = |
741 | cx231xx_set_field(FLD_HBLANK_CNT, 0x79)); | 1049 | cx231xx_read_modify_write_i2c_dword(dev, |
742 | } else if ( dev->norm & ( V4L2_STD_PAL_B | V4L2_STD_PAL_G | V4L2_STD_PAL_D | | 1050 | HAMMERHEAD_I2C_ADDRESS, |
743 | V4L2_STD_PAL_I | V4L2_STD_PAL_N | V4L2_STD_PAL_Nc) ) { | 1051 | VERT_TIM_CTRL, |
744 | cx231xx_info("do_mode_ctrl_overrides PAL\n"); | 1052 | FLD_VACTIVE_CNT, |
745 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1053 | 0x1E6000); |
746 | VERT_TIM_CTRL, FLD_VBLANK_CNT,0x24); | 1054 | status = |
747 | /* Adjust the active video horizontal start point */ | 1055 | cx231xx_read_modify_write_i2c_dword(dev, |
748 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1056 | HAMMERHEAD_I2C_ADDRESS, |
749 | HORIZ_TIM_CTRL, FLD_HBLANK_CNT, | 1057 | VERT_TIM_CTRL, |
750 | cx231xx_set_field(FLD_HBLANK_CNT, 0x85)); | 1058 | FLD_V656BLANK_CNT, |
751 | } else if (dev->norm & ( V4L2_STD_SECAM_B | V4L2_STD_SECAM_D | V4L2_STD_SECAM_G | | 1059 | 0x1E000000); |
752 | V4L2_STD_SECAM_K | V4L2_STD_SECAM_K1 | V4L2_STD_SECAM_L | | 1060 | |
753 | V4L2_STD_SECAM_LC) ) { | 1061 | status = |
754 | cx231xx_info("do_mode_ctrl_overrides SECAM\n"); | 1062 | cx231xx_read_modify_write_i2c_dword(dev, |
755 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1063 | HAMMERHEAD_I2C_ADDRESS, |
756 | VERT_TIM_CTRL, FLD_VBLANK_CNT,0x24); | 1064 | HORIZ_TIM_CTRL, |
757 | /* Adjust the active video horizontal start point */ | 1065 | FLD_HBLANK_CNT, |
758 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1066 | cx231xx_set_field |
759 | HORIZ_TIM_CTRL, FLD_HBLANK_CNT, | 1067 | (FLD_HBLANK_CNT, 0x79)); |
760 | cx231xx_set_field(FLD_HBLANK_CNT, 0x85)); | 1068 | } else if (dev-> |
761 | } | 1069 | norm & (V4L2_STD_PAL_B | V4L2_STD_PAL_G | V4L2_STD_PAL_D | |
762 | 1070 | V4L2_STD_PAL_I | V4L2_STD_PAL_N | V4L2_STD_PAL_Nc)) { | |
763 | return status; | 1071 | cx231xx_info("do_mode_ctrl_overrides PAL\n"); |
1072 | status = | ||
1073 | cx231xx_read_modify_write_i2c_dword(dev, | ||
1074 | HAMMERHEAD_I2C_ADDRESS, | ||
1075 | VERT_TIM_CTRL, | ||
1076 | FLD_VBLANK_CNT, 0x24); | ||
1077 | /* Adjust the active video horizontal start point */ | ||
1078 | status = | ||
1079 | cx231xx_read_modify_write_i2c_dword(dev, | ||
1080 | HAMMERHEAD_I2C_ADDRESS, | ||
1081 | HORIZ_TIM_CTRL, | ||
1082 | FLD_HBLANK_CNT, | ||
1083 | cx231xx_set_field | ||
1084 | (FLD_HBLANK_CNT, 0x85)); | ||
1085 | } else if (dev-> | ||
1086 | norm & (V4L2_STD_SECAM_B | V4L2_STD_SECAM_D | | ||
1087 | V4L2_STD_SECAM_G | V4L2_STD_SECAM_K | | ||
1088 | V4L2_STD_SECAM_K1 | V4L2_STD_SECAM_L | | ||
1089 | V4L2_STD_SECAM_LC)) { | ||
1090 | cx231xx_info("do_mode_ctrl_overrides SECAM\n"); | ||
1091 | status = | ||
1092 | cx231xx_read_modify_write_i2c_dword(dev, | ||
1093 | HAMMERHEAD_I2C_ADDRESS, | ||
1094 | VERT_TIM_CTRL, | ||
1095 | FLD_VBLANK_CNT, 0x24); | ||
1096 | /* Adjust the active video horizontal start point */ | ||
1097 | status = | ||
1098 | cx231xx_read_modify_write_i2c_dword(dev, | ||
1099 | HAMMERHEAD_I2C_ADDRESS, | ||
1100 | HORIZ_TIM_CTRL, | ||
1101 | FLD_HBLANK_CNT, | ||
1102 | cx231xx_set_field | ||
1103 | (FLD_HBLANK_CNT, 0x85)); | ||
1104 | } | ||
1105 | |||
1106 | return status; | ||
764 | } | 1107 | } |
765 | 1108 | ||
766 | int cx231xx_set_audio_input(struct cx231xx *dev, u8 input) | 1109 | int cx231xx_set_audio_input(struct cx231xx *dev, u8 input) |
767 | { | 1110 | { |
768 | int status = 0; | 1111 | int status = 0; |
769 | enum AUDIO_INPUT ainput = AUDIO_INPUT_LINE; | 1112 | enum AUDIO_INPUT ainput = AUDIO_INPUT_LINE; |
770 | 1113 | ||
771 | switch(INPUT(input)->amux) { | 1114 | switch (INPUT(input)->amux) { |
772 | case CX231XX_AMUX_VIDEO: | 1115 | case CX231XX_AMUX_VIDEO: |
773 | ainput = AUDIO_INPUT_TUNER_TV; | 1116 | ainput = AUDIO_INPUT_TUNER_TV; |
774 | break; | 1117 | break; |
775 | case CX231XX_AMUX_LINE_IN: | 1118 | case CX231XX_AMUX_LINE_IN: |
776 | status = cx231xx_flatiron_set_audio_input(dev, input); | 1119 | status = cx231xx_flatiron_set_audio_input(dev, input); |
777 | ainput = AUDIO_INPUT_LINE; | 1120 | ainput = AUDIO_INPUT_LINE; |
778 | break; | 1121 | break; |
779 | default: | 1122 | default: |
780 | break; | 1123 | break; |
781 | } | 1124 | } |
782 | 1125 | ||
783 | status = cx231xx_set_audio_decoder_input(dev, ainput); | 1126 | status = cx231xx_set_audio_decoder_input(dev, ainput); |
784 | 1127 | ||
785 | return status; | 1128 | return status; |
786 | } | 1129 | } |
787 | 1130 | ||
788 | int cx231xx_set_audio_decoder_input(struct cx231xx *dev, enum AUDIO_INPUT audio_input) | 1131 | int cx231xx_set_audio_decoder_input(struct cx231xx *dev, |
1132 | enum AUDIO_INPUT audio_input) | ||
789 | { | 1133 | { |
790 | u32 dwval; | 1134 | u32 dwval; |
791 | int status; | 1135 | int status; |
792 | u32 gen_ctrl; | 1136 | u32 gen_ctrl; |
793 | u32 value = 0; | 1137 | u32 value = 0; |
794 | 1138 | ||
795 | /* Put it in soft reset */ | 1139 | /* Put it in soft reset */ |
796 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, GENERAL_CTL, 2, &gen_ctrl, 1); | 1140 | status = |
797 | gen_ctrl |= 1; | 1141 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, GENERAL_CTL, 2, |
798 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, GENERAL_CTL, 2, gen_ctrl, 1); | 1142 | &gen_ctrl, 1); |
799 | 1143 | gen_ctrl |= 1; | |
800 | switch(audio_input) | 1144 | status = |
801 | { | 1145 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, GENERAL_CTL, 2, |
802 | case AUDIO_INPUT_LINE: | 1146 | gen_ctrl, 1); |
803 | 1147 | ||
804 | /* setup AUD_IO control from Merlin paralle output */ | 1148 | switch (audio_input) { |
805 | value = cx231xx_set_field(FLD_AUD_CHAN1_SRC, AUD_CHAN_SRC_PARALLEL); | 1149 | case AUDIO_INPUT_LINE: |
806 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AUD_IO_CTRL, 2, value, 4); | 1150 | |
807 | 1151 | /* setup AUD_IO control from Merlin paralle output */ | |
808 | /* setup input to Merlin, SRC2 connect to AC97 | 1152 | value = |
809 | bypass upsample-by-2, slave mode, sony mode, left justify | 1153 | cx231xx_set_field(FLD_AUD_CHAN1_SRC, AUD_CHAN_SRC_PARALLEL); |
810 | adr 091c, dat 01000000 */ | 1154 | status = |
811 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AC97_CTL, 2, &dwval, 4); | 1155 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
812 | 1156 | AUD_IO_CTRL, 2, value, 4); | |
813 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AC97_CTL, 2, (dwval | FLD_AC97_UP2X_BYPASS), 4); | 1157 | |
814 | 1158 | /* setup input to Merlin, SRC2 connect to AC97 | |
815 | /* select the parallel1 and SRC3 */ | 1159 | bypass upsample-by-2, slave mode, sony mode, left justify |
816 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, BAND_OUT_SEL, 2, | 1160 | adr 091c, dat 01000000 */ |
817 | cx231xx_set_field(FLD_SRC3_IN_SEL, 0x0)| | 1161 | status = |
818 | cx231xx_set_field(FLD_SRC3_CLK_SEL, 0x0)| | 1162 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AC97_CTL, |
819 | cx231xx_set_field(FLD_PARALLEL1_SRC_SEL, 0x0), 4); | 1163 | 2, &dwval, 4); |
820 | 1164 | ||
821 | /* unmute all, AC97 in, independence mode | 1165 | status = |
822 | adr 08d0, data 0x00063073 */ | 1166 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
823 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PATH1_CTL1, 2, 0x00063073, 4); | 1167 | AC97_CTL, 2, |
824 | 1168 | (dwval | FLD_AC97_UP2X_BYPASS), 4); | |
825 | /* set AVC maximum threshold, adr 08d4, dat ffff0024 */ | 1169 | |
826 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PATH1_VOL_CTL, 2, &dwval, 4); | 1170 | /* select the parallel1 and SRC3 */ |
827 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PATH1_VOL_CTL, 2, | 1171 | status = |
828 | (dwval | FLD_PATH1_AVC_THRESHOLD), 4); | 1172 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
829 | 1173 | BAND_OUT_SEL, 2, | |
830 | /* set SC maximum threshold, adr 08ec, dat ffffb3a3 */ | 1174 | cx231xx_set_field(FLD_SRC3_IN_SEL, |
831 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PATH1_SC_CTL, 2, &dwval, 4); | 1175 | 0x0) | |
832 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PATH1_SC_CTL, 2, | 1176 | cx231xx_set_field(FLD_SRC3_CLK_SEL, |
833 | (dwval | FLD_PATH1_SC_THRESHOLD), 4); | 1177 | 0x0) | |
834 | break; | 1178 | cx231xx_set_field |
835 | 1179 | (FLD_PARALLEL1_SRC_SEL, 0x0), 4); | |
836 | case AUDIO_INPUT_TUNER_TV: | 1180 | |
837 | default: | 1181 | /* unmute all, AC97 in, independence mode |
838 | 1182 | adr 08d0, data 0x00063073 */ | |
839 | /* Setup SRC sources and clocks */ | 1183 | status = |
840 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, BAND_OUT_SEL, 2, | 1184 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
841 | cx231xx_set_field(FLD_SRC6_IN_SEL, 0x00)| | 1185 | PATH1_CTL1, 2, 0x00063073, 4); |
842 | cx231xx_set_field(FLD_SRC6_CLK_SEL, 0x01)| | 1186 | |
843 | cx231xx_set_field(FLD_SRC5_IN_SEL, 0x00)| | 1187 | /* set AVC maximum threshold, adr 08d4, dat ffff0024 */ |
844 | cx231xx_set_field(FLD_SRC5_CLK_SEL, 0x02)| | 1188 | status = |
845 | cx231xx_set_field(FLD_SRC4_IN_SEL, 0x02)| | 1189 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
846 | cx231xx_set_field(FLD_SRC4_CLK_SEL, 0x03)| | 1190 | PATH1_VOL_CTL, 2, &dwval, 4); |
847 | cx231xx_set_field(FLD_SRC3_IN_SEL, 0x00)| | 1191 | status = |
848 | cx231xx_set_field(FLD_SRC3_CLK_SEL, 0x00)| | 1192 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
849 | cx231xx_set_field(FLD_BASEBAND_BYPASS_CTL, 0x00)| | 1193 | PATH1_VOL_CTL, 2, |
850 | cx231xx_set_field(FLD_AC97_SRC_SEL, 0x03)| | 1194 | (dwval | FLD_PATH1_AVC_THRESHOLD), |
851 | cx231xx_set_field(FLD_I2S_SRC_SEL, 0x00)| | 1195 | 4); |
852 | cx231xx_set_field(FLD_PARALLEL2_SRC_SEL, 0x02)| | 1196 | |
853 | cx231xx_set_field(FLD_PARALLEL1_SRC_SEL, 0x01) , 4); | 1197 | /* set SC maximum threshold, adr 08ec, dat ffffb3a3 */ |
854 | 1198 | status = | |
855 | /* Setup the AUD_IO control */ | 1199 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
856 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, AUD_IO_CTRL, 2, | 1200 | PATH1_SC_CTL, 2, &dwval, 4); |
857 | cx231xx_set_field(FLD_I2S_PORT_DIR, 0x00)| | 1201 | status = |
858 | cx231xx_set_field(FLD_I2S_OUT_SRC, 0x00)| | 1202 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
859 | cx231xx_set_field(FLD_AUD_CHAN3_SRC,0x00)| | 1203 | PATH1_SC_CTL, 2, |
860 | cx231xx_set_field(FLD_AUD_CHAN2_SRC, 0x00)| | 1204 | (dwval | FLD_PATH1_SC_THRESHOLD), 4); |
861 | cx231xx_set_field(FLD_AUD_CHAN1_SRC,0x03 ), 4); | 1205 | break; |
862 | 1206 | ||
863 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PATH1_CTL1, 2, 0x1F063870, 4); | 1207 | case AUDIO_INPUT_TUNER_TV: |
864 | 1208 | default: | |
865 | /* setAudioStandard(_audio_standard); */ | 1209 | |
866 | 1210 | /* Setup SRC sources and clocks */ | |
867 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PATH1_CTL1, 2, 0x00063870, 4); | 1211 | status = |
868 | switch(dev->model) | 1212 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
869 | { | 1213 | BAND_OUT_SEL, 2, |
870 | case CX231XX_BOARD_CNXT_RDE_250: | 1214 | cx231xx_set_field(FLD_SRC6_IN_SEL, |
871 | case CX231XX_BOARD_CNXT_RDU_250: | 1215 | 0x00) | |
872 | status = cx231xx_read_modify_write_i2c_dword(dev, HAMMERHEAD_I2C_ADDRESS, | 1216 | cx231xx_set_field(FLD_SRC6_CLK_SEL, |
873 | CHIP_CTRL, FLD_SIF_EN, | 1217 | 0x01) | |
874 | cx231xx_set_field(FLD_SIF_EN, 1)); | 1218 | cx231xx_set_field(FLD_SRC5_IN_SEL, |
875 | break; | 1219 | 0x00) | |
876 | default: | 1220 | cx231xx_set_field(FLD_SRC5_CLK_SEL, |
877 | break; | 1221 | 0x02) | |
878 | } | 1222 | cx231xx_set_field(FLD_SRC4_IN_SEL, |
879 | break; | 1223 | 0x02) | |
880 | 1224 | cx231xx_set_field(FLD_SRC4_CLK_SEL, | |
881 | case AUDIO_INPUT_TUNER_FM: | 1225 | 0x03) | |
882 | /* use SIF for FM radio | 1226 | cx231xx_set_field(FLD_SRC3_IN_SEL, |
883 | setupFM(); | 1227 | 0x00) | |
884 | setAudioStandard(_audio_standard); | 1228 | cx231xx_set_field(FLD_SRC3_CLK_SEL, |
885 | */ | 1229 | 0x00) | |
886 | break; | 1230 | cx231xx_set_field |
887 | 1231 | (FLD_BASEBAND_BYPASS_CTL, | |
888 | case AUDIO_INPUT_MUTE: | 1232 | 0x00) | |
889 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PATH1_CTL1, 2, 0x1F011012, 4); | 1233 | cx231xx_set_field(FLD_AC97_SRC_SEL, |
890 | break; | 1234 | 0x03) | |
891 | } | 1235 | cx231xx_set_field(FLD_I2S_SRC_SEL, |
892 | 1236 | 0x00) | | |
893 | /* Take it out of soft reset */ | 1237 | cx231xx_set_field |
894 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, GENERAL_CTL, 2, &gen_ctrl, 1); | 1238 | (FLD_PARALLEL2_SRC_SEL, |
895 | gen_ctrl &= ~1; | 1239 | 0x02) | |
896 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, GENERAL_CTL, 2, gen_ctrl, 1); | 1240 | cx231xx_set_field |
897 | 1241 | (FLD_PARALLEL1_SRC_SEL, 0x01), 4); | |
898 | return status; | 1242 | |
899 | } | 1243 | /* Setup the AUD_IO control */ |
1244 | status = | ||
1245 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1246 | AUD_IO_CTRL, 2, | ||
1247 | cx231xx_set_field(FLD_I2S_PORT_DIR, | ||
1248 | 0x00) | | ||
1249 | cx231xx_set_field(FLD_I2S_OUT_SRC, | ||
1250 | 0x00) | | ||
1251 | cx231xx_set_field(FLD_AUD_CHAN3_SRC, | ||
1252 | 0x00) | | ||
1253 | cx231xx_set_field(FLD_AUD_CHAN2_SRC, | ||
1254 | 0x00) | | ||
1255 | cx231xx_set_field(FLD_AUD_CHAN1_SRC, | ||
1256 | 0x03), 4); | ||
1257 | |||
1258 | status = | ||
1259 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1260 | PATH1_CTL1, 2, 0x1F063870, 4); | ||
1261 | |||
1262 | /* setAudioStandard(_audio_standard); */ | ||
1263 | |||
1264 | status = | ||
1265 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1266 | PATH1_CTL1, 2, 0x00063870, 4); | ||
1267 | switch (dev->model) { | ||
1268 | case CX231XX_BOARD_CNXT_RDE_250: | ||
1269 | case CX231XX_BOARD_CNXT_RDU_250: | ||
1270 | status = | ||
1271 | cx231xx_read_modify_write_i2c_dword(dev, | ||
1272 | HAMMERHEAD_I2C_ADDRESS, | ||
1273 | CHIP_CTRL, | ||
1274 | FLD_SIF_EN, | ||
1275 | cx231xx_set_field | ||
1276 | (FLD_SIF_EN, | ||
1277 | 1)); | ||
1278 | break; | ||
1279 | default: | ||
1280 | break; | ||
1281 | } | ||
1282 | break; | ||
1283 | |||
1284 | case AUDIO_INPUT_TUNER_FM: | ||
1285 | /* use SIF for FM radio | ||
1286 | setupFM(); | ||
1287 | setAudioStandard(_audio_standard); | ||
1288 | */ | ||
1289 | break; | ||
1290 | |||
1291 | case AUDIO_INPUT_MUTE: | ||
1292 | status = | ||
1293 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1294 | PATH1_CTL1, 2, 0x1F011012, 4); | ||
1295 | break; | ||
1296 | } | ||
900 | 1297 | ||
1298 | /* Take it out of soft reset */ | ||
1299 | status = | ||
1300 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, GENERAL_CTL, 2, | ||
1301 | &gen_ctrl, 1); | ||
1302 | gen_ctrl &= ~1; | ||
1303 | status = | ||
1304 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, GENERAL_CTL, 2, | ||
1305 | gen_ctrl, 1); | ||
901 | 1306 | ||
1307 | return status; | ||
1308 | } | ||
902 | 1309 | ||
903 | /* Set resolution of the video */ | 1310 | /* Set resolution of the video */ |
904 | int cx231xx_resolution_set(struct cx231xx *dev) | 1311 | int cx231xx_resolution_set(struct cx231xx *dev) |
905 | { | 1312 | { |
906 | int width, height; | 1313 | int width, height; |
907 | u32 hscale, vscale; | 1314 | u32 hscale, vscale; |
908 | int status = 0; | 1315 | int status = 0; |
909 | 1316 | ||
910 | width = dev->width; | 1317 | width = dev->width; |
911 | height = dev->height; | 1318 | height = dev->height; |
912 | 1319 | ||
913 | get_scale(dev,width, height,&hscale, &vscale); | 1320 | get_scale(dev, width, height, &hscale, &vscale); |
914 | 1321 | ||
915 | /* set horzontal scale */ | 1322 | /* set horzontal scale */ |
916 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, HSCALE_CTRL, 2, hscale, 4); | 1323 | status = |
1324 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, HSCALE_CTRL, 2, | ||
1325 | hscale, 4); | ||
917 | 1326 | ||
918 | /* set vertical scale */ | 1327 | /* set vertical scale */ |
919 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, VSCALE_CTRL, 2, vscale, 4); | 1328 | status = |
1329 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, VSCALE_CTRL, 2, | ||
1330 | vscale, 4); | ||
920 | 1331 | ||
921 | return status; | 1332 | return status; |
922 | } | 1333 | } |
923 | 1334 | ||
924 | /************************************************************************************* | 1335 | /************************************************************************************* |
@@ -926,397 +1337,697 @@ int cx231xx_resolution_set(struct cx231xx *dev) | |||
926 | *************************************************************************************/ | 1337 | *************************************************************************************/ |
927 | int cx231xx_init_ctrl_pin_status(struct cx231xx *dev) | 1338 | int cx231xx_init_ctrl_pin_status(struct cx231xx *dev) |
928 | { | 1339 | { |
929 | u32 value; | 1340 | u32 value; |
930 | int status = 0; | 1341 | int status = 0; |
931 | 1342 | ||
932 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PIN_CTRL, 2, &value, 4); | 1343 | status = |
933 | value |=(~dev->board.ctl_pin_status_mask); | 1344 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PIN_CTRL, 2, |
934 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PIN_CTRL, 2, value, 4); | 1345 | &value, 4); |
1346 | value |= (~dev->board.ctl_pin_status_mask); | ||
1347 | status = | ||
1348 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, PIN_CTRL, 2, | ||
1349 | value, 4); | ||
935 | 1350 | ||
936 | return status; | 1351 | return status; |
937 | } | 1352 | } |
938 | 1353 | ||
939 | int cx231xx_set_agc_analog_digital_mux_select(struct cx231xx *dev, u8 analog_or_digital) | 1354 | int cx231xx_set_agc_analog_digital_mux_select(struct cx231xx *dev, |
1355 | u8 analog_or_digital) | ||
940 | { | 1356 | { |
941 | int status = 0; | 1357 | int status = 0; |
942 | 1358 | ||
943 | /* first set the direction to output */ | 1359 | /* first set the direction to output */ |
944 | status = cx231xx_set_gpio_direction(dev, dev->board.agc_analog_digital_select_gpio, 1); | 1360 | status = |
1361 | cx231xx_set_gpio_direction(dev, | ||
1362 | dev->board. | ||
1363 | agc_analog_digital_select_gpio, 1); | ||
945 | 1364 | ||
946 | /* 0 - demod ; 1 - Analog mode */ | 1365 | /* 0 - demod ; 1 - Analog mode */ |
947 | status = cx231xx_set_gpio_value(dev, dev->board.agc_analog_digital_select_gpio, | 1366 | status = |
948 | analog_or_digital); | 1367 | cx231xx_set_gpio_value(dev, |
1368 | dev->board.agc_analog_digital_select_gpio, | ||
1369 | analog_or_digital); | ||
949 | 1370 | ||
950 | return status; | 1371 | return status; |
951 | } | 1372 | } |
952 | 1373 | ||
953 | int cx231xx_enable_i2c_for_tuner(struct cx231xx *dev, u8 I2CIndex) | 1374 | int cx231xx_enable_i2c_for_tuner(struct cx231xx *dev, u8 I2CIndex) |
954 | { | 1375 | { |
955 | u8 value[4] ={0,0,0,0}; | 1376 | u8 value[4] = { 0, 0, 0, 0 }; |
956 | int status = 0; | 1377 | int status = 0; |
957 | 1378 | ||
958 | cx231xx_info("Changing the i2c port for tuner to %d\n",I2CIndex); | 1379 | cx231xx_info("Changing the i2c port for tuner to %d\n", I2CIndex); |
959 | 1380 | ||
960 | status = cx231xx_read_ctrl_reg(dev,VRT_GET_REGISTER, PWR_CTL_EN, value, 4); | 1381 | status = |
961 | if(status < 0) | 1382 | cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, PWR_CTL_EN, value, 4); |
962 | return status; | 1383 | if (status < 0) |
1384 | return status; | ||
963 | 1385 | ||
964 | if(I2CIndex==I2C_1) { | 1386 | if (I2CIndex == I2C_1) { |
965 | if(value[0] & I2C_DEMOD_EN) { | 1387 | if (value[0] & I2C_DEMOD_EN) { |
966 | value[0] &= ~I2C_DEMOD_EN; | 1388 | value[0] &= ~I2C_DEMOD_EN; |
967 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 1389 | status = |
968 | } | 1390 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
969 | } else { | 1391 | PWR_CTL_EN, value, 4); |
970 | if(!(value[0] & I2C_DEMOD_EN)) { | 1392 | } |
971 | value[0] |= I2C_DEMOD_EN; | 1393 | } else { |
972 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 1394 | if (!(value[0] & I2C_DEMOD_EN)) { |
973 | } | 1395 | value[0] |= I2C_DEMOD_EN; |
974 | } | 1396 | status = |
1397 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, | ||
1398 | PWR_CTL_EN, value, 4); | ||
1399 | } | ||
1400 | } | ||
975 | 1401 | ||
976 | return status; | 1402 | return status; |
977 | 1403 | ||
978 | } | 1404 | } |
979 | 1405 | ||
980 | |||
981 | /************************************************************************************* | 1406 | /************************************************************************************* |
982 | * D I F - B L O C K C O N T R O L functions * | 1407 | * D I F - B L O C K C O N T R O L functions * |
983 | *************************************************************************************/ | 1408 | *************************************************************************************/ |
984 | int cx231xx_dif_configure_C2HH_for_low_IF(struct cx231xx *dev, u32 mode, | 1409 | int cx231xx_dif_configure_C2HH_for_low_IF(struct cx231xx *dev, u32 mode, |
985 | u32 function_mode, u32 standard) | 1410 | u32 function_mode, u32 standard) |
986 | { | 1411 | { |
987 | int status = 0; | 1412 | int status = 0; |
988 | 1413 | ||
989 | if(mode == V4L2_TUNER_RADIO) { | 1414 | if (mode == V4L2_TUNER_RADIO) { |
990 | /* C2HH */ | 1415 | /* C2HH */ |
991 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1416 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 30, 31, 0x1); /* lo if big signal */ |
992 | AFE_CTRL_C2HH_SRC_CTRL, 30, 31, 0x1); /* lo if big signal */ | 1417 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 23, 24, function_mode); /* FUNC_MODE = DIF */ |
993 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1418 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 15, 22, 0xFF); /* IF_MODE */ |
994 | AFE_CTRL_C2HH_SRC_CTRL, 23, 24, function_mode); /* FUNC_MODE = DIF */ | 1419 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 9, 9, 0x1); /* no inv */ |
995 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1420 | } else { |
996 | AFE_CTRL_C2HH_SRC_CTRL, 15, 22, 0xFF); /* IF_MODE */ | 1421 | switch (standard) { |
997 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1422 | case V4L2_STD_NTSC_M: /* 75 IRE Setup */ |
998 | AFE_CTRL_C2HH_SRC_CTRL, 9, 9, 0x1); /* no inv */ | 1423 | case V4L2_STD_NTSC_M_JP: /* Japan, 0 IRE Setup */ |
999 | } | 1424 | case V4L2_STD_PAL_M: |
1000 | else { | 1425 | case V4L2_STD_PAL_N: |
1001 | switch(standard) { | 1426 | case V4L2_STD_PAL_Nc: |
1002 | case V4L2_STD_NTSC_M: /* 75 IRE Setup */ | 1427 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 30, 31, 0x1); /* lo if big signal */ |
1003 | case V4L2_STD_NTSC_M_JP: /* Japan, 0 IRE Setup */ | 1428 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 23, 24, function_mode); /* FUNC_MODE = DIF */ |
1004 | case V4L2_STD_PAL_M: | 1429 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 15, 22, 0xb); /* IF_MODE */ |
1005 | case V4L2_STD_PAL_N: | 1430 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 9, 9, 0x1); /* no inv */ |
1006 | case V4L2_STD_PAL_Nc: | 1431 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AUD_IO_CTRL, 0, 31, 0x00000003); /* 0x124, AUD_CHAN1_SRC = 0x3 */ |
1007 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1432 | break; |
1008 | AFE_CTRL_C2HH_SRC_CTRL, 30, 31, 0x1); /* lo if big signal */ | 1433 | |
1009 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1434 | case V4L2_STD_PAL_B: |
1010 | AFE_CTRL_C2HH_SRC_CTRL, 23, 24, function_mode); /* FUNC_MODE = DIF */ | 1435 | case V4L2_STD_PAL_G: |
1011 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1436 | /* C2HH setup */ |
1012 | AFE_CTRL_C2HH_SRC_CTRL, 15, 22, 0xb); /* IF_MODE */ | 1437 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 30, 31, 0x1); /* lo if big signal */ |
1013 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1438 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 23, 24, function_mode); /* FUNC_MODE = DIF */ |
1014 | AFE_CTRL_C2HH_SRC_CTRL, 9, 9, 0x1); /* no inv */ | 1439 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 15, 22, 0xE); /* IF_MODE */ |
1015 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1440 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 9, 9, 0x1); /* no inv */ |
1016 | AUD_IO_CTRL, 0, 31, 0x00000003); /* 0x124, AUD_CHAN1_SRC = 0x3 */ | 1441 | break; |
1017 | break; | 1442 | |
1018 | 1443 | case V4L2_STD_PAL_D: | |
1019 | case V4L2_STD_PAL_B: | 1444 | case V4L2_STD_PAL_I: |
1020 | case V4L2_STD_PAL_G: | 1445 | case V4L2_STD_SECAM_L: |
1021 | /* C2HH setup */ | 1446 | case V4L2_STD_SECAM_LC: |
1022 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1447 | case V4L2_STD_SECAM_B: |
1023 | AFE_CTRL_C2HH_SRC_CTRL, 30, 31, 0x1); /* lo if big signal */ | 1448 | case V4L2_STD_SECAM_D: |
1024 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1449 | case V4L2_STD_SECAM_G: |
1025 | AFE_CTRL_C2HH_SRC_CTRL, 23, 24, function_mode); /* FUNC_MODE = DIF */ | 1450 | case V4L2_STD_SECAM_K: |
1026 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1451 | case V4L2_STD_SECAM_K1: |
1027 | AFE_CTRL_C2HH_SRC_CTRL, 15, 22, 0xE); /* IF_MODE */ | 1452 | /* C2HH setup */ |
1028 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | 1453 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 30, 31, 0x1); /* lo if big signal */ |
1029 | AFE_CTRL_C2HH_SRC_CTRL, 9, 9, 0x1); /* no inv */ | 1454 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 23, 24, function_mode); /* FUNC_MODE = DIF */ |
1030 | break; | 1455 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 15, 22, 0xF); /* IF_MODE */ |
1031 | 1456 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, AFE_CTRL_C2HH_SRC_CTRL, 9, 9, 0x1); /* no inv */ | |
1032 | case V4L2_STD_PAL_D: | 1457 | break; |
1033 | case V4L2_STD_PAL_I: | 1458 | |
1034 | case V4L2_STD_SECAM_L: | 1459 | case DIF_USE_BASEBAND: |
1035 | case V4L2_STD_SECAM_LC: | 1460 | default: |
1036 | case V4L2_STD_SECAM_B: | 1461 | /* do nothing to config C2HH for baseband */ |
1037 | case V4L2_STD_SECAM_D: | 1462 | break; |
1038 | case V4L2_STD_SECAM_G: | 1463 | } |
1039 | case V4L2_STD_SECAM_K: | 1464 | } |
1040 | case V4L2_STD_SECAM_K1: | 1465 | |
1041 | /* C2HH setup */ | 1466 | return status; |
1042 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1043 | AFE_CTRL_C2HH_SRC_CTRL, 30, 31, 0x1); /* lo if big signal */ | ||
1044 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1045 | AFE_CTRL_C2HH_SRC_CTRL, 23, 24, function_mode); /* FUNC_MODE = DIF */ | ||
1046 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1047 | AFE_CTRL_C2HH_SRC_CTRL, 15, 22, 0xF); /* IF_MODE */ | ||
1048 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1049 | AFE_CTRL_C2HH_SRC_CTRL, 9, 9, 0x1); /* no inv */ | ||
1050 | break; | ||
1051 | |||
1052 | case DIF_USE_BASEBAND: | ||
1053 | default: | ||
1054 | /* do nothing to config C2HH for baseband */ | ||
1055 | break; | ||
1056 | } | ||
1057 | } | ||
1058 | |||
1059 | return status; | ||
1060 | } | 1467 | } |
1061 | 1468 | ||
1062 | int cx231xx_dif_set_standard(struct cx231xx *dev, u32 standard) | 1469 | int cx231xx_dif_set_standard(struct cx231xx *dev, u32 standard) |
1063 | { | 1470 | { |
1064 | int status = 0; | 1471 | int status = 0; |
1065 | u32 dif_misc_ctrl_value = 0; | 1472 | u32 dif_misc_ctrl_value = 0; |
1066 | u32 func_mode = 0; | 1473 | u32 func_mode = 0; |
1067 | 1474 | ||
1068 | cx231xx_info("%s: setStandard to %x\n",__func__,standard); | 1475 | cx231xx_info("%s: setStandard to %x\n", __func__, standard); |
1069 | 1476 | ||
1070 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1477 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1071 | DIF_MISC_CTRL, 2, &dif_misc_ctrl_value, 4); | 1478 | DIF_MISC_CTRL, 2, &dif_misc_ctrl_value, |
1072 | if(standard != DIF_USE_BASEBAND ) | 1479 | 4); |
1073 | dev->norm = standard; | 1480 | if (standard != DIF_USE_BASEBAND) |
1074 | 1481 | dev->norm = standard; | |
1075 | switch (dev->model) { | 1482 | |
1076 | case CX231XX_BOARD_CNXT_RDE_250: | 1483 | switch (dev->model) { |
1077 | case CX231XX_BOARD_CNXT_RDU_250: | 1484 | case CX231XX_BOARD_CNXT_RDE_250: |
1078 | func_mode=0x03; | 1485 | case CX231XX_BOARD_CNXT_RDU_250: |
1079 | break; | 1486 | func_mode = 0x03; |
1080 | default: | 1487 | break; |
1081 | func_mode=0x01; | 1488 | default: |
1082 | } | 1489 | func_mode = 0x01; |
1083 | 1490 | } | |
1084 | status = cx231xx_dif_configure_C2HH_for_low_IF(dev, dev->active_mode, func_mode, standard); | 1491 | |
1085 | 1492 | status = | |
1086 | 1493 | cx231xx_dif_configure_C2HH_for_low_IF(dev, dev->active_mode, | |
1087 | if(standard == DIF_USE_BASEBAND ) { /* base band */ | 1494 | func_mode, standard); |
1088 | 1495 | ||
1089 | /* There is a different SRC_PHASE_INC value for baseband vs. DIF */ | 1496 | if (standard == DIF_USE_BASEBAND) { /* base band */ |
1090 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1497 | |
1091 | DIF_SRC_PHASE_INC, 2, 0xDF7DF83, 4); | 1498 | /* There is a different SRC_PHASE_INC value for baseband vs. DIF */ |
1092 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1499 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1093 | DIF_MISC_CTRL, 2, &dif_misc_ctrl_value, 4); | 1500 | DIF_SRC_PHASE_INC, 2, 0xDF7DF83, |
1094 | dif_misc_ctrl_value |= FLD_DIF_DIF_BYPASS; | 1501 | 4); |
1095 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1502 | status = |
1096 | DIF_MISC_CTRL, 2, dif_misc_ctrl_value, 4); | 1503 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1097 | 1504 | DIF_MISC_CTRL, 2, | |
1098 | } else if ( standard & (V4L2_STD_PAL_B | V4L2_STD_PAL_G) ) { | 1505 | &dif_misc_ctrl_value, 4); |
1099 | 1506 | dif_misc_ctrl_value |= FLD_DIF_DIF_BYPASS; | |
1100 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL, 0, 31, 0x6503bc0c); | 1507 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1101 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL1, 0, 31, 0xbd038c85); | 1508 | DIF_MISC_CTRL, 2, |
1102 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL2, 0, 31, 0x1db4640a); | 1509 | dif_misc_ctrl_value, 4); |
1103 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL3, 0, 31, 0x00008800); | 1510 | |
1104 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_REF, 0, 31, 0x444C1380); | 1511 | } else if (standard & (V4L2_STD_PAL_B | V4L2_STD_PAL_G)) { |
1105 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_IF, 0, 31, 0xDA302600); | 1512 | |
1106 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_INT, 0, 31, 0xDA261700); | 1513 | status = |
1107 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_RF, 0, 31, 0xDA262600); | 1514 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1108 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_INT_CURRENT, 0, 31, 0x26001700); | 1515 | DIF_PLL_CTRL, 0, 31, 0x6503bc0c); |
1109 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_RF_CURRENT, 0, 31, 0x00002660); | 1516 | status = |
1110 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VIDEO_AGC_CTRL, 0, 31, 0x72500800); | 1517 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1111 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VID_AUD_OVERRIDE, 0, 31, 0x27000100); | 1518 | DIF_PLL_CTRL1, 0, 31, 0xbd038c85); |
1112 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AV_SEP_CTRL, 0, 31, 0x3F3530EC); | 1519 | status = |
1113 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_COMP_FLT_CTRL, 0, 31, 0x00A653A8); | 1520 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1114 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_PHASE_INC, 0, 31, 0x1befbf06); | 1521 | DIF_PLL_CTRL2, 0, 31, 0x1db4640a); |
1115 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_GAIN_CONTROL, 0, 31, 0x000035e8); | 1522 | status = |
1116 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_RPT_VARIANCE, 0, 31, 0x00000000); | 1523 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1117 | /* Save the Spec Inversion value */ | 1524 | DIF_PLL_CTRL3, 0, 31, 0x00008800); |
1118 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | 1525 | status = |
1119 | dif_misc_ctrl_value |=0x3a013F11; | 1526 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1120 | 1527 | DIF_AGC_IF_REF, 0, 31, 0x444C1380); | |
1121 | } else if( standard & V4L2_STD_PAL_D ) { | 1528 | status = |
1122 | 1529 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | |
1123 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL, 0, 31, 0x6503bc0c); | 1530 | DIF_AGC_CTRL_IF, 0, 31, 0xDA302600); |
1124 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL1, 0, 31, 0xbd038c85); | 1531 | status = |
1125 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL2, 0, 31, 0x1db4640a); | 1532 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1126 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL3, 0, 31, 0x00008800); | 1533 | DIF_AGC_CTRL_INT, 0, 31, 0xDA261700); |
1127 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_REF, 0, 31, 0x444C1380); | 1534 | status = |
1128 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_IF, 0, 31, 0xDA302600); | 1535 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1129 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_INT, 0, 31, 0xDA261700); | 1536 | DIF_AGC_CTRL_RF, 0, 31, 0xDA262600); |
1130 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_RF, 0, 31, 0xDA262600); | 1537 | status = |
1131 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_INT_CURRENT, 0, 31, 0x26001700); | 1538 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1132 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_RF_CURRENT, 0, 31, 0x00002660); | 1539 | DIF_AGC_IF_INT_CURRENT, 0, 31, |
1133 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VIDEO_AGC_CTRL, 0, 31, 0x72500800); | 1540 | 0x26001700); |
1134 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VID_AUD_OVERRIDE, 0, 31, 0x27000100); | 1541 | status = |
1135 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AV_SEP_CTRL, 0, 31, 0x3F3934EA); | 1542 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1136 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_COMP_FLT_CTRL, 0, 31, 0x00000000); | 1543 | DIF_AGC_RF_CURRENT, 0, 31, |
1137 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_PHASE_INC, 0, 31, 0x1befbf06); | 1544 | 0x00002660); |
1138 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_GAIN_CONTROL, 0, 31, 0x000035e8); | 1545 | status = |
1139 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_RPT_VARIANCE, 0, 31, 0x00000000); | 1546 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1140 | /* Save the Spec Inversion value */ | 1547 | DIF_VIDEO_AGC_CTRL, 0, 31, |
1141 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | 1548 | 0x72500800); |
1142 | dif_misc_ctrl_value |=0x3a023F11; | 1549 | status = |
1143 | 1550 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | |
1144 | } else if( standard & V4L2_STD_PAL_I ) { | 1551 | DIF_VID_AUD_OVERRIDE, 0, 31, |
1145 | 1552 | 0x27000100); | |
1146 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL, 0, 31, 0x6503bc0c); | 1553 | status = |
1147 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL1, 0, 31, 0xbd038c85); | 1554 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1148 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL2, 0, 31, 0x1db4640a); | 1555 | DIF_AV_SEP_CTRL, 0, 31, 0x3F3530EC); |
1149 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL3, 0, 31, 0x00008800); | 1556 | status = |
1150 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_REF, 0, 31, 0x444C1380); | 1557 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1151 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_IF, 0, 31, 0xDA302600); | 1558 | DIF_COMP_FLT_CTRL, 0, 31, |
1152 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_INT, 0, 31, 0xDA261700); | 1559 | 0x00A653A8); |
1153 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_RF, 0, 31, 0xDA262600); | 1560 | status = |
1154 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_INT_CURRENT, 0, 31, 0x26001700); | 1561 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1155 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_RF_CURRENT, 0, 31, 0x00002660); | 1562 | DIF_SRC_PHASE_INC, 0, 31, |
1156 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VIDEO_AGC_CTRL, 0, 31, 0x72500800); | 1563 | 0x1befbf06); |
1157 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VID_AUD_OVERRIDE, 0, 31, 0x27000100); | 1564 | status = |
1158 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AV_SEP_CTRL, 0, 31, 0x5F39A934); | 1565 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1159 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_COMP_FLT_CTRL, 0, 31, 0x00000000); | 1566 | DIF_SRC_GAIN_CONTROL, 0, 31, |
1160 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_PHASE_INC, 0, 31, 0x1befbf06); | 1567 | 0x000035e8); |
1161 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_GAIN_CONTROL, 0, 31, 0x000035e8); | 1568 | status = |
1162 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_RPT_VARIANCE, 0, 31, 0x00000000); | 1569 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1163 | /* Save the Spec Inversion value */ | 1570 | DIF_RPT_VARIANCE, 0, 31, 0x00000000); |
1164 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | 1571 | /* Save the Spec Inversion value */ |
1165 | dif_misc_ctrl_value |=0x3a033F11; | 1572 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; |
1166 | 1573 | dif_misc_ctrl_value |= 0x3a013F11; | |
1167 | } else if( standard & V4L2_STD_PAL_M ) { | 1574 | |
1168 | 1575 | } else if (standard & V4L2_STD_PAL_D) { | |
1169 | /* improved Low Frequency Phase Noise */ | 1576 | |
1170 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1577 | status = |
1171 | DIF_PLL_CTRL, 2, 0xFF01FF0C, 4); | 1578 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1172 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1579 | DIF_PLL_CTRL, 0, 31, 0x6503bc0c); |
1173 | DIF_PLL_CTRL1, 2, 0xbd038c85, 4); | 1580 | status = |
1174 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1581 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1175 | DIF_PLL_CTRL2, 2, 0x1db4640a, 4); | 1582 | DIF_PLL_CTRL1, 0, 31, 0xbd038c85); |
1176 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1583 | status = |
1177 | DIF_PLL_CTRL3, 2, 0x00008800, 4); | 1584 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1178 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1585 | DIF_PLL_CTRL2, 0, 31, 0x1db4640a); |
1179 | DIF_AGC_IF_REF, 2, 0x444C1380, 4); | 1586 | status = |
1180 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1587 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1181 | DIF_AGC_IF_INT_CURRENT, 2, 0x26001700, 4); | 1588 | DIF_PLL_CTRL3, 0, 31, 0x00008800); |
1182 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1589 | status = |
1183 | DIF_AGC_RF_CURRENT, 2, 0x00002660, 4); | 1590 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1184 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1591 | DIF_AGC_IF_REF, 0, 31, 0x444C1380); |
1185 | DIF_VIDEO_AGC_CTRL, 2, 0x72500800, 4); | 1592 | status = |
1186 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1593 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1187 | DIF_VID_AUD_OVERRIDE, 2, 0x27000100, 4); | 1594 | DIF_AGC_CTRL_IF, 0, 31, 0xDA302600); |
1188 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1595 | status = |
1189 | DIF_AV_SEP_CTRL, 2, 0x012c405d, 4); | 1596 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1190 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1597 | DIF_AGC_CTRL_INT, 0, 31, 0xDA261700); |
1191 | DIF_COMP_FLT_CTRL, 2, 0x009f50c1, 4); | 1598 | status = |
1192 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1599 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1193 | DIF_SRC_PHASE_INC, 2, 0x1befbf06, 4); | 1600 | DIF_AGC_CTRL_RF, 0, 31, 0xDA262600); |
1194 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1601 | status = |
1195 | DIF_SRC_GAIN_CONTROL, 2, 0x000035e8, 4); | 1602 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1196 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 1603 | DIF_AGC_IF_INT_CURRENT, 0, 31, |
1197 | DIF_SOFT_RST_CTRL_REVB, 2, 0x00000000, 4); | 1604 | 0x26001700); |
1198 | 1605 | status = | |
1199 | /* Save the Spec Inversion value */ | 1606 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1200 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | 1607 | DIF_AGC_RF_CURRENT, 0, 31, |
1201 | dif_misc_ctrl_value |= 0x3A0A3F10; | 1608 | 0x00002660); |
1202 | 1609 | status = | |
1203 | } else if( standard & (V4L2_STD_PAL_N | V4L2_STD_PAL_Nc) ) { | 1610 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1204 | 1611 | DIF_VIDEO_AGC_CTRL, 0, 31, | |
1205 | /* improved Low Frequency Phase Noise */ | 1612 | 0x72500800); |
1206 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_PLL_CTRL, 2, 0xFF01FF0C, 4); | 1613 | status = |
1207 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_PLL_CTRL1, 2, 0xbd038c85, 4); | 1614 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1208 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_PLL_CTRL2, 2, 0x1db4640a, 4); | 1615 | DIF_VID_AUD_OVERRIDE, 0, 31, |
1209 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_PLL_CTRL3, 2, 0x00008800, 4); | 1616 | 0x27000100); |
1210 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_IF_REF, 2, 0x444C1380, 4); | 1617 | status = |
1211 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_IF_INT_CURRENT, 2, 0x26001700, 4); | 1618 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1212 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_RF_CURRENT, 2, 0x00002660, 4); | 1619 | DIF_AV_SEP_CTRL, 0, 31, 0x3F3934EA); |
1213 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_VIDEO_AGC_CTRL, 2, 0x72500800, 4); | 1620 | status = |
1214 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_VID_AUD_OVERRIDE, 2, 0x27000100, 4); | 1621 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1215 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AV_SEP_CTRL, 2, 0x012c405d, 4); | 1622 | DIF_COMP_FLT_CTRL, 0, 31, |
1216 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_COMP_FLT_CTRL, 2, 0x009f50c1, 4); | 1623 | 0x00000000); |
1217 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_SRC_PHASE_INC, 2, 0x1befbf06, 4); | 1624 | status = |
1218 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_SRC_GAIN_CONTROL, 2, 0x000035e8, 4); | 1625 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1219 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_SOFT_RST_CTRL_REVB, 2, 0x00000000, 4); | 1626 | DIF_SRC_PHASE_INC, 0, 31, |
1220 | 1627 | 0x1befbf06); | |
1221 | /* Save the Spec Inversion value */ | 1628 | status = |
1222 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | 1629 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1223 | dif_misc_ctrl_value = 0x3A093F10; | 1630 | DIF_SRC_GAIN_CONTROL, 0, 31, |
1224 | 1631 | 0x000035e8); | |
1225 | } else if( standard & ( V4L2_STD_SECAM_B | V4L2_STD_SECAM_D | V4L2_STD_SECAM_G | | 1632 | status = |
1226 | V4L2_STD_SECAM_K | V4L2_STD_SECAM_K1) ) { | 1633 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1227 | 1634 | DIF_RPT_VARIANCE, 0, 31, 0x00000000); | |
1228 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL, 0, 31, 0x6503bc0c); | 1635 | /* Save the Spec Inversion value */ |
1229 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL1, 0, 31, 0xbd038c85); | 1636 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; |
1230 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL2, 0, 31, 0x1db4640a); | 1637 | dif_misc_ctrl_value |= 0x3a023F11; |
1231 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL3, 0, 31, 0x00008800); | 1638 | |
1232 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_REF, 0, 31, 0x888C0380); | 1639 | } else if (standard & V4L2_STD_PAL_I) { |
1233 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_IF, 0, 31, 0xe0262600); | 1640 | |
1234 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_INT, 0, 31, 0xc2171700); | 1641 | status = |
1235 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_RF, 0, 31, 0xc2262600); | 1642 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1236 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_INT_CURRENT, 0, 31, 0x26001700); | 1643 | DIF_PLL_CTRL, 0, 31, 0x6503bc0c); |
1237 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_RF_CURRENT, 0, 31, 0x00002660); | 1644 | status = |
1238 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VID_AUD_OVERRIDE, 0, 31, 0x27000100); | 1645 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1239 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AV_SEP_CTRL, 0, 31, 0x3F3530ec); | 1646 | DIF_PLL_CTRL1, 0, 31, 0xbd038c85); |
1240 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_COMP_FLT_CTRL, 0, 31, 0x00000000); | 1647 | status = |
1241 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_PHASE_INC, 0, 31, 0x1befbf06); | 1648 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1242 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_GAIN_CONTROL, 0, 31, 0x000035e8); | 1649 | DIF_PLL_CTRL2, 0, 31, 0x1db4640a); |
1243 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_RPT_VARIANCE, 0, 31, 0x00000000); | 1650 | status = |
1244 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VIDEO_AGC_CTRL, 0, 31, 0xf4000000); | 1651 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1245 | 1652 | DIF_PLL_CTRL3, 0, 31, 0x00008800); | |
1246 | /* Save the Spec Inversion value */ | 1653 | status = |
1247 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | 1654 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1248 | dif_misc_ctrl_value |=0x3a023F11; | 1655 | DIF_AGC_IF_REF, 0, 31, 0x444C1380); |
1249 | 1656 | status = | |
1250 | } else if( standard & (V4L2_STD_SECAM_L | V4L2_STD_SECAM_LC) ) { | 1657 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1251 | 1658 | DIF_AGC_CTRL_IF, 0, 31, 0xDA302600); | |
1252 | /* Is it SECAM_L1? */ | 1659 | status = |
1253 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL, 0, 31, 0x6503bc0c); | 1660 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1254 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL1, 0, 31, 0xbd038c85); | 1661 | DIF_AGC_CTRL_INT, 0, 31, 0xDA261700); |
1255 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL2, 0, 31, 0x1db4640a); | 1662 | status = |
1256 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_PLL_CTRL3, 0, 31, 0x00008800); | 1663 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1257 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_REF, 0, 31, 0x888C0380); | 1664 | DIF_AGC_CTRL_RF, 0, 31, 0xDA262600); |
1258 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_IF, 0, 31, 0xe0262600); | 1665 | status = |
1259 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_INT, 0, 31, 0xc2171700); | 1666 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1260 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_CTRL_RF, 0, 31, 0xc2262600); | 1667 | DIF_AGC_IF_INT_CURRENT, 0, 31, |
1261 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_IF_INT_CURRENT, 0, 31, 0x26001700); | 1668 | 0x26001700); |
1262 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AGC_RF_CURRENT, 0, 31, 0x00002660); | 1669 | status = |
1263 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VID_AUD_OVERRIDE, 0, 31, 0x27000100); | 1670 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1264 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_AV_SEP_CTRL, 0, 31, 0x3F3530ec); | 1671 | DIF_AGC_RF_CURRENT, 0, 31, |
1265 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_COMP_FLT_CTRL, 0, 31, 0x00000000); | 1672 | 0x00002660); |
1266 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_PHASE_INC, 0, 31, 0x1befbf06); | 1673 | status = |
1267 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_SRC_GAIN_CONTROL, 0, 31, 0x000035e8); | 1674 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1268 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_RPT_VARIANCE, 0, 31, 0x00000000); | 1675 | DIF_VIDEO_AGC_CTRL, 0, 31, |
1269 | status = cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, DIF_VIDEO_AGC_CTRL, 0, 31, 0xf2560000); | 1676 | 0x72500800); |
1270 | 1677 | status = | |
1271 | /* Save the Spec Inversion value */ | 1678 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1272 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | 1679 | DIF_VID_AUD_OVERRIDE, 0, 31, |
1273 | dif_misc_ctrl_value |=0x3a023F11; | 1680 | 0x27000100); |
1274 | 1681 | status = | |
1275 | } else { /* V4L2_STD_NTSC_M (75 IRE Setup) Or V4L2_STD_NTSC_M_JP (Japan, 0 IRE Setup) */ | 1682 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1276 | 1683 | DIF_AV_SEP_CTRL, 0, 31, 0x5F39A934); | |
1277 | /* For NTSC the centre frequency of video coming out of sidewinder is | 1684 | status = |
1278 | around 7.1MHz or 3.6MHz depending on the spectral inversion. | 1685 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1279 | so for a non spectrally inverted channel the pll freq word is 0x03420c49 | 1686 | DIF_COMP_FLT_CTRL, 0, 31, |
1280 | */ | 1687 | 0x00000000); |
1281 | 1688 | status = | |
1282 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_PLL_CTRL, 2, 0x6503BC0C, 4); | 1689 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1283 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_PLL_CTRL1, 2, 0xBD038C85, 4); | 1690 | DIF_SRC_PHASE_INC, 0, 31, |
1284 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_PLL_CTRL2, 2, 0x1DB4640A, 4); | 1691 | 0x1befbf06); |
1285 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_PLL_CTRL3, 2, 0x00008800, 4); | 1692 | status = |
1286 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_IF_REF, 2, 0x444C0380, 4); | 1693 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1287 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_IF_INT_CURRENT, 2, 0x26001700, 4); | 1694 | DIF_SRC_GAIN_CONTROL, 0, 31, |
1288 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_RF_CURRENT, 2, 0x00002660, 4); | 1695 | 0x000035e8); |
1289 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_VIDEO_AGC_CTRL, 2, 0x04000800, 4); | 1696 | status = |
1290 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_VID_AUD_OVERRIDE, 2, 0x27000100, 4); | 1697 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, |
1291 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AV_SEP_CTRL, 2, 0x01296e1f, 4); | 1698 | DIF_RPT_VARIANCE, 0, 31, 0x00000000); |
1292 | 1699 | /* Save the Spec Inversion value */ | |
1293 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_COMP_FLT_CTRL, 2, 0x009f50c1, 4); | 1700 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; |
1294 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_SRC_PHASE_INC, 2, 0x1befbf06, 4); | 1701 | dif_misc_ctrl_value |= 0x3a033F11; |
1295 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_SRC_GAIN_CONTROL, 2, 0x000035e8, 4); | 1702 | |
1296 | 1703 | } else if (standard & V4L2_STD_PAL_M) { | |
1297 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_CTRL_IF, 2, 0xC2262600, 4); | 1704 | |
1298 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_CTRL_INT, 2, 0xC2262600, 4); | 1705 | /* improved Low Frequency Phase Noise */ |
1299 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_AGC_CTRL_RF, 2, 0xC2262600, 4); | 1706 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1300 | 1707 | DIF_PLL_CTRL, 2, 0xFF01FF0C, 4); | |
1301 | /* Save the Spec Inversion value */ | 1708 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1302 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | 1709 | DIF_PLL_CTRL1, 2, 0xbd038c85, |
1303 | dif_misc_ctrl_value |= 0x3a003F10; | 1710 | 4); |
1304 | 1711 | status = | |
1305 | } | 1712 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1306 | 1713 | DIF_PLL_CTRL2, 2, 0x1db4640a, 4); | |
1307 | /* The AGC values should be the same for all standards, | 1714 | status = |
1308 | AUD_SRC_SEL[19] should always be disabled */ | 1715 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1309 | dif_misc_ctrl_value &= ~FLD_DIF_AUD_SRC_SEL; | 1716 | DIF_PLL_CTRL3, 2, 0x00008800, 4); |
1310 | 1717 | status = | |
1311 | /* It is still possible to get Set Standard calls even when we are in FM mode | 1718 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1312 | This is done to override the value for FM. */ | 1719 | DIF_AGC_IF_REF, 2, 0x444C1380, 4); |
1313 | if (dev->active_mode == V4L2_TUNER_RADIO) | 1720 | status = |
1314 | dif_misc_ctrl_value = 0x7a080000; | 1721 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1315 | 1722 | DIF_AGC_IF_INT_CURRENT, 2, | |
1316 | /* Write the calculated value for misc ontrol register */ | 1723 | 0x26001700, 4); |
1317 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_MISC_CTRL, 2, dif_misc_ctrl_value, 4); | 1724 | status = |
1318 | 1725 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | |
1319 | return status; | 1726 | DIF_AGC_RF_CURRENT, 2, 0x00002660, |
1727 | 4); | ||
1728 | status = | ||
1729 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1730 | DIF_VIDEO_AGC_CTRL, 2, 0x72500800, | ||
1731 | 4); | ||
1732 | status = | ||
1733 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1734 | DIF_VID_AUD_OVERRIDE, 2, 0x27000100, | ||
1735 | 4); | ||
1736 | status = | ||
1737 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1738 | DIF_AV_SEP_CTRL, 2, 0x012c405d, 4); | ||
1739 | status = | ||
1740 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1741 | DIF_COMP_FLT_CTRL, 2, 0x009f50c1, 4); | ||
1742 | status = | ||
1743 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1744 | DIF_SRC_PHASE_INC, 2, 0x1befbf06, 4); | ||
1745 | status = | ||
1746 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1747 | DIF_SRC_GAIN_CONTROL, 2, 0x000035e8, | ||
1748 | 4); | ||
1749 | status = | ||
1750 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1751 | DIF_SOFT_RST_CTRL_REVB, 2, | ||
1752 | 0x00000000, 4); | ||
1753 | |||
1754 | /* Save the Spec Inversion value */ | ||
1755 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | ||
1756 | dif_misc_ctrl_value |= 0x3A0A3F10; | ||
1757 | |||
1758 | } else if (standard & (V4L2_STD_PAL_N | V4L2_STD_PAL_Nc)) { | ||
1759 | |||
1760 | /* improved Low Frequency Phase Noise */ | ||
1761 | status = | ||
1762 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1763 | DIF_PLL_CTRL, 2, 0xFF01FF0C, 4); | ||
1764 | status = | ||
1765 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1766 | DIF_PLL_CTRL1, 2, 0xbd038c85, 4); | ||
1767 | status = | ||
1768 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1769 | DIF_PLL_CTRL2, 2, 0x1db4640a, 4); | ||
1770 | status = | ||
1771 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1772 | DIF_PLL_CTRL3, 2, 0x00008800, 4); | ||
1773 | status = | ||
1774 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1775 | DIF_AGC_IF_REF, 2, 0x444C1380, 4); | ||
1776 | status = | ||
1777 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1778 | DIF_AGC_IF_INT_CURRENT, 2, | ||
1779 | 0x26001700, 4); | ||
1780 | status = | ||
1781 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1782 | DIF_AGC_RF_CURRENT, 2, 0x00002660, | ||
1783 | 4); | ||
1784 | status = | ||
1785 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1786 | DIF_VIDEO_AGC_CTRL, 2, 0x72500800, | ||
1787 | 4); | ||
1788 | status = | ||
1789 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1790 | DIF_VID_AUD_OVERRIDE, 2, 0x27000100, | ||
1791 | 4); | ||
1792 | status = | ||
1793 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1794 | DIF_AV_SEP_CTRL, 2, 0x012c405d, 4); | ||
1795 | status = | ||
1796 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1797 | DIF_COMP_FLT_CTRL, 2, 0x009f50c1, 4); | ||
1798 | status = | ||
1799 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1800 | DIF_SRC_PHASE_INC, 2, 0x1befbf06, 4); | ||
1801 | status = | ||
1802 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1803 | DIF_SRC_GAIN_CONTROL, 2, 0x000035e8, | ||
1804 | 4); | ||
1805 | status = | ||
1806 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1807 | DIF_SOFT_RST_CTRL_REVB, 2, | ||
1808 | 0x00000000, 4); | ||
1809 | |||
1810 | /* Save the Spec Inversion value */ | ||
1811 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | ||
1812 | dif_misc_ctrl_value = 0x3A093F10; | ||
1813 | |||
1814 | } else if (standard & | ||
1815 | (V4L2_STD_SECAM_B | V4L2_STD_SECAM_D | V4L2_STD_SECAM_G | | ||
1816 | V4L2_STD_SECAM_K | V4L2_STD_SECAM_K1)) { | ||
1817 | |||
1818 | status = | ||
1819 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1820 | DIF_PLL_CTRL, 0, 31, 0x6503bc0c); | ||
1821 | status = | ||
1822 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1823 | DIF_PLL_CTRL1, 0, 31, 0xbd038c85); | ||
1824 | status = | ||
1825 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1826 | DIF_PLL_CTRL2, 0, 31, 0x1db4640a); | ||
1827 | status = | ||
1828 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1829 | DIF_PLL_CTRL3, 0, 31, 0x00008800); | ||
1830 | status = | ||
1831 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1832 | DIF_AGC_IF_REF, 0, 31, 0x888C0380); | ||
1833 | status = | ||
1834 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1835 | DIF_AGC_CTRL_IF, 0, 31, 0xe0262600); | ||
1836 | status = | ||
1837 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1838 | DIF_AGC_CTRL_INT, 0, 31, 0xc2171700); | ||
1839 | status = | ||
1840 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1841 | DIF_AGC_CTRL_RF, 0, 31, 0xc2262600); | ||
1842 | status = | ||
1843 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1844 | DIF_AGC_IF_INT_CURRENT, 0, 31, | ||
1845 | 0x26001700); | ||
1846 | status = | ||
1847 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1848 | DIF_AGC_RF_CURRENT, 0, 31, | ||
1849 | 0x00002660); | ||
1850 | status = | ||
1851 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1852 | DIF_VID_AUD_OVERRIDE, 0, 31, | ||
1853 | 0x27000100); | ||
1854 | status = | ||
1855 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1856 | DIF_AV_SEP_CTRL, 0, 31, 0x3F3530ec); | ||
1857 | status = | ||
1858 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1859 | DIF_COMP_FLT_CTRL, 0, 31, | ||
1860 | 0x00000000); | ||
1861 | status = | ||
1862 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1863 | DIF_SRC_PHASE_INC, 0, 31, | ||
1864 | 0x1befbf06); | ||
1865 | status = | ||
1866 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1867 | DIF_SRC_GAIN_CONTROL, 0, 31, | ||
1868 | 0x000035e8); | ||
1869 | status = | ||
1870 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1871 | DIF_RPT_VARIANCE, 0, 31, 0x00000000); | ||
1872 | status = | ||
1873 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1874 | DIF_VIDEO_AGC_CTRL, 0, 31, | ||
1875 | 0xf4000000); | ||
1876 | |||
1877 | /* Save the Spec Inversion value */ | ||
1878 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | ||
1879 | dif_misc_ctrl_value |= 0x3a023F11; | ||
1880 | |||
1881 | } else if (standard & (V4L2_STD_SECAM_L | V4L2_STD_SECAM_LC)) { | ||
1882 | |||
1883 | /* Is it SECAM_L1? */ | ||
1884 | status = | ||
1885 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1886 | DIF_PLL_CTRL, 0, 31, 0x6503bc0c); | ||
1887 | status = | ||
1888 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1889 | DIF_PLL_CTRL1, 0, 31, 0xbd038c85); | ||
1890 | status = | ||
1891 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1892 | DIF_PLL_CTRL2, 0, 31, 0x1db4640a); | ||
1893 | status = | ||
1894 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1895 | DIF_PLL_CTRL3, 0, 31, 0x00008800); | ||
1896 | status = | ||
1897 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1898 | DIF_AGC_IF_REF, 0, 31, 0x888C0380); | ||
1899 | status = | ||
1900 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1901 | DIF_AGC_CTRL_IF, 0, 31, 0xe0262600); | ||
1902 | status = | ||
1903 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1904 | DIF_AGC_CTRL_INT, 0, 31, 0xc2171700); | ||
1905 | status = | ||
1906 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1907 | DIF_AGC_CTRL_RF, 0, 31, 0xc2262600); | ||
1908 | status = | ||
1909 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1910 | DIF_AGC_IF_INT_CURRENT, 0, 31, | ||
1911 | 0x26001700); | ||
1912 | status = | ||
1913 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1914 | DIF_AGC_RF_CURRENT, 0, 31, | ||
1915 | 0x00002660); | ||
1916 | status = | ||
1917 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1918 | DIF_VID_AUD_OVERRIDE, 0, 31, | ||
1919 | 0x27000100); | ||
1920 | status = | ||
1921 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1922 | DIF_AV_SEP_CTRL, 0, 31, 0x3F3530ec); | ||
1923 | status = | ||
1924 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1925 | DIF_COMP_FLT_CTRL, 0, 31, | ||
1926 | 0x00000000); | ||
1927 | status = | ||
1928 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1929 | DIF_SRC_PHASE_INC, 0, 31, | ||
1930 | 0x1befbf06); | ||
1931 | status = | ||
1932 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1933 | DIF_SRC_GAIN_CONTROL, 0, 31, | ||
1934 | 0x000035e8); | ||
1935 | status = | ||
1936 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1937 | DIF_RPT_VARIANCE, 0, 31, 0x00000000); | ||
1938 | status = | ||
1939 | cx231xx_reg_mask_write(dev, HAMMERHEAD_I2C_ADDRESS, 32, | ||
1940 | DIF_VIDEO_AGC_CTRL, 0, 31, | ||
1941 | 0xf2560000); | ||
1942 | |||
1943 | /* Save the Spec Inversion value */ | ||
1944 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | ||
1945 | dif_misc_ctrl_value |= 0x3a023F11; | ||
1946 | |||
1947 | } else { /* V4L2_STD_NTSC_M (75 IRE Setup) Or V4L2_STD_NTSC_M_JP (Japan, 0 IRE Setup) */ | ||
1948 | |||
1949 | /* For NTSC the centre frequency of video coming out of sidewinder is | ||
1950 | around 7.1MHz or 3.6MHz depending on the spectral inversion. | ||
1951 | so for a non spectrally inverted channel the pll freq word is 0x03420c49 | ||
1952 | */ | ||
1953 | |||
1954 | status = | ||
1955 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1956 | DIF_PLL_CTRL, 2, 0x6503BC0C, 4); | ||
1957 | status = | ||
1958 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1959 | DIF_PLL_CTRL1, 2, 0xBD038C85, 4); | ||
1960 | status = | ||
1961 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1962 | DIF_PLL_CTRL2, 2, 0x1DB4640A, 4); | ||
1963 | status = | ||
1964 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1965 | DIF_PLL_CTRL3, 2, 0x00008800, 4); | ||
1966 | status = | ||
1967 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1968 | DIF_AGC_IF_REF, 2, 0x444C0380, 4); | ||
1969 | status = | ||
1970 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1971 | DIF_AGC_IF_INT_CURRENT, 2, | ||
1972 | 0x26001700, 4); | ||
1973 | status = | ||
1974 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1975 | DIF_AGC_RF_CURRENT, 2, 0x00002660, | ||
1976 | 4); | ||
1977 | status = | ||
1978 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1979 | DIF_VIDEO_AGC_CTRL, 2, 0x04000800, | ||
1980 | 4); | ||
1981 | status = | ||
1982 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1983 | DIF_VID_AUD_OVERRIDE, 2, 0x27000100, | ||
1984 | 4); | ||
1985 | status = | ||
1986 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1987 | DIF_AV_SEP_CTRL, 2, 0x01296e1f, 4); | ||
1988 | |||
1989 | status = | ||
1990 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1991 | DIF_COMP_FLT_CTRL, 2, 0x009f50c1, 4); | ||
1992 | status = | ||
1993 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1994 | DIF_SRC_PHASE_INC, 2, 0x1befbf06, 4); | ||
1995 | status = | ||
1996 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
1997 | DIF_SRC_GAIN_CONTROL, 2, 0x000035e8, | ||
1998 | 4); | ||
1999 | |||
2000 | status = | ||
2001 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
2002 | DIF_AGC_CTRL_IF, 2, 0xC2262600, 4); | ||
2003 | status = | ||
2004 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
2005 | DIF_AGC_CTRL_INT, 2, 0xC2262600, 4); | ||
2006 | status = | ||
2007 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | ||
2008 | DIF_AGC_CTRL_RF, 2, 0xC2262600, 4); | ||
2009 | |||
2010 | /* Save the Spec Inversion value */ | ||
2011 | dif_misc_ctrl_value &= FLD_DIF_SPEC_INV; | ||
2012 | dif_misc_ctrl_value |= 0x3a003F10; | ||
2013 | |||
2014 | } | ||
2015 | |||
2016 | /* The AGC values should be the same for all standards, | ||
2017 | AUD_SRC_SEL[19] should always be disabled */ | ||
2018 | dif_misc_ctrl_value &= ~FLD_DIF_AUD_SRC_SEL; | ||
2019 | |||
2020 | /* It is still possible to get Set Standard calls even when we are in FM mode | ||
2021 | This is done to override the value for FM. */ | ||
2022 | if (dev->active_mode == V4L2_TUNER_RADIO) | ||
2023 | dif_misc_ctrl_value = 0x7a080000; | ||
2024 | |||
2025 | /* Write the calculated value for misc ontrol register */ | ||
2026 | status = | ||
2027 | cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, DIF_MISC_CTRL, | ||
2028 | 2, dif_misc_ctrl_value, 4); | ||
2029 | |||
2030 | return status; | ||
1320 | } | 2031 | } |
1321 | 2032 | ||
1322 | int cx231xx_tuner_pre_channel_change(struct cx231xx *dev) | 2033 | int cx231xx_tuner_pre_channel_change(struct cx231xx *dev) |
@@ -1325,101 +2036,103 @@ int cx231xx_tuner_pre_channel_change(struct cx231xx *dev) | |||
1325 | u32 dwval; | 2036 | u32 dwval; |
1326 | 2037 | ||
1327 | /* Set the RF and IF k_agc values to 3 */ | 2038 | /* Set the RF and IF k_agc values to 3 */ |
1328 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 2039 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1329 | DIF_AGC_IF_REF, 2, &dwval, 4); | 2040 | DIF_AGC_IF_REF, 2, &dwval, 4); |
1330 | dwval &= ~(FLD_DIF_K_AGC_RF | FLD_DIF_K_AGC_IF); | 2041 | dwval &= ~(FLD_DIF_K_AGC_RF | FLD_DIF_K_AGC_IF); |
1331 | dwval |= 0x33000000; | 2042 | dwval |= 0x33000000; |
1332 | 2043 | ||
1333 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 2044 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1334 | DIF_AGC_IF_REF, 2, dwval, 4); | 2045 | DIF_AGC_IF_REF, 2, dwval, 4); |
1335 | 2046 | ||
1336 | return status; | 2047 | return status; |
1337 | } | 2048 | } |
1338 | 2049 | ||
1339 | int cx231xx_tuner_post_channel_change(struct cx231xx *dev) | 2050 | int cx231xx_tuner_post_channel_change(struct cx231xx *dev) |
1340 | { | 2051 | { |
1341 | int status = 0; | 2052 | int status = 0; |
1342 | u32 dwval; | 2053 | u32 dwval; |
1343 | 2054 | ||
1344 | /* Set the RF and IF k_agc values to 4 for PAL/NTSC and 8 for SECAM */ | 2055 | /* Set the RF and IF k_agc values to 4 for PAL/NTSC and 8 for SECAM */ |
1345 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 2056 | status = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1346 | DIF_AGC_IF_REF, 2, &dwval, 4); | 2057 | DIF_AGC_IF_REF, 2, &dwval, 4); |
1347 | dwval &= ~(FLD_DIF_K_AGC_RF | FLD_DIF_K_AGC_IF); | 2058 | dwval &= ~(FLD_DIF_K_AGC_RF | FLD_DIF_K_AGC_IF); |
1348 | 2059 | ||
1349 | if(dev->norm & ( V4L2_STD_SECAM_L | V4L2_STD_SECAM_B | V4L2_STD_SECAM_D) ) { | 2060 | if (dev-> |
1350 | dwval |= 0x88000000; | 2061 | norm & (V4L2_STD_SECAM_L | V4L2_STD_SECAM_B | V4L2_STD_SECAM_D)) { |
1351 | } else { | 2062 | dwval |= 0x88000000; |
1352 | dwval |= 0x44000000; | 2063 | } else { |
1353 | } | 2064 | dwval |= 0x44000000; |
2065 | } | ||
1354 | 2066 | ||
1355 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, | 2067 | status = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1356 | DIF_AGC_IF_REF, 2, dwval, 4); | 2068 | DIF_AGC_IF_REF, 2, dwval, 4); |
1357 | 2069 | ||
1358 | return status; | 2070 | return status; |
1359 | } | 2071 | } |
1360 | 2072 | ||
1361 | |||
1362 | |||
1363 | /************************************************************************************* | 2073 | /************************************************************************************* |
1364 | * F L A T I R O N - B L O C K C O N T R O L functions * | 2074 | * F L A T I R O N - B L O C K C O N T R O L functions * |
1365 | *************************************************************************************/ | 2075 | *************************************************************************************/ |
1366 | int cx231xx_flatiron_initialize(struct cx231xx *dev) | 2076 | int cx231xx_flatiron_initialize(struct cx231xx *dev) |
1367 | { | 2077 | { |
1368 | int status = 0; | 2078 | int status = 0; |
1369 | u32 value; | 2079 | u32 value; |
1370 | 2080 | ||
1371 | status = cx231xx_read_i2c_data(dev, Flatrion_DEVICE_ADDRESS, CH_PWR_CTRL1, 1, &value, 1); | 2081 | status = |
1372 | /* enables clock to delta-sigma and decimation filter */ | 2082 | cx231xx_read_i2c_data(dev, Flatrion_DEVICE_ADDRESS, CH_PWR_CTRL1, 1, |
1373 | value |= 0x80; | 2083 | &value, 1); |
1374 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, | 2084 | /* enables clock to delta-sigma and decimation filter */ |
1375 | CH_PWR_CTRL1, 1, value, 1); | 2085 | value |= 0x80; |
1376 | /* power up all channel */ | 2086 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, |
1377 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, | 2087 | CH_PWR_CTRL1, 1, value, 1); |
1378 | CH_PWR_CTRL2, 1, 0x00, 1); | 2088 | /* power up all channel */ |
1379 | 2089 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, | |
1380 | return status; | 2090 | CH_PWR_CTRL2, 1, 0x00, 1); |
2091 | |||
2092 | return status; | ||
1381 | } | 2093 | } |
1382 | 2094 | ||
1383 | int cx231xx_flatiron_update_power_control(struct cx231xx *dev, AV_MODE avmode) | 2095 | int cx231xx_flatiron_update_power_control(struct cx231xx *dev, AV_MODE avmode) |
1384 | { | 2096 | { |
1385 | int status = 0; | 2097 | int status = 0; |
1386 | u32 value=0; | 2098 | u32 value = 0; |
1387 | 2099 | ||
1388 | if(avmode!=POLARIS_AVMODE_ENXTERNAL_AV) { | 2100 | if (avmode != POLARIS_AVMODE_ENXTERNAL_AV) { |
1389 | status = cx231xx_read_i2c_data(dev, Flatrion_DEVICE_ADDRESS, CH_PWR_CTRL2, 1, &value, 1); | 2101 | status = |
1390 | value |= 0xfe; | 2102 | cx231xx_read_i2c_data(dev, Flatrion_DEVICE_ADDRESS, |
1391 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, | 2103 | CH_PWR_CTRL2, 1, &value, 1); |
1392 | CH_PWR_CTRL2, 1, value, 1); | 2104 | value |= 0xfe; |
1393 | } | 2105 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, |
1394 | else { | 2106 | CH_PWR_CTRL2, 1, value, 1); |
1395 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, | 2107 | } else { |
1396 | CH_PWR_CTRL2, 1, 0x00, 1); | 2108 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, |
1397 | } | 2109 | CH_PWR_CTRL2, 1, 0x00, 1); |
1398 | 2110 | } | |
1399 | return status; | 2111 | |
2112 | return status; | ||
1400 | } | 2113 | } |
1401 | 2114 | ||
1402 | /* set flatiron for audio input types */ | 2115 | /* set flatiron for audio input types */ |
1403 | int cx231xx_flatiron_set_audio_input(struct cx231xx *dev, u8 audio_input) | 2116 | int cx231xx_flatiron_set_audio_input(struct cx231xx *dev, u8 audio_input) |
1404 | { | 2117 | { |
1405 | int status = 0; | 2118 | int status = 0; |
1406 | |||
1407 | switch(audio_input) { | ||
1408 | case CX231XX_AMUX_LINE_IN: | ||
1409 | 2119 | ||
1410 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, | 2120 | switch (audio_input) { |
1411 | CH_PWR_CTRL2, 1, 0x00, 1); | 2121 | case CX231XX_AMUX_LINE_IN: |
1412 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, | 2122 | |
1413 | CH_PWR_CTRL1, 1, 0x80, 1); | 2123 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, |
1414 | break; | 2124 | CH_PWR_CTRL2, 1, 0x00, 1); |
1415 | case CX231XX_AMUX_VIDEO: | 2125 | status = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, |
1416 | default: | 2126 | CH_PWR_CTRL1, 1, 0x80, 1); |
1417 | break; | 2127 | break; |
1418 | } | 2128 | case CX231XX_AMUX_VIDEO: |
2129 | default: | ||
2130 | break; | ||
2131 | } | ||
1419 | 2132 | ||
1420 | dev->ctl_ainput = audio_input; | 2133 | dev->ctl_ainput = audio_input; |
1421 | 2134 | ||
1422 | return status; | 2135 | return status; |
1423 | } | 2136 | } |
1424 | 2137 | ||
1425 | /************************************************************************************* | 2138 | /************************************************************************************* |
@@ -1427,438 +2140,467 @@ int cx231xx_flatiron_set_audio_input(struct cx231xx *dev, u8 audio_input) | |||
1427 | *************************************************************************************/ | 2140 | *************************************************************************************/ |
1428 | int cx231xx_set_power_mode(struct cx231xx *dev, AV_MODE mode) | 2141 | int cx231xx_set_power_mode(struct cx231xx *dev, AV_MODE mode) |
1429 | { | 2142 | { |
1430 | u8 value[4] ={0,0,0,0}; | 2143 | u8 value[4] = { 0, 0, 0, 0 }; |
1431 | u32 tmp = 0; | 2144 | u32 tmp = 0; |
1432 | int status = 0; | 2145 | int status = 0; |
1433 | 2146 | ||
1434 | if(dev->power_mode != mode) | 2147 | if (dev->power_mode != mode) |
1435 | dev->power_mode = mode; | 2148 | dev->power_mode = mode; |
1436 | else { | 2149 | else { |
1437 | cx231xx_info(" setPowerMode::mode = %d, No Change req.\n",mode); | 2150 | cx231xx_info(" setPowerMode::mode = %d, No Change req.\n", |
1438 | return 0; | 2151 | mode); |
1439 | } | 2152 | return 0; |
1440 | 2153 | } | |
1441 | cx231xx_info(" setPowerMode::mode = %d\n",mode); | 2154 | |
1442 | 2155 | cx231xx_info(" setPowerMode::mode = %d\n", mode); | |
1443 | status = cx231xx_read_ctrl_reg(dev,VRT_GET_REGISTER, PWR_CTL_EN, value, 4); | 2156 | |
1444 | if(status < 0) | 2157 | status = |
1445 | return status; | 2158 | cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, PWR_CTL_EN, value, 4); |
1446 | 2159 | if (status < 0) | |
1447 | tmp = *((u32 *)value); | 2160 | return status; |
1448 | 2161 | ||
1449 | switch(mode) { | 2162 | tmp = *((u32 *) value); |
1450 | case POLARIS_AVMODE_ENXTERNAL_AV: | 2163 | |
1451 | 2164 | switch (mode) { | |
1452 | tmp &= (~PWR_MODE_MASK); | 2165 | case POLARIS_AVMODE_ENXTERNAL_AV: |
1453 | 2166 | ||
1454 | tmp |= PWR_AV_EN; | 2167 | tmp &= (~PWR_MODE_MASK); |
1455 | value[0]=(u8)tmp; | 2168 | |
1456 | value[1]=(u8)(tmp>>8); | 2169 | tmp |= PWR_AV_EN; |
1457 | value[2]=(u8)(tmp>>16); | 2170 | value[0] = (u8) tmp; |
1458 | value[3]=(u8)(tmp>>24); | 2171 | value[1] = (u8) (tmp >> 8); |
1459 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2172 | value[2] = (u8) (tmp >> 16); |
1460 | msleep(PWR_SLEEP_INTERVAL); | 2173 | value[3] = (u8) (tmp >> 24); |
1461 | 2174 | status = | |
1462 | tmp |= PWR_ISO_EN; | 2175 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, PWR_CTL_EN, |
1463 | value[0]=(u8)tmp; | 2176 | value, 4); |
1464 | value[1]=(u8)(tmp>>8); | 2177 | msleep(PWR_SLEEP_INTERVAL); |
1465 | value[2]=(u8)(tmp>>16); | 2178 | |
1466 | value[3]=(u8)(tmp>>24); | 2179 | tmp |= PWR_ISO_EN; |
1467 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2180 | value[0] = (u8) tmp; |
1468 | msleep(PWR_SLEEP_INTERVAL); | 2181 | value[1] = (u8) (tmp >> 8); |
1469 | 2182 | value[2] = (u8) (tmp >> 16); | |
1470 | tmp |=POLARIS_AVMODE_ENXTERNAL_AV; | 2183 | value[3] = (u8) (tmp >> 24); |
1471 | value[0]=(u8)tmp; | 2184 | status = |
1472 | value[1]=(u8)(tmp>>8); | 2185 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, PWR_CTL_EN, |
1473 | value[2]=(u8)(tmp>>16); | 2186 | value, 4); |
1474 | value[3]=(u8)(tmp>>24); | 2187 | msleep(PWR_SLEEP_INTERVAL); |
1475 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2188 | |
1476 | 2189 | tmp |= POLARIS_AVMODE_ENXTERNAL_AV; | |
1477 | dev->xc_fw_load_done = 0; /* reset state of xceive tuner */ | 2190 | value[0] = (u8) tmp; |
1478 | break; | 2191 | value[1] = (u8) (tmp >> 8); |
1479 | 2192 | value[2] = (u8) (tmp >> 16); | |
1480 | case POLARIS_AVMODE_ANALOGT_TV: | 2193 | value[3] = (u8) (tmp >> 24); |
1481 | 2194 | status = | |
1482 | tmp &= (~PWR_DEMOD_EN); | 2195 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, PWR_CTL_EN, |
1483 | tmp |= (I2C_DEMOD_EN); | 2196 | value, 4); |
1484 | value[0]=(u8)tmp; | 2197 | |
1485 | value[1]=(u8)(tmp>>8); | 2198 | dev->xc_fw_load_done = 0; /* reset state of xceive tuner */ |
1486 | value[2]=(u8)(tmp>>16); | 2199 | break; |
1487 | value[3]=(u8)(tmp>>24); | 2200 | |
1488 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2201 | case POLARIS_AVMODE_ANALOGT_TV: |
1489 | msleep(PWR_SLEEP_INTERVAL); | 2202 | |
1490 | 2203 | tmp &= (~PWR_DEMOD_EN); | |
1491 | if(!(tmp & PWR_TUNER_EN)) { | 2204 | tmp |= (I2C_DEMOD_EN); |
1492 | tmp |= (PWR_TUNER_EN); | 2205 | value[0] = (u8) tmp; |
1493 | value[0]=(u8)tmp; | 2206 | value[1] = (u8) (tmp >> 8); |
1494 | value[1]=(u8)(tmp>>8); | 2207 | value[2] = (u8) (tmp >> 16); |
1495 | value[2]=(u8)(tmp>>16); | 2208 | value[3] = (u8) (tmp >> 24); |
1496 | value[3]=(u8)(tmp>>24); | 2209 | status = |
1497 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2210 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, PWR_CTL_EN, |
1498 | msleep(PWR_SLEEP_INTERVAL); | 2211 | value, 4); |
1499 | } | 2212 | msleep(PWR_SLEEP_INTERVAL); |
1500 | 2213 | ||
1501 | if(!(tmp & PWR_AV_EN)) { | 2214 | if (!(tmp & PWR_TUNER_EN)) { |
1502 | tmp |= PWR_AV_EN; | 2215 | tmp |= (PWR_TUNER_EN); |
1503 | value[0]=(u8)tmp; | 2216 | value[0] = (u8) tmp; |
1504 | value[1]=(u8)(tmp>>8); | 2217 | value[1] = (u8) (tmp >> 8); |
1505 | value[2]=(u8)(tmp>>16); | 2218 | value[2] = (u8) (tmp >> 16); |
1506 | value[3]=(u8)(tmp>>24); | 2219 | value[3] = (u8) (tmp >> 24); |
1507 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2220 | status = |
1508 | msleep(PWR_SLEEP_INTERVAL); | 2221 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
1509 | } | 2222 | PWR_CTL_EN, value, 4); |
1510 | if(!(tmp & PWR_ISO_EN )) { | 2223 | msleep(PWR_SLEEP_INTERVAL); |
1511 | tmp |= PWR_ISO_EN; | 2224 | } |
1512 | value[0]=(u8)tmp; | 2225 | |
1513 | value[1]=(u8)(tmp>>8); | 2226 | if (!(tmp & PWR_AV_EN)) { |
1514 | value[2]=(u8)(tmp>>16); | 2227 | tmp |= PWR_AV_EN; |
1515 | value[3]=(u8)(tmp>>24); | 2228 | value[0] = (u8) tmp; |
1516 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2229 | value[1] = (u8) (tmp >> 8); |
1517 | msleep(PWR_SLEEP_INTERVAL); | 2230 | value[2] = (u8) (tmp >> 16); |
1518 | } | 2231 | value[3] = (u8) (tmp >> 24); |
1519 | 2232 | status = | |
1520 | if(!(tmp & POLARIS_AVMODE_ANALOGT_TV )) { | 2233 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
1521 | tmp |= POLARIS_AVMODE_ANALOGT_TV; | 2234 | PWR_CTL_EN, value, 4); |
1522 | value[0]=(u8)tmp; | 2235 | msleep(PWR_SLEEP_INTERVAL); |
1523 | value[1]=(u8)(tmp>>8); | 2236 | } |
1524 | value[2]=(u8)(tmp>>16); | 2237 | if (!(tmp & PWR_ISO_EN)) { |
1525 | value[3]=(u8)(tmp>>24); | 2238 | tmp |= PWR_ISO_EN; |
1526 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2239 | value[0] = (u8) tmp; |
1527 | msleep(PWR_SLEEP_INTERVAL); | 2240 | value[1] = (u8) (tmp >> 8); |
1528 | } | 2241 | value[2] = (u8) (tmp >> 16); |
1529 | 2242 | value[3] = (u8) (tmp >> 24); | |
1530 | if( (dev->model == CX231XX_BOARD_CNXT_RDE_250) || | 2243 | status = |
1531 | (dev->model == CX231XX_BOARD_CNXT_RDU_250)) { | 2244 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
1532 | 2245 | PWR_CTL_EN, value, 4); | |
1533 | /* tuner path to channel 1 from port 3 */ | 2246 | msleep(PWR_SLEEP_INTERVAL); |
1534 | cx231xx_enable_i2c_for_tuner(dev, I2C_3); | 2247 | } |
1535 | 2248 | ||
1536 | if(dev->cx231xx_reset_analog_tuner) | 2249 | if (!(tmp & POLARIS_AVMODE_ANALOGT_TV)) { |
1537 | dev->cx231xx_reset_analog_tuner(dev); | 2250 | tmp |= POLARIS_AVMODE_ANALOGT_TV; |
1538 | } | 2251 | value[0] = (u8) tmp; |
1539 | break; | 2252 | value[1] = (u8) (tmp >> 8); |
1540 | 2253 | value[2] = (u8) (tmp >> 16); | |
1541 | case POLARIS_AVMODE_DIGITAL: | 2254 | value[3] = (u8) (tmp >> 24); |
1542 | 2255 | status = | |
1543 | if(!(tmp & PWR_TUNER_EN)) { | 2256 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
1544 | tmp |= (PWR_TUNER_EN); | 2257 | PWR_CTL_EN, value, 4); |
1545 | value[0]=(u8)tmp; | 2258 | msleep(PWR_SLEEP_INTERVAL); |
1546 | value[1]=(u8)(tmp>>8); | 2259 | } |
1547 | value[2]=(u8)(tmp>>16); | 2260 | |
1548 | value[3]=(u8)(tmp>>24); | 2261 | if ((dev->model == CX231XX_BOARD_CNXT_RDE_250) || |
1549 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2262 | (dev->model == CX231XX_BOARD_CNXT_RDU_250)) { |
1550 | msleep(PWR_SLEEP_INTERVAL); | 2263 | |
1551 | } | 2264 | /* tuner path to channel 1 from port 3 */ |
1552 | if(!(tmp & PWR_AV_EN)) { | 2265 | cx231xx_enable_i2c_for_tuner(dev, I2C_3); |
1553 | tmp |= PWR_AV_EN; | 2266 | |
1554 | value[0]=(u8)tmp; | 2267 | if (dev->cx231xx_reset_analog_tuner) |
1555 | value[1]=(u8)(tmp>>8); | 2268 | dev->cx231xx_reset_analog_tuner(dev); |
1556 | value[2]=(u8)(tmp>>16); | 2269 | } |
1557 | value[3]=(u8)(tmp>>24); | 2270 | break; |
1558 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2271 | |
1559 | msleep(PWR_SLEEP_INTERVAL); | 2272 | case POLARIS_AVMODE_DIGITAL: |
1560 | } | 2273 | |
1561 | if(!(tmp & PWR_ISO_EN)) { | 2274 | if (!(tmp & PWR_TUNER_EN)) { |
1562 | tmp |= PWR_ISO_EN; | 2275 | tmp |= (PWR_TUNER_EN); |
1563 | value[0]=(u8)tmp; | 2276 | value[0] = (u8) tmp; |
1564 | value[1]=(u8)(tmp>>8); | 2277 | value[1] = (u8) (tmp >> 8); |
1565 | value[2]=(u8)(tmp>>16); | 2278 | value[2] = (u8) (tmp >> 16); |
1566 | value[3]=(u8)(tmp>>24); | 2279 | value[3] = (u8) (tmp >> 24); |
1567 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2280 | status = |
1568 | msleep(PWR_SLEEP_INTERVAL); | 2281 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
1569 | } | 2282 | PWR_CTL_EN, value, 4); |
1570 | 2283 | msleep(PWR_SLEEP_INTERVAL); | |
1571 | tmp |= POLARIS_AVMODE_DIGITAL|I2C_DEMOD_EN; | 2284 | } |
1572 | value[0]=(u8)tmp; | 2285 | if (!(tmp & PWR_AV_EN)) { |
1573 | value[1]=(u8)(tmp>>8); | 2286 | tmp |= PWR_AV_EN; |
1574 | value[2]=(u8)(tmp>>16); | 2287 | value[0] = (u8) tmp; |
1575 | value[3]=(u8)(tmp>>24); | 2288 | value[1] = (u8) (tmp >> 8); |
1576 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2289 | value[2] = (u8) (tmp >> 16); |
1577 | msleep(PWR_SLEEP_INTERVAL); | 2290 | value[3] = (u8) (tmp >> 24); |
1578 | 2291 | status = | |
1579 | if(!(tmp & PWR_DEMOD_EN)) { | 2292 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
1580 | tmp |= PWR_DEMOD_EN; | 2293 | PWR_CTL_EN, value, 4); |
1581 | value[0]=(u8)tmp; | 2294 | msleep(PWR_SLEEP_INTERVAL); |
1582 | value[1]=(u8)(tmp>>8); | 2295 | } |
1583 | value[2]=(u8)(tmp>>16); | 2296 | if (!(tmp & PWR_ISO_EN)) { |
1584 | value[3]=(u8)(tmp>>24); | 2297 | tmp |= PWR_ISO_EN; |
1585 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2298 | value[0] = (u8) tmp; |
1586 | msleep(PWR_SLEEP_INTERVAL); | 2299 | value[1] = (u8) (tmp >> 8); |
1587 | } | 2300 | value[2] = (u8) (tmp >> 16); |
1588 | 2301 | value[3] = (u8) (tmp >> 24); | |
1589 | if( (dev->model == CX231XX_BOARD_CNXT_RDE_250) || | 2302 | status = |
1590 | (dev->model == CX231XX_BOARD_CNXT_RDU_250)) { | 2303 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
1591 | 2304 | PWR_CTL_EN, value, 4); | |
1592 | /* tuner path to channel 1 from port 3 */ | 2305 | msleep(PWR_SLEEP_INTERVAL); |
1593 | cx231xx_enable_i2c_for_tuner(dev, I2C_3); | 2306 | } |
1594 | 2307 | ||
1595 | if(dev->cx231xx_reset_analog_tuner) | 2308 | tmp |= POLARIS_AVMODE_DIGITAL | I2C_DEMOD_EN; |
1596 | dev->cx231xx_reset_analog_tuner(dev); | 2309 | value[0] = (u8) tmp; |
1597 | } | 2310 | value[1] = (u8) (tmp >> 8); |
1598 | break; | 2311 | value[2] = (u8) (tmp >> 16); |
1599 | 2312 | value[3] = (u8) (tmp >> 24); | |
1600 | default: | 2313 | status = |
1601 | break; | 2314 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, PWR_CTL_EN, |
1602 | } | 2315 | value, 4); |
1603 | 2316 | msleep(PWR_SLEEP_INTERVAL); | |
1604 | msleep(PWR_SLEEP_INTERVAL); | 2317 | |
1605 | 2318 | if (!(tmp & PWR_DEMOD_EN)) { | |
1606 | /* For power saving, only enable Pwr_resetout_n when digital TV is selected. */ | 2319 | tmp |= PWR_DEMOD_EN; |
1607 | if(mode == POLARIS_AVMODE_DIGITAL) { | 2320 | value[0] = (u8) tmp; |
1608 | tmp |= PWR_RESETOUT_EN; | 2321 | value[1] = (u8) (tmp >> 8); |
1609 | value[0]=(u8)tmp; | 2322 | value[2] = (u8) (tmp >> 16); |
1610 | value[1]=(u8)(tmp>>8); | 2323 | value[3] = (u8) (tmp >> 24); |
1611 | value[2]=(u8)(tmp>>16); | 2324 | status = |
1612 | value[3]=(u8)(tmp>>24); | 2325 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, |
1613 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2326 | PWR_CTL_EN, value, 4); |
1614 | msleep(PWR_SLEEP_INTERVAL); | 2327 | msleep(PWR_SLEEP_INTERVAL); |
1615 | } | 2328 | } |
1616 | 2329 | ||
1617 | /* update power control for colibri */ | 2330 | if ((dev->model == CX231XX_BOARD_CNXT_RDE_250) || |
1618 | status = cx231xx_colibri_update_power_control(dev, mode); | 2331 | (dev->model == CX231XX_BOARD_CNXT_RDU_250)) { |
1619 | 2332 | ||
1620 | /* update power control for flatiron */ | 2333 | /* tuner path to channel 1 from port 3 */ |
1621 | status = cx231xx_flatiron_update_power_control(dev, mode); | 2334 | cx231xx_enable_i2c_for_tuner(dev, I2C_3); |
1622 | 2335 | ||
1623 | status = cx231xx_read_ctrl_reg(dev,VRT_GET_REGISTER, PWR_CTL_EN, value, 4); | 2336 | if (dev->cx231xx_reset_analog_tuner) |
1624 | cx231xx_info(" The data of PWR_CTL_EN register 0x74=0x%0x,0x%0x,0x%0x,0x%0x\n",value[0],value[1],value[2],value[3]); | 2337 | dev->cx231xx_reset_analog_tuner(dev); |
1625 | 2338 | } | |
1626 | return status; | 2339 | break; |
2340 | |||
2341 | default: | ||
2342 | break; | ||
2343 | } | ||
2344 | |||
2345 | msleep(PWR_SLEEP_INTERVAL); | ||
2346 | |||
2347 | /* For power saving, only enable Pwr_resetout_n when digital TV is selected. */ | ||
2348 | if (mode == POLARIS_AVMODE_DIGITAL) { | ||
2349 | tmp |= PWR_RESETOUT_EN; | ||
2350 | value[0] = (u8) tmp; | ||
2351 | value[1] = (u8) (tmp >> 8); | ||
2352 | value[2] = (u8) (tmp >> 16); | ||
2353 | value[3] = (u8) (tmp >> 24); | ||
2354 | status = | ||
2355 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, PWR_CTL_EN, | ||
2356 | value, 4); | ||
2357 | msleep(PWR_SLEEP_INTERVAL); | ||
2358 | } | ||
2359 | |||
2360 | /* update power control for colibri */ | ||
2361 | status = cx231xx_colibri_update_power_control(dev, mode); | ||
2362 | |||
2363 | /* update power control for flatiron */ | ||
2364 | status = cx231xx_flatiron_update_power_control(dev, mode); | ||
2365 | |||
2366 | status = | ||
2367 | cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, PWR_CTL_EN, value, 4); | ||
2368 | cx231xx_info | ||
2369 | (" The data of PWR_CTL_EN register 0x74=0x%0x,0x%0x,0x%0x,0x%0x\n", | ||
2370 | value[0], value[1], value[2], value[3]); | ||
2371 | |||
2372 | return status; | ||
1627 | } | 2373 | } |
1628 | 2374 | ||
1629 | int cx231xx_power_suspend(struct cx231xx *dev) | 2375 | int cx231xx_power_suspend(struct cx231xx *dev) |
1630 | { | 2376 | { |
1631 | u8 value[4] ={0,0,0,0}; | 2377 | u8 value[4] = { 0, 0, 0, 0 }; |
1632 | u32 tmp = 0; | 2378 | u32 tmp = 0; |
1633 | int status = 0; | 2379 | int status = 0; |
1634 | 2380 | ||
1635 | status = cx231xx_read_ctrl_reg(dev,VRT_GET_REGISTER, PWR_CTL_EN, value, 4); | 2381 | status = |
1636 | if(status > 0) | 2382 | cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, PWR_CTL_EN, value, 4); |
1637 | return status; | 2383 | if (status > 0) |
2384 | return status; | ||
1638 | 2385 | ||
1639 | tmp = *((u32 *)value); | 2386 | tmp = *((u32 *) value); |
1640 | tmp &= (~PWR_MODE_MASK); | 2387 | tmp &= (~PWR_MODE_MASK); |
1641 | 2388 | ||
1642 | value[0]=(u8)tmp; | 2389 | value[0] = (u8) tmp; |
1643 | value[1]=(u8)(tmp>>8); | 2390 | value[1] = (u8) (tmp >> 8); |
1644 | value[2]=(u8)(tmp>>16); | 2391 | value[2] = (u8) (tmp >> 16); |
1645 | value[3]=(u8)(tmp>>24); | 2392 | value[3] = (u8) (tmp >> 24); |
1646 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, PWR_CTL_EN,value,4); | 2393 | status = |
2394 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, PWR_CTL_EN, value, 4); | ||
1647 | 2395 | ||
1648 | return status; | 2396 | return status; |
1649 | } | 2397 | } |
1650 | 2398 | ||
1651 | |||
1652 | /************************************************************************************* | 2399 | /************************************************************************************* |
1653 | * S T R E A M C O N T R O L functions * | 2400 | * S T R E A M C O N T R O L functions * |
1654 | *************************************************************************************/ | 2401 | *************************************************************************************/ |
1655 | int cx231xx_start_stream(struct cx231xx *dev, u32 ep_mask) | 2402 | int cx231xx_start_stream(struct cx231xx *dev, u32 ep_mask) |
1656 | { | 2403 | { |
1657 | u8 value[4] = {0x0, 0x0, 0x0, 0x0}; | 2404 | u8 value[4] = { 0x0, 0x0, 0x0, 0x0 }; |
1658 | u32 tmp =0; | 2405 | u32 tmp = 0; |
1659 | int status = 0; | 2406 | int status = 0; |
1660 | 2407 | ||
1661 | cx231xx_info("cx231xx_start_stream():: ep_mask = %x\n", ep_mask); | 2408 | cx231xx_info("cx231xx_start_stream():: ep_mask = %x\n", ep_mask); |
1662 | status = cx231xx_read_ctrl_reg(dev,VRT_GET_REGISTER, EP_MODE_SET,value,4); | 2409 | status = |
1663 | if(status < 0) | 2410 | cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, EP_MODE_SET, value, 4); |
1664 | return status; | 2411 | if (status < 0) |
2412 | return status; | ||
1665 | 2413 | ||
1666 | tmp = *((u32 *)value); | 2414 | tmp = *((u32 *) value); |
1667 | tmp |= ep_mask; | 2415 | tmp |= ep_mask; |
1668 | value[0]=(u8) tmp; | 2416 | value[0] = (u8) tmp; |
1669 | value[1]=(u8)(tmp>>8); | 2417 | value[1] = (u8) (tmp >> 8); |
1670 | value[2]=(u8)(tmp>>16); | 2418 | value[2] = (u8) (tmp >> 16); |
1671 | value[3]=(u8)(tmp>>24); | 2419 | value[3] = (u8) (tmp >> 24); |
1672 | 2420 | ||
1673 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, EP_MODE_SET,value,4); | 2421 | status = |
2422 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, EP_MODE_SET, value, | ||
2423 | 4); | ||
1674 | 2424 | ||
1675 | return status; | 2425 | return status; |
1676 | } | 2426 | } |
1677 | 2427 | ||
1678 | int cx231xx_stop_stream(struct cx231xx *dev, u32 ep_mask) | 2428 | int cx231xx_stop_stream(struct cx231xx *dev, u32 ep_mask) |
1679 | { | 2429 | { |
1680 | u8 value[4] = {0x0, 0x0, 0x0, 0x0}; | 2430 | u8 value[4] = { 0x0, 0x0, 0x0, 0x0 }; |
1681 | u32 tmp =0; | 2431 | u32 tmp = 0; |
1682 | int status = 0; | 2432 | int status = 0; |
1683 | 2433 | ||
1684 | cx231xx_info("cx231xx_stop_stream():: ep_mask = %x\n", ep_mask); | 2434 | cx231xx_info("cx231xx_stop_stream():: ep_mask = %x\n", ep_mask); |
1685 | status = cx231xx_read_ctrl_reg(dev,VRT_GET_REGISTER, EP_MODE_SET,value,4); | 2435 | status = |
1686 | if(status < 0) | 2436 | cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, EP_MODE_SET, value, 4); |
1687 | return status; | 2437 | if (status < 0) |
2438 | return status; | ||
1688 | 2439 | ||
1689 | tmp = *((u32 *)value); | 2440 | tmp = *((u32 *) value); |
1690 | tmp&= (~ep_mask); | 2441 | tmp &= (~ep_mask); |
1691 | value[0]=(u8) tmp; | 2442 | value[0] = (u8) tmp; |
1692 | value[1]=(u8)(tmp>>8); | 2443 | value[1] = (u8) (tmp >> 8); |
1693 | value[2]=(u8)(tmp>>16); | 2444 | value[2] = (u8) (tmp >> 16); |
1694 | value[3]=(u8)(tmp>>24); | 2445 | value[3] = (u8) (tmp >> 24); |
1695 | 2446 | ||
1696 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, EP_MODE_SET,value,4); | 2447 | status = |
2448 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, EP_MODE_SET, value, | ||
2449 | 4); | ||
1697 | 2450 | ||
1698 | return status; | 2451 | return status; |
1699 | } | 2452 | } |
1700 | 2453 | ||
1701 | int cx231xx_initialize_stream_xfer(struct cx231xx *dev, u32 media_type) | 2454 | int cx231xx_initialize_stream_xfer(struct cx231xx *dev, u32 media_type) |
1702 | { | 2455 | { |
1703 | int status = 0; | 2456 | int status = 0; |
1704 | |||
1705 | if(dev->udev->speed == USB_SPEED_HIGH) | ||
1706 | { | ||
1707 | switch(media_type) | ||
1708 | { | ||
1709 | case 81: /* audio */ | ||
1710 | cx231xx_info("%s: Audio enter HANC\n",__func__); | ||
1711 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x9300); | ||
1712 | break; | ||
1713 | |||
1714 | case 2: /* vbi */ | ||
1715 | cx231xx_info("%s: set vanc registers\n",__func__); | ||
1716 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x300); | ||
1717 | break; | ||
1718 | |||
1719 | case 3: /* sliced cc */ | ||
1720 | cx231xx_info("%s: set hanc registers\n",__func__); | ||
1721 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x1300); | ||
1722 | break; | ||
1723 | |||
1724 | case 0: /* video */ | ||
1725 | cx231xx_info("%s: set video registers\n",__func__); | ||
1726 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x100); | ||
1727 | break; | ||
1728 | |||
1729 | case 4: /* ts1 */ | ||
1730 | cx231xx_info("%s: set ts1 registers\n",__func__); | ||
1731 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x101); | ||
1732 | status = cx231xx_mode_register(dev, TS1_CFG_REG, 0x400); | ||
1733 | break; | ||
1734 | case 6: /* ts1 parallel mode */ | ||
1735 | cx231xx_info("%s: set ts1 parrallel mode registers\n",__func__); | ||
1736 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x100); | ||
1737 | status = cx231xx_mode_register(dev, TS1_CFG_REG, 0x400); | ||
1738 | break; | ||
1739 | } | ||
1740 | } | ||
1741 | else | ||
1742 | { | ||
1743 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x101); | ||
1744 | } | ||
1745 | |||
1746 | return status; | ||
1747 | } | ||
1748 | |||
1749 | 2457 | ||
2458 | if (dev->udev->speed == USB_SPEED_HIGH) { | ||
2459 | switch (media_type) { | ||
2460 | case 81: /* audio */ | ||
2461 | cx231xx_info("%s: Audio enter HANC\n", __func__); | ||
2462 | status = | ||
2463 | cx231xx_mode_register(dev, TS_MODE_REG, 0x9300); | ||
2464 | break; | ||
2465 | |||
2466 | case 2: /* vbi */ | ||
2467 | cx231xx_info("%s: set vanc registers\n", __func__); | ||
2468 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x300); | ||
2469 | break; | ||
2470 | |||
2471 | case 3: /* sliced cc */ | ||
2472 | cx231xx_info("%s: set hanc registers\n", __func__); | ||
2473 | status = | ||
2474 | cx231xx_mode_register(dev, TS_MODE_REG, 0x1300); | ||
2475 | break; | ||
2476 | |||
2477 | case 0: /* video */ | ||
2478 | cx231xx_info("%s: set video registers\n", __func__); | ||
2479 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x100); | ||
2480 | break; | ||
2481 | |||
2482 | case 4: /* ts1 */ | ||
2483 | cx231xx_info("%s: set ts1 registers\n", __func__); | ||
2484 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x101); | ||
2485 | status = cx231xx_mode_register(dev, TS1_CFG_REG, 0x400); | ||
2486 | break; | ||
2487 | case 6: /* ts1 parallel mode */ | ||
2488 | cx231xx_info("%s: set ts1 parrallel mode registers\n", | ||
2489 | __func__); | ||
2490 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x100); | ||
2491 | status = cx231xx_mode_register(dev, TS1_CFG_REG, 0x400); | ||
2492 | break; | ||
2493 | } | ||
2494 | } else { | ||
2495 | status = cx231xx_mode_register(dev, TS_MODE_REG, 0x101); | ||
2496 | } | ||
1750 | 2497 | ||
2498 | return status; | ||
2499 | } | ||
1751 | 2500 | ||
1752 | int cx231xx_capture_start(struct cx231xx *dev, int start, u8 media_type) | 2501 | int cx231xx_capture_start(struct cx231xx *dev, int start, u8 media_type) |
1753 | { | 2502 | { |
1754 | int rc; | 2503 | int rc; |
1755 | u32 ep_mask = -1; | 2504 | u32 ep_mask = -1; |
1756 | PPCB_CONFIG pcb_config; | 2505 | PPCB_CONFIG pcb_config; |
1757 | 2506 | ||
1758 | /* get EP for media type */ | 2507 | /* get EP for media type */ |
1759 | pcb_config = &dev->current_pcb_config; | 2508 | pcb_config = &dev->current_pcb_config; |
1760 | 2509 | ||
1761 | if(pcb_config->config_num==1) | 2510 | if (pcb_config->config_num == 1) { |
1762 | { | 2511 | switch (media_type) { |
1763 | switch (media_type) | 2512 | case 0: /* Video */ |
1764 | { | 2513 | ep_mask = ENABLE_EP4; /* ep4 [00:1000] */ |
1765 | case 0: /* Video */ | 2514 | break; |
1766 | ep_mask =ENABLE_EP4; /* ep4 [00:1000] */ | 2515 | case 1: /* Audio */ |
1767 | break; | 2516 | ep_mask = ENABLE_EP3; /* ep3 [00:0100] */ |
1768 | case 1: /* Audio */ | 2517 | break; |
1769 | ep_mask =ENABLE_EP3; /* ep3 [00:0100] */ | 2518 | case 2: /* Vbi */ |
1770 | break; | 2519 | ep_mask = ENABLE_EP5; /* ep5 [01:0000] */ |
1771 | case 2: /* Vbi */ | 2520 | break; |
1772 | ep_mask = ENABLE_EP5; /* ep5 [01:0000] */ | 2521 | case 3: /* Sliced_cc */ |
1773 | break; | 2522 | ep_mask = ENABLE_EP6; /* ep6 [10:0000] */ |
1774 | case 3: /* Sliced_cc */ | 2523 | break; |
1775 | ep_mask = ENABLE_EP6; /* ep6 [10:0000] */ | 2524 | case 4: /* ts1 */ |
1776 | break; | 2525 | case 6: /* ts1 parallel mode */ |
1777 | case 4: /* ts1 */ | 2526 | ep_mask = ENABLE_EP1; /* ep1 [00:0001] */ |
1778 | case 6: /* ts1 parallel mode */ | 2527 | break; |
1779 | ep_mask = ENABLE_EP1; /* ep1 [00:0001] */ | 2528 | case 5: /* ts2 */ |
1780 | break; | 2529 | ep_mask = ENABLE_EP2; /* ep2 [00:0010] */ |
1781 | case 5: /* ts2 */ | 2530 | break; |
1782 | ep_mask = ENABLE_EP2; /* ep2 [00:0010] */ | 2531 | } |
1783 | break; | 2532 | |
1784 | } | 2533 | } else if (pcb_config->config_num > 1) { |
1785 | 2534 | switch (media_type) { | |
1786 | } | 2535 | case 0: /* Video */ |
1787 | else if(pcb_config->config_num>1) | 2536 | ep_mask = ENABLE_EP4; /* ep4 [00:1000] */ |
1788 | { | 2537 | break; |
1789 | switch (media_type) | 2538 | case 1: /* Audio */ |
1790 | { | 2539 | ep_mask = ENABLE_EP3; /* ep3 [00:0100] */ |
1791 | case 0: /* Video */ | 2540 | break; |
1792 | ep_mask = ENABLE_EP4; /* ep4 [00:1000] */ | 2541 | case 2: /* Vbi */ |
1793 | break; | 2542 | ep_mask = ENABLE_EP5; /* ep5 [01:0000] */ |
1794 | case 1: /* Audio */ | 2543 | break; |
1795 | ep_mask = ENABLE_EP3; /* ep3 [00:0100] */ | 2544 | case 3: /* Sliced_cc */ |
1796 | break; | 2545 | ep_mask = ENABLE_EP6; /* ep6 [10:0000] */ |
1797 | case 2: /* Vbi */ | 2546 | break; |
1798 | ep_mask = ENABLE_EP5; /* ep5 [01:0000] */ | 2547 | case 4: /* ts1 */ |
1799 | break; | 2548 | case 6: /* ts1 parallel mode */ |
1800 | case 3: /* Sliced_cc */ | 2549 | ep_mask = ENABLE_EP1; /* ep1 [00:0001] */ |
1801 | ep_mask = ENABLE_EP6; /* ep6 [10:0000] */ | 2550 | break; |
1802 | break; | 2551 | case 5: /* ts2 */ |
1803 | case 4: /* ts1 */ | 2552 | ep_mask = ENABLE_EP2; /* ep2 [00:0010] */ |
1804 | case 6: /* ts1 parallel mode */ | 2553 | break; |
1805 | ep_mask = ENABLE_EP1; /* ep1 [00:0001] */ | 2554 | } |
1806 | break; | 2555 | |
1807 | case 5: /* ts2 */ | 2556 | } |
1808 | ep_mask = ENABLE_EP2; /* ep2 [00:0010] */ | 2557 | |
1809 | break; | 2558 | if (start) { |
1810 | } | 2559 | rc = cx231xx_initialize_stream_xfer(dev, media_type); |
1811 | 2560 | ||
1812 | } | 2561 | if (rc < 0) { |
1813 | 2562 | return rc; | |
1814 | if(start) { | 2563 | } |
1815 | rc = cx231xx_initialize_stream_xfer(dev, media_type); | 2564 | |
1816 | 2565 | /* enable video capture */ | |
1817 | if(rc < 0) { | 2566 | if (ep_mask > 0) |
1818 | return rc; | 2567 | rc = cx231xx_start_stream(dev, ep_mask); |
1819 | } | 2568 | } else { |
1820 | 2569 | /* disable video capture */ | |
1821 | /* enable video capture */ | 2570 | if (ep_mask > 0) |
1822 | if(ep_mask > 0 ) | 2571 | rc = cx231xx_stop_stream(dev, ep_mask); |
1823 | rc = cx231xx_start_stream(dev, ep_mask); | 2572 | } |
1824 | } | 2573 | |
1825 | else { | 2574 | if (dev->mode == CX231XX_ANALOG_MODE) { |
1826 | /* disable video capture */ | 2575 | /* do any in Analog mode */ |
1827 | if(ep_mask > 0 ) | 2576 | } else { |
1828 | rc = cx231xx_stop_stream(dev, ep_mask); | 2577 | /* do any in digital mode */ |
1829 | } | 2578 | } |
1830 | |||
1831 | if (dev->mode == CX231XX_ANALOG_MODE){ | ||
1832 | /* do any in Analog mode */ | ||
1833 | } | ||
1834 | else { | ||
1835 | /* do any in digital mode */ | ||
1836 | } | ||
1837 | 2579 | ||
1838 | return rc; | 2580 | return rc; |
1839 | } | 2581 | } |
1840 | EXPORT_SYMBOL_GPL(cx231xx_capture_start); | ||
1841 | 2582 | ||
2583 | EXPORT_SYMBOL_GPL(cx231xx_capture_start); | ||
1842 | 2584 | ||
1843 | /************************************************************************************ | 2585 | /************************************************************************************ |
1844 | * G P I O B I T control functions * | 2586 | * G P I O B I T control functions * |
1845 | *************************************************************************************/ | 2587 | *************************************************************************************/ |
1846 | int cx231xx_set_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8* gpio_val) | 2588 | int cx231xx_set_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8 * gpio_val) |
1847 | { | 2589 | { |
1848 | int status = 0; | 2590 | int status = 0; |
1849 | 2591 | ||
1850 | status = cx231xx_send_gpio_cmd(dev, gpio_bit, gpio_val, 4, 0, 0); | 2592 | status = cx231xx_send_gpio_cmd(dev, gpio_bit, gpio_val, 4, 0, 0); |
1851 | 2593 | ||
1852 | return status; | 2594 | return status; |
1853 | } | 2595 | } |
1854 | 2596 | ||
1855 | int cx231xx_get_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8* gpio_val) | 2597 | int cx231xx_get_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8 * gpio_val) |
1856 | { | 2598 | { |
1857 | int status = 0; | 2599 | int status = 0; |
1858 | 2600 | ||
1859 | status = cx231xx_send_gpio_cmd(dev, gpio_bit, gpio_val, 4, 0, 1); | 2601 | status = cx231xx_send_gpio_cmd(dev, gpio_bit, gpio_val, 4, 0, 1); |
1860 | 2602 | ||
1861 | return status; | 2603 | return status; |
1862 | } | 2604 | } |
1863 | 2605 | ||
1864 | /* | 2606 | /* |
@@ -1873,32 +2615,30 @@ int cx231xx_get_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8* gpio_val) | |||
1873 | * 1 = Output direction | 2615 | * 1 = Output direction |
1874 | */ | 2616 | */ |
1875 | int cx231xx_set_gpio_direction(struct cx231xx *dev, | 2617 | int cx231xx_set_gpio_direction(struct cx231xx *dev, |
1876 | int pin_number, | 2618 | int pin_number, int pin_value) |
1877 | int pin_value) | ||
1878 | { | 2619 | { |
1879 | int status = 0; | 2620 | int status = 0; |
1880 | u32 value = 0; | 2621 | u32 value = 0; |
1881 | 2622 | ||
1882 | /* Check for valid pin_number - if 32 , bail out */ | 2623 | /* Check for valid pin_number - if 32 , bail out */ |
1883 | if (pin_number >= 32) { | 2624 | if (pin_number >= 32) { |
1884 | return -EINVAL; | 2625 | return -EINVAL; |
1885 | } | 2626 | } |
1886 | 2627 | ||
1887 | if (pin_value == 0) { /* input */ | 2628 | if (pin_value == 0) { /* input */ |
1888 | value = dev->gpio_dir &(~(1<<pin_number)) ; /* clear */ | 2629 | value = dev->gpio_dir & (~(1 << pin_number)); /* clear */ |
1889 | } else { | 2630 | } else { |
1890 | value = dev->gpio_dir | (1<<pin_number) ; | 2631 | value = dev->gpio_dir | (1 << pin_number); |
1891 | } | 2632 | } |
1892 | 2633 | ||
1893 | status = cx231xx_set_gpio_bit(dev, value, (u8*) & dev->gpio_val); | 2634 | status = cx231xx_set_gpio_bit(dev, value, (u8 *) & dev->gpio_val); |
1894 | 2635 | ||
1895 | /* cache the value for future */ | 2636 | /* cache the value for future */ |
1896 | dev->gpio_dir = value; | 2637 | dev->gpio_dir = value; |
1897 | 2638 | ||
1898 | return status; | 2639 | return status; |
1899 | } | 2640 | } |
1900 | 2641 | ||
1901 | |||
1902 | /* | 2642 | /* |
1903 | * SetGpioPinLogicValue | 2643 | * SetGpioPinLogicValue |
1904 | * Sets the value of the GPIO pin to Logic high or low. The Pin under | 2644 | * Sets the value of the GPIO pin to Logic high or low. The Pin under |
@@ -1910,43 +2650,42 @@ int cx231xx_set_gpio_direction(struct cx231xx *dev, | |||
1910 | * 0 = set it to 0 | 2650 | * 0 = set it to 0 |
1911 | * 1 = set it to 1 | 2651 | * 1 = set it to 1 |
1912 | */ | 2652 | */ |
1913 | int cx231xx_set_gpio_value(struct cx231xx *dev, | 2653 | int cx231xx_set_gpio_value(struct cx231xx *dev, int pin_number, int pin_value) |
1914 | int pin_number, | ||
1915 | int pin_value) | ||
1916 | { | 2654 | { |
1917 | int status = 0; | 2655 | int status = 0; |
1918 | u32 value = 0; | 2656 | u32 value = 0; |
1919 | 2657 | ||
1920 | /* Check for valid pin_number - if 0xFF , bail out */ | 2658 | /* Check for valid pin_number - if 0xFF , bail out */ |
1921 | if (pin_number >= 32) | 2659 | if (pin_number >= 32) |
1922 | return -EINVAL; | 2660 | return -EINVAL; |
1923 | 2661 | ||
1924 | /* first do a sanity check - if the Pin is not output, make it output */ | 2662 | /* first do a sanity check - if the Pin is not output, make it output */ |
1925 | if ((dev->gpio_dir & (1<<pin_number)) == 0x00) | 2663 | if ((dev->gpio_dir & (1 << pin_number)) == 0x00) { |
1926 | { | 2664 | /* It was in input mode */ |
1927 | /* It was in input mode */ | 2665 | value = dev->gpio_dir | (1 << pin_number); |
1928 | value = dev->gpio_dir | (1<<pin_number) ; | 2666 | dev->gpio_dir = value; |
1929 | dev->gpio_dir = value; | 2667 | status = |
1930 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2668 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, |
2669 | (u8 *) & dev->gpio_val); | ||
1931 | value = 0; | 2670 | value = 0; |
1932 | } | 2671 | } |
1933 | 2672 | ||
1934 | if (pin_value == 0) { | 2673 | if (pin_value == 0) { |
1935 | value = dev->gpio_val & (~(1<<pin_number)); | 2674 | value = dev->gpio_val & (~(1 << pin_number)); |
1936 | } else { | 2675 | } else { |
1937 | value = dev->gpio_val | (1<<pin_number); | 2676 | value = dev->gpio_val | (1 << pin_number); |
1938 | } | 2677 | } |
1939 | 2678 | ||
1940 | /* store the value */ | 2679 | /* store the value */ |
1941 | dev->gpio_val=value; | 2680 | dev->gpio_val = value; |
1942 | 2681 | ||
1943 | /* toggle bit0 of GP_IO */ | 2682 | /* toggle bit0 of GP_IO */ |
1944 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2683 | status = |
2684 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
1945 | 2685 | ||
1946 | return status; | 2686 | return status; |
1947 | } | 2687 | } |
1948 | 2688 | ||
1949 | |||
1950 | /************************************************************************************ | 2689 | /************************************************************************************ |
1951 | * G P I O I2C related functions * | 2690 | * G P I O I2C related functions * |
1952 | *************************************************************************************/ | 2691 | *************************************************************************************/ |
@@ -1955,140 +2694,162 @@ int cx231xx_gpio_i2c_start(struct cx231xx *dev) | |||
1955 | int status = 0; | 2694 | int status = 0; |
1956 | 2695 | ||
1957 | /* set SCL to output 1 ; set SDA to output 1 */ | 2696 | /* set SCL to output 1 ; set SDA to output 1 */ |
1958 | dev->gpio_dir |= 1<< dev->board.tuner_scl_gpio; | 2697 | dev->gpio_dir |= 1 << dev->board.tuner_scl_gpio; |
1959 | dev->gpio_dir |= 1<<dev->board.tuner_sda_gpio; | 2698 | dev->gpio_dir |= 1 << dev->board.tuner_sda_gpio; |
1960 | dev->gpio_val |= 1<<dev->board.tuner_scl_gpio; | 2699 | dev->gpio_val |= 1 << dev->board.tuner_scl_gpio; |
1961 | dev->gpio_val |= 1<<dev->board.tuner_sda_gpio; | 2700 | dev->gpio_val |= 1 << dev->board.tuner_sda_gpio; |
1962 | 2701 | ||
1963 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2702 | status = |
1964 | if(status < 0){ | 2703 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); |
2704 | if (status < 0) { | ||
1965 | return -EINVAL; | 2705 | return -EINVAL; |
1966 | } | 2706 | } |
1967 | 2707 | ||
1968 | /* set SCL to output 1; set SDA to output 0 */ | 2708 | /* set SCL to output 1; set SDA to output 0 */ |
1969 | dev->gpio_val |= 1<<dev->board.tuner_scl_gpio; | 2709 | dev->gpio_val |= 1 << dev->board.tuner_scl_gpio; |
1970 | dev->gpio_val &= ~(1<<dev->board.tuner_sda_gpio); | 2710 | dev->gpio_val &= ~(1 << dev->board.tuner_sda_gpio); |
1971 | 2711 | ||
1972 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2712 | status = |
1973 | if(status < 0){ | 2713 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); |
2714 | if (status < 0) { | ||
1974 | return -EINVAL; | 2715 | return -EINVAL; |
1975 | } | 2716 | } |
1976 | 2717 | ||
1977 | /* set SCL to output 0; set SDA to output 0 */ | 2718 | /* set SCL to output 0; set SDA to output 0 */ |
1978 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2719 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
1979 | dev->gpio_val &= ~(1<<dev->board.tuner_sda_gpio); | 2720 | dev->gpio_val &= ~(1 << dev->board.tuner_sda_gpio); |
1980 | 2721 | ||
1981 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2722 | status = |
1982 | if(status < 0){ | 2723 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); |
2724 | if (status < 0) { | ||
1983 | return -EINVAL; | 2725 | return -EINVAL; |
1984 | } | 2726 | } |
1985 | 2727 | ||
1986 | return status; | 2728 | return status; |
1987 | } | 2729 | } |
1988 | 2730 | ||
1989 | |||
1990 | int cx231xx_gpio_i2c_end(struct cx231xx *dev) | 2731 | int cx231xx_gpio_i2c_end(struct cx231xx *dev) |
1991 | { | 2732 | { |
1992 | int status = 0; | 2733 | int status = 0; |
1993 | 2734 | ||
1994 | /* set SCL to output 0; set SDA to output 0 */ | 2735 | /* set SCL to output 0; set SDA to output 0 */ |
1995 | dev->gpio_dir |= 1<<dev->board.tuner_scl_gpio; | 2736 | dev->gpio_dir |= 1 << dev->board.tuner_scl_gpio; |
1996 | dev->gpio_dir |= 1<<dev->board.tuner_sda_gpio; | 2737 | dev->gpio_dir |= 1 << dev->board.tuner_sda_gpio; |
1997 | 2738 | ||
1998 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2739 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
1999 | dev->gpio_val &= ~(1<<dev->board.tuner_sda_gpio); | 2740 | dev->gpio_val &= ~(1 << dev->board.tuner_sda_gpio); |
2000 | 2741 | ||
2001 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2742 | status = |
2002 | if(status < 0){ | 2743 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); |
2744 | if (status < 0) { | ||
2003 | return -EINVAL; | 2745 | return -EINVAL; |
2004 | } | 2746 | } |
2005 | 2747 | ||
2006 | /* set SCL to output 1; set SDA to output 0 */ | 2748 | /* set SCL to output 1; set SDA to output 0 */ |
2007 | dev->gpio_val |= 1<<dev->board.tuner_scl_gpio; | 2749 | dev->gpio_val |= 1 << dev->board.tuner_scl_gpio; |
2008 | dev->gpio_val &= ~(1<<dev->board.tuner_sda_gpio); | 2750 | dev->gpio_val &= ~(1 << dev->board.tuner_sda_gpio); |
2009 | 2751 | ||
2010 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2752 | status = |
2011 | if(status < 0){ | 2753 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); |
2754 | if (status < 0) { | ||
2012 | return -EINVAL; | 2755 | return -EINVAL; |
2013 | } | 2756 | } |
2014 | 2757 | ||
2015 | /* set SCL to input ,release SCL cable control | 2758 | /* set SCL to input ,release SCL cable control |
2016 | set SDA to input ,release SDA cable control */ | 2759 | set SDA to input ,release SDA cable control */ |
2017 | dev->gpio_dir &= ~(1<<dev->board.tuner_scl_gpio); | 2760 | dev->gpio_dir &= ~(1 << dev->board.tuner_scl_gpio); |
2018 | dev->gpio_dir &= ~(1<<dev->board.tuner_sda_gpio); | 2761 | dev->gpio_dir &= ~(1 << dev->board.tuner_sda_gpio); |
2019 | 2762 | ||
2020 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2763 | status = |
2021 | if(status < 0){ | 2764 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); |
2765 | if (status < 0) { | ||
2022 | return -EINVAL; | 2766 | return -EINVAL; |
2023 | } | 2767 | } |
2024 | return status; | 2768 | return status; |
2025 | } | 2769 | } |
2026 | 2770 | ||
2027 | |||
2028 | int cx231xx_gpio_i2c_write_byte(struct cx231xx *dev, u8 data) | 2771 | int cx231xx_gpio_i2c_write_byte(struct cx231xx *dev, u8 data) |
2029 | { | 2772 | { |
2030 | int status = 0; | 2773 | int status = 0; |
2031 | u8 i; | 2774 | u8 i; |
2032 | 2775 | ||
2033 | /* set SCL to output ; set SDA to output */ | 2776 | /* set SCL to output ; set SDA to output */ |
2034 | dev->gpio_dir |= 1<<dev->board.tuner_scl_gpio; | 2777 | dev->gpio_dir |= 1 << dev->board.tuner_scl_gpio; |
2035 | dev->gpio_dir |= 1<<dev->board.tuner_sda_gpio; | 2778 | dev->gpio_dir |= 1 << dev->board.tuner_sda_gpio; |
2036 | 2779 | ||
2037 | for(i = 0;i<8;i++) { | 2780 | for (i = 0; i < 8; i++) { |
2038 | if(((data<<i) & 0x80) == 0) { | 2781 | if (((data << i) & 0x80) == 0) { |
2039 | /* set SCL to output 0; set SDA to output 0 */ | 2782 | /* set SCL to output 0; set SDA to output 0 */ |
2040 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2783 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
2041 | dev->gpio_val &= ~(1<<dev->board.tuner_sda_gpio); | 2784 | dev->gpio_val &= ~(1 << dev->board.tuner_sda_gpio); |
2042 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2785 | status = |
2043 | 2786 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, | |
2044 | /* set SCL to output 1; set SDA to output 0 */ | 2787 | (u8 *) & dev->gpio_val); |
2045 | dev->gpio_val |= 1<<dev->board.tuner_scl_gpio; | 2788 | |
2046 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2789 | /* set SCL to output 1; set SDA to output 0 */ |
2047 | 2790 | dev->gpio_val |= 1 << dev->board.tuner_scl_gpio; | |
2048 | /* set SCL to output 0; set SDA to output 0 */ | 2791 | status = |
2049 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2792 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, |
2050 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2793 | (u8 *) & dev->gpio_val); |
2794 | |||
2795 | /* set SCL to output 0; set SDA to output 0 */ | ||
2796 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); | ||
2797 | status = | ||
2798 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, | ||
2799 | (u8 *) & dev->gpio_val); | ||
2051 | } else { | 2800 | } else { |
2052 | /* set SCL to output 0; set SDA to output 1 */ | 2801 | /* set SCL to output 0; set SDA to output 1 */ |
2053 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2802 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
2054 | dev->gpio_val |= 1<<dev->board.tuner_sda_gpio; | 2803 | dev->gpio_val |= 1 << dev->board.tuner_sda_gpio; |
2055 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2804 | status = |
2056 | 2805 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, | |
2057 | /* set SCL to output 1; set SDA to output 1 */ | 2806 | (u8 *) & dev->gpio_val); |
2058 | dev->gpio_val |= 1<<dev->board.tuner_scl_gpio; | 2807 | |
2059 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2808 | /* set SCL to output 1; set SDA to output 1 */ |
2060 | 2809 | dev->gpio_val |= 1 << dev->board.tuner_scl_gpio; | |
2061 | /* set SCL to output 0; set SDA to output 1 */ | 2810 | status = |
2062 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2811 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, |
2063 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2812 | (u8 *) & dev->gpio_val); |
2064 | } | 2813 | |
2814 | /* set SCL to output 0; set SDA to output 1 */ | ||
2815 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); | ||
2816 | status = | ||
2817 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, | ||
2818 | (u8 *) & dev->gpio_val); | ||
2819 | } | ||
2065 | } | 2820 | } |
2066 | return status; | 2821 | return status; |
2067 | } | 2822 | } |
2068 | 2823 | ||
2069 | int cx231xx_gpio_i2c_read_byte(struct cx231xx *dev, u8 *buf) | 2824 | int cx231xx_gpio_i2c_read_byte(struct cx231xx *dev, u8 * buf) |
2070 | { | 2825 | { |
2071 | u8 value = 0; | 2826 | u8 value = 0; |
2072 | int status = 0; | 2827 | int status = 0; |
2073 | u32 gpio_logic_value =0; | 2828 | u32 gpio_logic_value = 0; |
2074 | u8 i; | 2829 | u8 i; |
2075 | 2830 | ||
2076 | /* read byte */ | 2831 | /* read byte */ |
2077 | for(i=0;i<8;i++) { /* send write I2c addr */ | 2832 | for (i = 0; i < 8; i++) { /* send write I2c addr */ |
2078 | 2833 | ||
2079 | /* set SCL to output 0; set SDA to input */ | 2834 | /* set SCL to output 0; set SDA to input */ |
2080 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2835 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
2081 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2836 | status = |
2837 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, | ||
2838 | (u8 *) & dev->gpio_val); | ||
2082 | 2839 | ||
2083 | /* set SCL to output 1; set SDA to input */ | 2840 | /* set SCL to output 1; set SDA to input */ |
2084 | dev->gpio_val |= 1<<dev->board.tuner_scl_gpio; | 2841 | dev->gpio_val |= 1 << dev->board.tuner_scl_gpio; |
2085 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2842 | status = |
2843 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, | ||
2844 | (u8 *) & dev->gpio_val); | ||
2086 | 2845 | ||
2087 | /* get SDA data bit */ | 2846 | /* get SDA data bit */ |
2088 | gpio_logic_value = dev->gpio_val; | 2847 | gpio_logic_value = dev->gpio_val; |
2089 | status = cx231xx_get_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2848 | status = |
2090 | if((dev->gpio_val & (1<<dev->board.tuner_sda_gpio)) != 0) { | 2849 | cx231xx_get_gpio_bit(dev, dev->gpio_dir, |
2091 | value |= (1<<(8-i-1)); | 2850 | (u8 *) & dev->gpio_val); |
2851 | if ((dev->gpio_val & (1 << dev->board.tuner_sda_gpio)) != 0) { | ||
2852 | value |= (1 << (8 - i - 1)); | ||
2092 | } | 2853 | } |
2093 | 2854 | ||
2094 | dev->gpio_val = gpio_logic_value; | 2855 | dev->gpio_val = gpio_logic_value; |
@@ -2096,146 +2857,160 @@ int cx231xx_gpio_i2c_read_byte(struct cx231xx *dev, u8 *buf) | |||
2096 | 2857 | ||
2097 | /* set SCL to output 0,finish the read latest SCL signal. | 2858 | /* set SCL to output 0,finish the read latest SCL signal. |
2098 | !!!set SDA to input,never to modify SDA direction at the same times */ | 2859 | !!!set SDA to input,never to modify SDA direction at the same times */ |
2099 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2860 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
2100 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2861 | status = |
2862 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2101 | 2863 | ||
2102 | /* store the value */ | 2864 | /* store the value */ |
2103 | *buf = value & 0xff; | 2865 | *buf = value & 0xff; |
2104 | 2866 | ||
2105 | return status; | 2867 | return status; |
2106 | } | 2868 | } |
2107 | 2869 | ||
2108 | int cx231xx_gpio_i2c_read_ack(struct cx231xx *dev) | 2870 | int cx231xx_gpio_i2c_read_ack(struct cx231xx *dev) |
2109 | { | 2871 | { |
2110 | int status = 0; | 2872 | int status = 0; |
2111 | u32 gpio_logic_value = 0; | 2873 | u32 gpio_logic_value = 0; |
2112 | int nCnt=10; | 2874 | int nCnt = 10; |
2113 | int nInit=nCnt; | 2875 | int nInit = nCnt; |
2114 | 2876 | ||
2115 | /* clock stretch; set SCL to input; set SDA to input; get SCL value till SCL = 1 */ | 2877 | /* clock stretch; set SCL to input; set SDA to input; get SCL value till SCL = 1 */ |
2116 | dev->gpio_dir &= ~(1<<dev->board.tuner_sda_gpio); | 2878 | dev->gpio_dir &= ~(1 << dev->board.tuner_sda_gpio); |
2117 | dev->gpio_dir &= ~(1<<dev->board.tuner_scl_gpio); | 2879 | dev->gpio_dir &= ~(1 << dev->board.tuner_scl_gpio); |
2118 | 2880 | ||
2119 | gpio_logic_value = dev->gpio_val; | 2881 | gpio_logic_value = dev->gpio_val; |
2120 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2882 | status = |
2883 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2121 | 2884 | ||
2122 | do{ | 2885 | do { |
2123 | msleep(2); | 2886 | msleep(2); |
2124 | status = cx231xx_get_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2887 | status = |
2125 | nCnt--; | 2888 | cx231xx_get_gpio_bit(dev, dev->gpio_dir, |
2126 | }while(((dev->gpio_val & (1<<dev->board.tuner_scl_gpio)) == 0) && (nCnt>0)); | 2889 | (u8 *) & dev->gpio_val); |
2127 | 2890 | nCnt--; | |
2128 | if(nCnt==0) { | 2891 | } while (((dev->gpio_val & (1 << dev->board.tuner_scl_gpio)) == 0) |
2129 | cx231xx_info("No ACK after %d msec for clock stretch. GPIO I2C operation failed!",nInit*10); | 2892 | && (nCnt > 0)); |
2130 | } | 2893 | |
2894 | if (nCnt == 0) { | ||
2895 | cx231xx_info | ||
2896 | ("No ACK after %d msec for clock stretch. GPIO I2C operation failed!", | ||
2897 | nInit * 10); | ||
2898 | } | ||
2131 | 2899 | ||
2132 | /* readAck | 2900 | /* readAck |
2133 | throuth clock stretch ,slave has given a SCL signal,so the SDA data can be directly read. */ | 2901 | throuth clock stretch ,slave has given a SCL signal,so the SDA data can be directly read. */ |
2134 | status = cx231xx_get_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2902 | status = |
2903 | cx231xx_get_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2135 | 2904 | ||
2136 | if((dev->gpio_val & 1<< dev->board.tuner_sda_gpio) == 0){ | 2905 | if ((dev->gpio_val & 1 << dev->board.tuner_sda_gpio) == 0) { |
2137 | dev->gpio_val = gpio_logic_value; | 2906 | dev->gpio_val = gpio_logic_value; |
2138 | dev->gpio_val &= ~(1<< dev->board.tuner_sda_gpio); | 2907 | dev->gpio_val &= ~(1 << dev->board.tuner_sda_gpio); |
2139 | status = 0; | 2908 | status = 0; |
2140 | } else { | 2909 | } else { |
2141 | dev->gpio_val = gpio_logic_value; | 2910 | dev->gpio_val = gpio_logic_value; |
2142 | dev->gpio_val |= (1<< dev->board.tuner_sda_gpio); | 2911 | dev->gpio_val |= (1 << dev->board.tuner_sda_gpio); |
2143 | } | 2912 | } |
2144 | 2913 | ||
2145 | /* read SDA end, set the SCL to output 0, after this operation, SDA direction can be changed. */ | 2914 | /* read SDA end, set the SCL to output 0, after this operation, SDA direction can be changed. */ |
2146 | dev->gpio_val = gpio_logic_value; | 2915 | dev->gpio_val = gpio_logic_value; |
2147 | dev->gpio_dir |= (1<<dev->board.tuner_scl_gpio); | 2916 | dev->gpio_dir |= (1 << dev->board.tuner_scl_gpio); |
2148 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2917 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
2149 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2918 | status = |
2919 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2150 | 2920 | ||
2151 | return status; | 2921 | return status; |
2152 | } | 2922 | } |
2153 | 2923 | ||
2154 | |||
2155 | int cx231xx_gpio_i2c_write_ack(struct cx231xx *dev) | 2924 | int cx231xx_gpio_i2c_write_ack(struct cx231xx *dev) |
2156 | { | 2925 | { |
2157 | int status = 0; | 2926 | int status = 0; |
2158 | 2927 | ||
2159 | /* set SDA to ouput */ | 2928 | /* set SDA to ouput */ |
2160 | dev->gpio_dir |= 1<<dev->board.tuner_sda_gpio; | 2929 | dev->gpio_dir |= 1 << dev->board.tuner_sda_gpio; |
2161 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2930 | status = |
2931 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2162 | 2932 | ||
2163 | /* set SCL = 0 (output); set SDA = 0 (output) */ | 2933 | /* set SCL = 0 (output); set SDA = 0 (output) */ |
2164 | dev->gpio_val &= ~(1<<dev->board.tuner_sda_gpio); | 2934 | dev->gpio_val &= ~(1 << dev->board.tuner_sda_gpio); |
2165 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2935 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
2166 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2936 | status = |
2937 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2167 | 2938 | ||
2168 | /* set SCL = 1 (output); set SDA = 0 (output) */ | 2939 | /* set SCL = 1 (output); set SDA = 0 (output) */ |
2169 | dev->gpio_val |= 1<<dev->board.tuner_scl_gpio; | 2940 | dev->gpio_val |= 1 << dev->board.tuner_scl_gpio; |
2170 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2941 | status = |
2942 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2171 | 2943 | ||
2172 | /* set SCL = 0 (output); set SDA = 0 (output) */ | 2944 | /* set SCL = 0 (output); set SDA = 0 (output) */ |
2173 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2945 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
2174 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2946 | status = |
2947 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2175 | 2948 | ||
2176 | /* set SDA to input,and then the slave will read data from SDA. */ | 2949 | /* set SDA to input,and then the slave will read data from SDA. */ |
2177 | dev->gpio_dir &= ~(1<<dev->board.tuner_sda_gpio); | 2950 | dev->gpio_dir &= ~(1 << dev->board.tuner_sda_gpio); |
2178 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2951 | status = |
2952 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2179 | 2953 | ||
2180 | return status; | 2954 | return status; |
2181 | } | 2955 | } |
2182 | 2956 | ||
2183 | int cx231xx_gpio_i2c_write_nak(struct cx231xx *dev) | 2957 | int cx231xx_gpio_i2c_write_nak(struct cx231xx *dev) |
2184 | { | 2958 | { |
2185 | int status = 0; | 2959 | int status = 0; |
2186 | 2960 | ||
2187 | /* set scl to output ; set sda to input */ | 2961 | /* set scl to output ; set sda to input */ |
2188 | dev->gpio_dir |= 1<<dev->board.tuner_scl_gpio; | 2962 | dev->gpio_dir |= 1 << dev->board.tuner_scl_gpio; |
2189 | dev->gpio_dir &= ~(1<<dev->board.tuner_sda_gpio); | 2963 | dev->gpio_dir &= ~(1 << dev->board.tuner_sda_gpio); |
2190 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2964 | status = |
2965 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2191 | 2966 | ||
2192 | /* set scl to output 0; set sda to input */ | 2967 | /* set scl to output 0; set sda to input */ |
2193 | dev->gpio_val &= ~(1<<dev->board.tuner_scl_gpio); | 2968 | dev->gpio_val &= ~(1 << dev->board.tuner_scl_gpio); |
2194 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2969 | status = |
2970 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2195 | 2971 | ||
2196 | /* set scl to output 1; set sda to input */ | 2972 | /* set scl to output 1; set sda to input */ |
2197 | dev->gpio_val |= 1<<dev->board.tuner_scl_gpio; | 2973 | dev->gpio_val |= 1 << dev->board.tuner_scl_gpio; |
2198 | status = cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8*) &dev->gpio_val); | 2974 | status = |
2975 | cx231xx_set_gpio_bit(dev, dev->gpio_dir, (u8 *) & dev->gpio_val); | ||
2199 | 2976 | ||
2200 | return status; | 2977 | return status; |
2201 | } | 2978 | } |
2202 | 2979 | ||
2203 | |||
2204 | |||
2205 | /************************************************************************************ | 2980 | /************************************************************************************ |
2206 | * G P I O I2C related functions * | 2981 | * G P I O I2C related functions * |
2207 | *************************************************************************************/ | 2982 | *************************************************************************************/ |
2208 | /* cx231xx_gpio_i2c_read | 2983 | /* cx231xx_gpio_i2c_read |
2209 | * Function to read data from gpio based I2C interface | 2984 | * Function to read data from gpio based I2C interface |
2210 | */ | 2985 | */ |
2211 | int cx231xx_gpio_i2c_read(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len) | 2986 | int cx231xx_gpio_i2c_read(struct cx231xx *dev, u8 dev_addr, u8 * buf, u8 len) |
2212 | { | 2987 | { |
2213 | int status = 0; | 2988 | int status = 0; |
2214 | int i = 0; | 2989 | int i = 0; |
2215 | 2990 | ||
2216 | /* get the lock */ | 2991 | /* get the lock */ |
2217 | mutex_lock(&dev->gpio_i2c_lock); | 2992 | mutex_lock(&dev->gpio_i2c_lock); |
2218 | 2993 | ||
2219 | /* start */ | 2994 | /* start */ |
2220 | status = cx231xx_gpio_i2c_start(dev); | 2995 | status = cx231xx_gpio_i2c_start(dev); |
2221 | 2996 | ||
2222 | /* write dev_addr */ | 2997 | /* write dev_addr */ |
2223 | status = cx231xx_gpio_i2c_write_byte(dev, (dev_addr << 1) +1); | 2998 | status = cx231xx_gpio_i2c_write_byte(dev, (dev_addr << 1) + 1); |
2224 | 2999 | ||
2225 | /* readAck */ | 3000 | /* readAck */ |
2226 | status = cx231xx_gpio_i2c_read_ack(dev); | 3001 | status = cx231xx_gpio_i2c_read_ack(dev); |
2227 | 3002 | ||
2228 | /* read data */ | 3003 | /* read data */ |
2229 | for(i = 0; i < len; i++ ) { | 3004 | for (i = 0; i < len; i++) { |
2230 | /* read data */ | 3005 | /* read data */ |
2231 | buf[i] = 0; | 3006 | buf[i] = 0; |
2232 | status = cx231xx_gpio_i2c_read_byte(dev, & buf[i]); | 3007 | status = cx231xx_gpio_i2c_read_byte(dev, &buf[i]); |
2233 | 3008 | ||
2234 | if( (i+1) != len) { | 3009 | if ((i + 1) != len) { |
2235 | /* only do write ack if we more length */ | 3010 | /* only do write ack if we more length */ |
2236 | status = cx231xx_gpio_i2c_write_ack(dev); | 3011 | status = cx231xx_gpio_i2c_write_ack(dev); |
2237 | } | 3012 | } |
2238 | } | 3013 | } |
2239 | 3014 | ||
2240 | /* write NAK - inform reads are complete */ | 3015 | /* write NAK - inform reads are complete */ |
2241 | status = cx231xx_gpio_i2c_write_nak(dev); | 3016 | status = cx231xx_gpio_i2c_write_nak(dev); |
@@ -2249,14 +3024,13 @@ int cx231xx_gpio_i2c_read(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len) | |||
2249 | return status; | 3024 | return status; |
2250 | } | 3025 | } |
2251 | 3026 | ||
2252 | |||
2253 | /* cx231xx_gpio_i2c_write | 3027 | /* cx231xx_gpio_i2c_write |
2254 | * Function to write data to gpio based I2C interface | 3028 | * Function to write data to gpio based I2C interface |
2255 | */ | 3029 | */ |
2256 | int cx231xx_gpio_i2c_write(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len) | 3030 | int cx231xx_gpio_i2c_write(struct cx231xx *dev, u8 dev_addr, u8 * buf, u8 len) |
2257 | { | 3031 | { |
2258 | int status = 0; | 3032 | int status = 0; |
2259 | int i=0; | 3033 | int i = 0; |
2260 | 3034 | ||
2261 | /* get the lock */ | 3035 | /* get the lock */ |
2262 | mutex_lock(&dev->gpio_i2c_lock); | 3036 | mutex_lock(&dev->gpio_i2c_lock); |
@@ -2268,17 +3042,17 @@ int cx231xx_gpio_i2c_write(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len) | |||
2268 | status = cx231xx_gpio_i2c_write_byte(dev, dev_addr << 1); | 3042 | status = cx231xx_gpio_i2c_write_byte(dev, dev_addr << 1); |
2269 | 3043 | ||
2270 | /* read Ack */ | 3044 | /* read Ack */ |
2271 | status = cx231xx_gpio_i2c_read_ack(dev); | 3045 | status = cx231xx_gpio_i2c_read_ack(dev); |
2272 | 3046 | ||
2273 | for(i = 0; i < len; i++ ) { | 3047 | for (i = 0; i < len; i++) { |
2274 | /* Write data */ | 3048 | /* Write data */ |
2275 | status = cx231xx_gpio_i2c_write_byte(dev, buf[i]); | 3049 | status = cx231xx_gpio_i2c_write_byte(dev, buf[i]); |
2276 | 3050 | ||
2277 | /* read Ack */ | 3051 | /* read Ack */ |
2278 | status = cx231xx_gpio_i2c_read_ack(dev); | 3052 | status = cx231xx_gpio_i2c_read_ack(dev); |
2279 | } | 3053 | } |
2280 | 3054 | ||
2281 | /* write End */ | 3055 | /* write End */ |
2282 | status = cx231xx_gpio_i2c_end(dev); | 3056 | status = cx231xx_gpio_i2c_end(dev); |
2283 | 3057 | ||
2284 | /* release the lock */ | 3058 | /* release the lock */ |
@@ -2286,4 +3060,3 @@ int cx231xx_gpio_i2c_write(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len) | |||
2286 | 3060 | ||
2287 | return 0; | 3061 | return 0; |
2288 | } | 3062 | } |
2289 | |||
diff --git a/drivers/media/video/cx231xx/cx231xx-cards.c b/drivers/media/video/cx231xx/cx231xx-cards.c index c567e5a9eec8..a1f6ed645add 100644 --- a/drivers/media/video/cx231xx/cx231xx-cards.c +++ b/drivers/media/video/cx231xx/cx231xx-cards.c | |||
@@ -2,7 +2,7 @@ | |||
2 | cx231xx-cards.c - driver for Conexant Cx23100/101/102 USB video capture devices | 2 | cx231xx-cards.c - driver for Conexant Cx23100/101/102 USB video capture devices |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on em28xx driver | 5 | Based on em28xx driver |
6 | 6 | ||
7 | This program is free software; you can redistribute it and/or modify | 7 | This program is free software; you can redistribute it and/or modify |
8 | it under the terms of the GNU General Public License as published by | 8 | it under the terms of the GNU General Public License as published by |
@@ -50,131 +50,151 @@ static unsigned long cx231xx_devused; | |||
50 | */ | 50 | */ |
51 | 51 | ||
52 | static struct cx231xx_reg_seq RDE250_XCV_TUNER[] = { | 52 | static struct cx231xx_reg_seq RDE250_XCV_TUNER[] = { |
53 | { 0x03, 0x01, 10 }, | 53 | {0x03, 0x01, 10}, |
54 | { 0x03, 0x00, 30 }, | 54 | {0x03, 0x00, 30}, |
55 | { 0x03, 0x01, 10 }, | 55 | {0x03, 0x01, 10}, |
56 | { -1, -1, -1 }, | 56 | {-1, -1, -1}, |
57 | }; | 57 | }; |
58 | 58 | ||
59 | |||
60 | |||
61 | /* | 59 | /* |
62 | * Board definitions | 60 | * Board definitions |
63 | */ | 61 | */ |
64 | struct cx231xx_board cx231xx_boards[] = { | 62 | struct cx231xx_board cx231xx_boards[] = { |
65 | 63 | ||
66 | [CX231XX_BOARD_UNKNOWN] = { | 64 | [CX231XX_BOARD_UNKNOWN] = { |
67 | .name = "Unknown CX231xx video grabber", | 65 | .name = "Unknown CX231xx video grabber", |
68 | .tuner_type = TUNER_ABSENT, | 66 | .tuner_type = TUNER_ABSENT, |
69 | .input = { { | 67 | .input = {{ |
70 | .type = CX231XX_VMUX_TELEVISION, | 68 | .type = CX231XX_VMUX_TELEVISION, |
71 | .vmux = CX231XX_VIN_3_1, | 69 | .vmux = CX231XX_VIN_3_1, |
72 | .amux = CX231XX_AMUX_VIDEO, | 70 | .amux = CX231XX_AMUX_VIDEO, |
73 | .gpio = 0, | 71 | .gpio = 0, |
74 | }, { | 72 | }, { |
75 | .type = CX231XX_VMUX_COMPOSITE1, | 73 | .type = |
76 | .vmux = CX231XX_VIN_2_1, | 74 | CX231XX_VMUX_COMPOSITE1, |
77 | .amux = CX231XX_AMUX_LINE_IN, | 75 | .vmux = CX231XX_VIN_2_1, |
78 | .gpio = 0, | 76 | .amux = CX231XX_AMUX_LINE_IN, |
79 | }, { | 77 | .gpio = 0, |
80 | .type = CX231XX_VMUX_SVIDEO, | 78 | }, { |
81 | .vmux = CX231XX_VIN_1_1 | (CX231XX_VIN_1_2 << 8 ) | | 79 | .type = |
82 | CX25840_SVIDEO_ON, | 80 | CX231XX_VMUX_SVIDEO, |
83 | .amux = CX231XX_AMUX_LINE_IN, | 81 | .vmux = |
84 | .gpio = 0, | 82 | CX231XX_VIN_1_1 | |
85 | } }, | 83 | (CX231XX_VIN_1_2 << 8) | |
86 | }, | 84 | CX25840_SVIDEO_ON, |
85 | .amux = | ||
86 | CX231XX_AMUX_LINE_IN, | ||
87 | .gpio = 0, | ||
88 | }}, | ||
89 | }, | ||
87 | 90 | ||
88 | [CX231XX_BOARD_CNXT_RDE_250] = { | 91 | [CX231XX_BOARD_CNXT_RDE_250] = { |
89 | .name = "Conexant Hybrid TV - RDE250", | 92 | .name = "Conexant Hybrid TV - RDE250", |
90 | .valid = CX231XX_BOARD_VALIDATED, | 93 | .valid = CX231XX_BOARD_VALIDATED, |
91 | .tuner_type = TUNER_XC5000, | 94 | .tuner_type = TUNER_XC5000, |
92 | .tuner_addr = 0x61, | 95 | .tuner_addr = 0x61, |
93 | .tuner_gpio = RDE250_XCV_TUNER, | 96 | .tuner_gpio = RDE250_XCV_TUNER, |
94 | .tuner_sif_gpio = 0x05, | 97 | .tuner_sif_gpio = 0x05, |
95 | .tuner_scl_gpio = 0x1a, | 98 | .tuner_scl_gpio = 0x1a, |
96 | .tuner_sda_gpio = 0x1b, | 99 | .tuner_sda_gpio = 0x1b, |
97 | .decoder = CX231XX_AVDECODER, | 100 | .decoder = CX231XX_AVDECODER, |
98 | .demod_xfer_mode = 0, | 101 | .demod_xfer_mode = 0, |
99 | .ctl_pin_status_mask = 0xFFFFFFC4, | 102 | .ctl_pin_status_mask = 0xFFFFFFC4, |
100 | .agc_analog_digital_select_gpio = 0x0c, | 103 | .agc_analog_digital_select_gpio = 0x0c, |
101 | .gpio_pin_status_mask = 0x4001000, | 104 | .gpio_pin_status_mask = 0x4001000, |
102 | .tuner_i2c_master = 1, | 105 | .tuner_i2c_master = 1, |
103 | .demod_i2c_master = 2, | 106 | .demod_i2c_master = 2, |
104 | .has_dvb = 1, | 107 | .has_dvb = 1, |
105 | .demod_addr = 0x02, | 108 | .demod_addr = 0x02, |
106 | .norm = V4L2_STD_PAL, | 109 | .norm = V4L2_STD_PAL, |
107 | 110 | ||
108 | .input = { { | 111 | .input = {{ |
109 | .type = CX231XX_VMUX_TELEVISION, | 112 | .type = |
110 | .vmux = CX231XX_VIN_3_1, | 113 | CX231XX_VMUX_TELEVISION, |
111 | .amux = CX231XX_AMUX_VIDEO, | 114 | .vmux = CX231XX_VIN_3_1, |
112 | .gpio = 0, | 115 | .amux = CX231XX_AMUX_VIDEO, |
113 | }, { | 116 | .gpio = 0, |
114 | .type = CX231XX_VMUX_COMPOSITE1, | 117 | }, { |
115 | .vmux = CX231XX_VIN_2_1, | 118 | .type = |
116 | .amux = CX231XX_AMUX_LINE_IN, | 119 | CX231XX_VMUX_COMPOSITE1, |
117 | .gpio = 0, | 120 | .vmux = CX231XX_VIN_2_1, |
118 | }, { | 121 | .amux = |
119 | .type = CX231XX_VMUX_SVIDEO, | 122 | CX231XX_AMUX_LINE_IN, |
120 | .vmux = CX231XX_VIN_1_1 | (CX231XX_VIN_1_2 << 8 ) | | 123 | .gpio = 0, |
121 | CX25840_SVIDEO_ON, | 124 | }, { |
122 | .amux = CX231XX_AMUX_LINE_IN, | 125 | .type = |
123 | .gpio = 0, | 126 | CX231XX_VMUX_SVIDEO, |
124 | } }, | 127 | .vmux = |
125 | }, | 128 | CX231XX_VIN_1_1 | |
126 | 129 | (CX231XX_VIN_1_2 << | |
127 | [CX231XX_BOARD_CNXT_RDU_250] = { | 130 | 8) | |
128 | .name = "Conexant Hybrid TV - RDU250", | 131 | CX25840_SVIDEO_ON, |
129 | .valid = CX231XX_BOARD_VALIDATED, | 132 | .amux = |
130 | .tuner_type = TUNER_XC5000, | 133 | CX231XX_AMUX_LINE_IN, |
131 | .tuner_addr = 0x61, | 134 | .gpio = 0, |
132 | .tuner_gpio = RDE250_XCV_TUNER, | 135 | }}, |
133 | .tuner_sif_gpio = 0x05, | 136 | }, |
134 | .tuner_scl_gpio = 0x1a, | 137 | |
135 | .tuner_sda_gpio = 0x1b, | 138 | [CX231XX_BOARD_CNXT_RDU_250] = { |
136 | .decoder = CX231XX_AVDECODER, | 139 | .name = "Conexant Hybrid TV - RDU250", |
137 | .demod_xfer_mode = 0, | 140 | .valid = CX231XX_BOARD_VALIDATED, |
138 | .ctl_pin_status_mask = 0xFFFFFFC4, | 141 | .tuner_type = TUNER_XC5000, |
139 | .agc_analog_digital_select_gpio = 0x0c, | 142 | .tuner_addr = 0x61, |
140 | .gpio_pin_status_mask = 0x4001000, | 143 | .tuner_gpio = RDE250_XCV_TUNER, |
141 | .tuner_i2c_master = 1, | 144 | .tuner_sif_gpio = 0x05, |
142 | .demod_i2c_master = 2, | 145 | .tuner_scl_gpio = 0x1a, |
143 | .has_dvb = 1, | 146 | .tuner_sda_gpio = 0x1b, |
144 | .demod_addr = 0x32, | 147 | .decoder = CX231XX_AVDECODER, |
145 | .norm = V4L2_STD_NTSC, | 148 | .demod_xfer_mode = 0, |
146 | 149 | .ctl_pin_status_mask = 0xFFFFFFC4, | |
147 | .input = { { | 150 | .agc_analog_digital_select_gpio = 0x0c, |
148 | .type = CX231XX_VMUX_TELEVISION, | 151 | .gpio_pin_status_mask = 0x4001000, |
149 | .vmux = CX231XX_VIN_3_1, | 152 | .tuner_i2c_master = 1, |
150 | .amux = CX231XX_AMUX_VIDEO, | 153 | .demod_i2c_master = 2, |
151 | .gpio = 0, | 154 | .has_dvb = 1, |
152 | }, { | 155 | .demod_addr = 0x32, |
153 | .type = CX231XX_VMUX_COMPOSITE1, | 156 | .norm = V4L2_STD_NTSC, |
154 | .vmux = CX231XX_VIN_2_1, | 157 | |
155 | .amux = CX231XX_AMUX_LINE_IN, | 158 | .input = {{ |
156 | .gpio = 0, | 159 | .type = |
157 | }, { | 160 | CX231XX_VMUX_TELEVISION, |
158 | .type = CX231XX_VMUX_SVIDEO, | 161 | .vmux = CX231XX_VIN_3_1, |
159 | .vmux = CX231XX_VIN_1_1 | (CX231XX_VIN_1_2 << 8 ) | | 162 | .amux = CX231XX_AMUX_VIDEO, |
160 | CX25840_SVIDEO_ON, | 163 | .gpio = 0, |
161 | .amux = CX231XX_AMUX_LINE_IN, | 164 | }, { |
162 | .gpio = 0, | 165 | .type = |
163 | } }, | 166 | CX231XX_VMUX_COMPOSITE1, |
164 | }, | 167 | .vmux = CX231XX_VIN_2_1, |
168 | .amux = | ||
169 | CX231XX_AMUX_LINE_IN, | ||
170 | .gpio = 0, | ||
171 | }, { | ||
172 | .type = | ||
173 | CX231XX_VMUX_SVIDEO, | ||
174 | .vmux = | ||
175 | CX231XX_VIN_1_1 | | ||
176 | (CX231XX_VIN_1_2 << | ||
177 | 8) | | ||
178 | CX25840_SVIDEO_ON, | ||
179 | .amux = | ||
180 | CX231XX_AMUX_LINE_IN, | ||
181 | .gpio = 0, | ||
182 | }}, | ||
183 | }, | ||
165 | }; | 184 | }; |
166 | const unsigned int cx231xx_bcount = ARRAY_SIZE(cx231xx_boards); | 185 | const unsigned int cx231xx_bcount = ARRAY_SIZE(cx231xx_boards); |
167 | 186 | ||
168 | /* table of devices that work with this driver */ | 187 | /* table of devices that work with this driver */ |
169 | struct usb_device_id cx231xx_id_table [] = { | 188 | struct usb_device_id cx231xx_id_table[] = { |
170 | { USB_DEVICE(0x0572, 0x58A0), | 189 | {USB_DEVICE(0x0572, 0x58A0), |
171 | .driver_info = CX231XX_BOARD_UNKNOWN }, | 190 | .driver_info = CX231XX_BOARD_UNKNOWN}, |
172 | { USB_DEVICE(0x0572, 0x58A2), | 191 | {USB_DEVICE(0x0572, 0x58A2), |
173 | .driver_info = CX231XX_BOARD_CNXT_RDE_250 }, | 192 | .driver_info = CX231XX_BOARD_CNXT_RDE_250}, |
174 | { USB_DEVICE(0x0572, 0x5A3C), | 193 | {USB_DEVICE(0x0572, 0x5A3C), |
175 | .driver_info = CX231XX_BOARD_CNXT_RDU_250 }, | 194 | .driver_info = CX231XX_BOARD_CNXT_RDU_250}, |
176 | { }, | 195 | {}, |
177 | }; | 196 | }; |
197 | |||
178 | MODULE_DEVICE_TABLE(usb, cx231xx_id_table); | 198 | MODULE_DEVICE_TABLE(usb, cx231xx_id_table); |
179 | 199 | ||
180 | /* cx231xx_tuner_callback | 200 | /* cx231xx_tuner_callback |
@@ -186,21 +206,26 @@ int cx231xx_tuner_callback(void *ptr, int component, int command, int arg) | |||
186 | int rc = 0; | 206 | int rc = 0; |
187 | struct cx231xx *dev = ptr; | 207 | struct cx231xx *dev = ptr; |
188 | 208 | ||
189 | if (dev->tuner_type == TUNER_XC5000) { | 209 | if (dev->tuner_type == TUNER_XC5000) { |
190 | if (command == XC5000_TUNER_RESET) { | 210 | if (command == XC5000_TUNER_RESET) { |
191 | cx231xx_info("Tuner Call back : RESET : command %d : tuner type %d \n", | 211 | cx231xx_info |
192 | command, dev->tuner_type); | 212 | ("Tuner Call back : RESET : command %d : tuner type %d \n", |
193 | 213 | command, dev->tuner_type); | |
194 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit,1); | 214 | |
195 | msleep(10); | 215 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit, |
196 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit,0); | 216 | 1); |
197 | msleep(330); | 217 | msleep(10); |
198 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit,1); | 218 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit, |
199 | msleep(10); | 219 | 0); |
200 | } | 220 | msleep(330); |
201 | } | 221 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit, |
222 | 1); | ||
223 | msleep(10); | ||
224 | } | ||
225 | } | ||
202 | return rc; | 226 | return rc; |
203 | } | 227 | } |
228 | |||
204 | EXPORT_SYMBOL_GPL(cx231xx_tuner_callback); | 229 | EXPORT_SYMBOL_GPL(cx231xx_tuner_callback); |
205 | 230 | ||
206 | static void inline cx231xx_set_model(struct cx231xx *dev) | 231 | static void inline cx231xx_set_model(struct cx231xx *dev) |
@@ -217,34 +242,34 @@ void cx231xx_pre_card_setup(struct cx231xx *dev) | |||
217 | cx231xx_set_model(dev); | 242 | cx231xx_set_model(dev); |
218 | 243 | ||
219 | cx231xx_info("Identified as %s (card=%d)\n", | 244 | cx231xx_info("Identified as %s (card=%d)\n", |
220 | dev->board.name, dev->model); | 245 | dev->board.name, dev->model); |
221 | 246 | ||
222 | /* Do card specific if any */ | 247 | /* Do card specific if any */ |
223 | switch (dev->model) { | 248 | switch (dev->model) { |
224 | case CX231XX_BOARD_CNXT_RDE_250: | 249 | case CX231XX_BOARD_CNXT_RDE_250: |
225 | /* do card specific GPIO settings if required */ | 250 | /* do card specific GPIO settings if required */ |
226 | cx231xx_info("Precard: Board is Conexnat RDE 250\n"); | 251 | cx231xx_info("Precard: Board is Conexnat RDE 250\n"); |
227 | /* set the direction for GPIO pins */ | 252 | /* set the direction for GPIO pins */ |
228 | cx231xx_set_gpio_direction(dev, dev->board.tuner_gpio->bit,1); | 253 | cx231xx_set_gpio_direction(dev, dev->board.tuner_gpio->bit, 1); |
229 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit,1); | 254 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit, 1); |
230 | cx231xx_set_gpio_direction(dev, dev->board.tuner_sif_gpio,1); | 255 | cx231xx_set_gpio_direction(dev, dev->board.tuner_sif_gpio, 1); |
231 | break; | 256 | break; |
232 | case CX231XX_BOARD_CNXT_RDU_250: | 257 | case CX231XX_BOARD_CNXT_RDU_250: |
233 | /* do card specific GPIO settings if required */ | 258 | /* do card specific GPIO settings if required */ |
234 | cx231xx_info("Precard: Board is Conexnat RDU 250\n"); | 259 | cx231xx_info("Precard: Board is Conexnat RDU 250\n"); |
235 | /* set the direction for GPIO pins */ | 260 | /* set the direction for GPIO pins */ |
236 | cx231xx_set_gpio_direction(dev, dev->board.tuner_gpio->bit,1); | 261 | cx231xx_set_gpio_direction(dev, dev->board.tuner_gpio->bit, 1); |
237 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit,1); | 262 | cx231xx_set_gpio_value(dev, dev->board.tuner_gpio->bit, 1); |
238 | cx231xx_set_gpio_direction(dev, dev->board.tuner_sif_gpio,1); | 263 | cx231xx_set_gpio_direction(dev, dev->board.tuner_sif_gpio, 1); |
239 | break; | 264 | break; |
240 | } | 265 | } |
241 | 266 | ||
242 | /* request some modules if any required */ | 267 | /* request some modules if any required */ |
243 | 268 | ||
244 | /* reset the Tuner */ | 269 | /* reset the Tuner */ |
245 | cx231xx_gpio_set(dev, dev->board.tuner_gpio); | 270 | cx231xx_gpio_set(dev, dev->board.tuner_gpio); |
246 | 271 | ||
247 | /* set the mode to Analog mode initially */ | 272 | /* set the mode to Analog mode initially */ |
248 | cx231xx_set_mode(dev, CX231XX_ANALOG_MODE); | 273 | cx231xx_set_mode(dev, CX231XX_ANALOG_MODE); |
249 | 274 | ||
250 | /* Unlock device */ | 275 | /* Unlock device */ |
@@ -256,8 +281,8 @@ void cx231xx_pre_card_setup(struct cx231xx *dev) | |||
256 | 281 | ||
257 | static void cx231xx_config_tuner(struct cx231xx *dev) | 282 | static void cx231xx_config_tuner(struct cx231xx *dev) |
258 | { | 283 | { |
259 | struct tuner_setup tun_setup; | 284 | struct tuner_setup tun_setup; |
260 | struct v4l2_frequency f; | 285 | struct v4l2_frequency f; |
261 | 286 | ||
262 | if (dev->tuner_type == TUNER_ABSENT) | 287 | if (dev->tuner_type == TUNER_ABSENT) |
263 | return; | 288 | return; |
@@ -267,26 +292,28 @@ static void cx231xx_config_tuner(struct cx231xx *dev) | |||
267 | tun_setup.addr = dev->tuner_addr; | 292 | tun_setup.addr = dev->tuner_addr; |
268 | tun_setup.tuner_callback = cx231xx_tuner_callback; | 293 | tun_setup.tuner_callback = cx231xx_tuner_callback; |
269 | 294 | ||
270 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], TUNER_SET_TYPE_ADDR, &tun_setup); | 295 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], TUNER_SET_TYPE_ADDR, |
296 | &tun_setup); | ||
271 | #if 0 | 297 | #if 0 |
272 | if (tun_setup.type == TUNER_XC5000) { | 298 | if (tun_setup.type == TUNER_XC5000) { |
273 | static struct xc2028_ctrl ctrl = { | 299 | static struct xc2028_ctrl ctrl = { |
274 | .fname = XC5000_DEFAULT_FIRMWARE, | 300 | .fname = XC5000_DEFAULT_FIRMWARE, |
275 | .max_len = 64, | 301 | .max_len = 64, |
276 | .demod = 0; | 302 | .demod = 0; |
277 | }; | 303 | }; |
278 | struct v4l2_priv_tun_config cfg = { | 304 | struct v4l2_priv_tun_config cfg = { |
279 | .tuner = dev->tuner_type, | 305 | .tuner = dev->tuner_type, |
280 | .priv = &ctrl, | 306 | .priv = &ctrl, |
281 | }; | 307 | }; |
282 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], TUNER_SET_CONFIG, &cfg); | 308 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], TUNER_SET_CONFIG, |
309 | &cfg); | ||
283 | } | 310 | } |
284 | #endif | 311 | #endif |
285 | 312 | ||
286 | /* configure tuner */ | 313 | /* configure tuner */ |
287 | f.tuner = 0; | 314 | f.tuner = 0; |
288 | f.type = V4L2_TUNER_ANALOG_TV; | 315 | f.type = V4L2_TUNER_ANALOG_TV; |
289 | f.frequency = 9076; /* just a magic number */ | 316 | f.frequency = 9076; /* just a magic number */ |
290 | dev->ctl_freq = f.frequency; | 317 | dev->ctl_freq = f.frequency; |
291 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_FREQUENCY, &f); | 318 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_FREQUENCY, &f); |
292 | } | 319 | } |
@@ -298,18 +325,18 @@ void cx231xx_set_ir(struct cx231xx *dev, struct IR_i2c *ir) | |||
298 | { | 325 | { |
299 | if (disable_ir) { | 326 | if (disable_ir) { |
300 | ir->get_key = NULL; | 327 | ir->get_key = NULL; |
301 | return ; | 328 | return; |
302 | } | 329 | } |
303 | 330 | ||
304 | /* detect & configure */ | 331 | /* detect & configure */ |
305 | switch (dev->model) { | 332 | switch (dev->model) { |
306 | 333 | ||
307 | case CX231XX_BOARD_CNXT_RDE_250: | 334 | case CX231XX_BOARD_CNXT_RDE_250: |
308 | break; | 335 | break; |
309 | case CX231XX_BOARD_CNXT_RDU_250: | 336 | case CX231XX_BOARD_CNXT_RDU_250: |
310 | break; | 337 | break; |
311 | default: | 338 | default: |
312 | break; | 339 | break; |
313 | } | 340 | } |
314 | } | 341 | } |
315 | 342 | ||
@@ -321,58 +348,55 @@ void cx231xx_card_setup(struct cx231xx *dev) | |||
321 | if (cx231xx_boards[dev->model].tuner_addr) | 348 | if (cx231xx_boards[dev->model].tuner_addr) |
322 | dev->tuner_addr = cx231xx_boards[dev->model].tuner_addr; | 349 | dev->tuner_addr = cx231xx_boards[dev->model].tuner_addr; |
323 | 350 | ||
324 | cx231xx_info(": tuner type %d, tuner address %d \n", | 351 | cx231xx_info(": tuner type %d, tuner address %d \n", |
325 | dev->tuner_type, dev->tuner_addr); | 352 | dev->tuner_type, dev->tuner_addr); |
326 | 353 | ||
327 | /* Do card specific if any */ | 354 | /* Do card specific if any */ |
328 | switch (dev->model) { | 355 | switch (dev->model) { |
329 | case CX231XX_BOARD_CNXT_RDE_250: | 356 | case CX231XX_BOARD_CNXT_RDE_250: |
330 | /* do card specific GPIO settings if required */ | 357 | /* do card specific GPIO settings if required */ |
331 | cx231xx_info("Board is Conexnat RDE 250\n"); | 358 | cx231xx_info("Board is Conexnat RDE 250\n"); |
332 | break; | 359 | break; |
333 | case CX231XX_BOARD_CNXT_RDU_250: | 360 | case CX231XX_BOARD_CNXT_RDU_250: |
334 | /* do card specific GPIO settings if required */ | 361 | /* do card specific GPIO settings if required */ |
335 | cx231xx_info("Board is Conexnat RDU 250\n"); | 362 | cx231xx_info("Board is Conexnat RDU 250\n"); |
336 | break; | 363 | break; |
337 | } | 364 | } |
338 | 365 | ||
339 | if (dev->board.valid == CX231XX_BOARD_NOT_VALIDATED) { | 366 | if (dev->board.valid == CX231XX_BOARD_NOT_VALIDATED) { |
340 | cx231xx_errdev("\n\n"); | 367 | cx231xx_errdev("\n\n"); |
341 | cx231xx_errdev("The support for this board weren't " | 368 | cx231xx_errdev("The support for this board weren't " |
342 | "valid yet.\n"); | 369 | "valid yet.\n"); |
343 | cx231xx_errdev("Please send a report of having this working\n"); | 370 | cx231xx_errdev("Please send a report of having this working\n"); |
344 | cx231xx_errdev("not to V4L mailing list (and/or to other " | 371 | cx231xx_errdev("not to V4L mailing list (and/or to other " |
345 | "addresses)\n\n"); | 372 | "addresses)\n\n"); |
346 | } | 373 | } |
347 | 374 | ||
348 | |||
349 | /* request some modules */ | 375 | /* request some modules */ |
350 | if (dev->board.decoder == CX231XX_AVDECODER) { | 376 | if (dev->board.decoder == CX231XX_AVDECODER) { |
351 | cx231xx_info(": Requesting cx25840 module\n"); | 377 | cx231xx_info(": Requesting cx25840 module\n"); |
352 | request_module("cx25840"); | 378 | request_module("cx25840"); |
353 | } | 379 | } |
354 | #if 0 | 380 | #if 0 |
355 | if (dev->board.tuner_type != TUNER_ABSENT) { | 381 | if (dev->board.tuner_type != TUNER_ABSENT) { |
356 | cx231xx_info(": Requesting Tuner module\n"); | 382 | cx231xx_info(": Requesting Tuner module\n"); |
357 | request_module("tuner"); | 383 | request_module("tuner"); |
358 | } | 384 | } |
359 | 385 | ||
360 | cx231xx_config_tuner(dev); | 386 | cx231xx_config_tuner(dev); |
361 | 387 | ||
362 | /* TBD IR will be added later */ | 388 | /* TBD IR will be added later */ |
363 | cx231xx_ir_init(dev); | 389 | cx231xx_ir_init(dev); |
364 | #endif | 390 | #endif |
365 | } | 391 | } |
366 | 392 | ||
367 | |||
368 | |||
369 | /* | 393 | /* |
370 | * cx231xx_config() | 394 | * cx231xx_config() |
371 | * inits registers with sane defaults | 395 | * inits registers with sane defaults |
372 | */ | 396 | */ |
373 | int cx231xx_config(struct cx231xx *dev) | 397 | int cx231xx_config(struct cx231xx *dev) |
374 | { | 398 | { |
375 | /* TBD need to add cx231xx specific code */ | 399 | /* TBD need to add cx231xx specific code */ |
376 | dev->mute = 1; /* maybe not the right place... */ | 400 | dev->mute = 1; /* maybe not the right place... */ |
377 | dev->volume = 0x1f; | 401 | dev->volume = 0x1f; |
378 | 402 | ||
@@ -401,30 +425,29 @@ void cx231xx_config_i2c(struct cx231xx *dev) | |||
401 | void cx231xx_release_resources(struct cx231xx *dev) | 425 | void cx231xx_release_resources(struct cx231xx *dev) |
402 | { | 426 | { |
403 | 427 | ||
404 | #if 0 /* TBD IR related */ | 428 | #if 0 /* TBD IR related */ |
405 | if (dev->ir) | 429 | if (dev->ir) |
406 | cx231xx_ir_fini(dev); | 430 | cx231xx_ir_fini(dev); |
407 | #endif | 431 | #endif |
408 | 432 | ||
409 | cx231xx_release_analog_resources(dev); | 433 | cx231xx_release_analog_resources(dev); |
410 | 434 | ||
411 | cx231xx_remove_from_devlist(dev); | 435 | cx231xx_remove_from_devlist(dev); |
412 | 436 | ||
413 | cx231xx_dev_uninit(dev); | 437 | cx231xx_dev_uninit(dev); |
414 | 438 | ||
415 | usb_put_dev(dev->udev); | 439 | usb_put_dev(dev->udev); |
416 | 440 | ||
417 | /* Mark device as unused */ | 441 | /* Mark device as unused */ |
418 | cx231xx_devused &= ~(1<<dev->devno); | 442 | cx231xx_devused &= ~(1 << dev->devno); |
419 | } | 443 | } |
420 | 444 | ||
421 | |||
422 | /* | 445 | /* |
423 | * cx231xx_init_dev() | 446 | * cx231xx_init_dev() |
424 | * allocates and inits the device structs, registers i2c bus and v4l device | 447 | * allocates and inits the device structs, registers i2c bus and v4l device |
425 | */ | 448 | */ |
426 | static int cx231xx_init_dev(struct cx231xx **devhandle, struct usb_device *udev, | 449 | static int cx231xx_init_dev(struct cx231xx **devhandle, struct usb_device *udev, |
427 | int minor) | 450 | int minor) |
428 | { | 451 | { |
429 | struct cx231xx *dev = *devhandle; | 452 | struct cx231xx *dev = *devhandle; |
430 | int retval = -ENOMEM; | 453 | int retval = -ENOMEM; |
@@ -434,26 +457,26 @@ static int cx231xx_init_dev(struct cx231xx **devhandle, struct usb_device *udev, | |||
434 | dev->udev = udev; | 457 | dev->udev = udev; |
435 | mutex_init(&dev->lock); | 458 | mutex_init(&dev->lock); |
436 | mutex_init(&dev->ctrl_urb_lock); | 459 | mutex_init(&dev->ctrl_urb_lock); |
437 | mutex_init(&dev->gpio_i2c_lock); | 460 | mutex_init(&dev->gpio_i2c_lock); |
438 | 461 | ||
439 | spin_lock_init(&dev->video_mode.slock); | 462 | spin_lock_init(&dev->video_mode.slock); |
440 | spin_lock_init(&dev->vbi_mode.slock); | 463 | spin_lock_init(&dev->vbi_mode.slock); |
441 | spin_lock_init(&dev->sliced_cc_mode.slock); | 464 | spin_lock_init(&dev->sliced_cc_mode.slock); |
442 | 465 | ||
443 | init_waitqueue_head(&dev->open); | 466 | init_waitqueue_head(&dev->open); |
444 | init_waitqueue_head(&dev->wait_frame); | 467 | init_waitqueue_head(&dev->wait_frame); |
445 | init_waitqueue_head(&dev->wait_stream); | 468 | init_waitqueue_head(&dev->wait_stream); |
446 | 469 | ||
447 | dev->cx231xx_read_ctrl_reg = cx231xx_read_ctrl_reg; | 470 | dev->cx231xx_read_ctrl_reg = cx231xx_read_ctrl_reg; |
448 | dev->cx231xx_write_ctrl_reg = cx231xx_write_ctrl_reg; | 471 | dev->cx231xx_write_ctrl_reg = cx231xx_write_ctrl_reg; |
449 | dev->cx231xx_send_usb_command = cx231xx_send_usb_command; | 472 | dev->cx231xx_send_usb_command = cx231xx_send_usb_command; |
450 | dev->cx231xx_gpio_i2c_read = cx231xx_gpio_i2c_read; | 473 | dev->cx231xx_gpio_i2c_read = cx231xx_gpio_i2c_read; |
451 | dev->cx231xx_gpio_i2c_write = cx231xx_gpio_i2c_write; | 474 | dev->cx231xx_gpio_i2c_write = cx231xx_gpio_i2c_write; |
452 | 475 | ||
453 | /* Query cx231xx to find what pcb config it is related to */ | 476 | /* Query cx231xx to find what pcb config it is related to */ |
454 | initialize_cx231xx(dev); | 477 | initialize_cx231xx(dev); |
455 | 478 | ||
456 | /* Cx231xx pre card setup */ | 479 | /* Cx231xx pre card setup */ |
457 | cx231xx_pre_card_setup(dev); | 480 | cx231xx_pre_card_setup(dev); |
458 | 481 | ||
459 | errCode = cx231xx_config(dev); | 482 | errCode = cx231xx_config(dev); |
@@ -462,14 +485,14 @@ static int cx231xx_init_dev(struct cx231xx **devhandle, struct usb_device *udev, | |||
462 | return -ENOMEM; | 485 | return -ENOMEM; |
463 | } | 486 | } |
464 | 487 | ||
465 | /* set default norm */ | 488 | /* set default norm */ |
466 | dev->norm = dev->board.norm; | 489 | dev->norm = dev->board.norm; |
467 | 490 | ||
468 | /* register i2c bus */ | 491 | /* register i2c bus */ |
469 | errCode = cx231xx_dev_init(dev); | 492 | errCode = cx231xx_dev_init(dev); |
470 | if (errCode < 0) { | 493 | if (errCode < 0) { |
471 | cx231xx_errdev("%s: cx231xx_i2c_register - errCode [%d]!\n", | 494 | cx231xx_errdev("%s: cx231xx_i2c_register - errCode [%d]!\n", |
472 | __func__, errCode); | 495 | __func__, errCode); |
473 | return errCode; | 496 | return errCode; |
474 | } | 497 | } |
475 | 498 | ||
@@ -493,7 +516,7 @@ static int cx231xx_init_dev(struct cx231xx **devhandle, struct usb_device *udev, | |||
493 | errCode = cx231xx_config(dev); | 516 | errCode = cx231xx_config(dev); |
494 | if (errCode < 0) { | 517 | if (errCode < 0) { |
495 | cx231xx_errdev("%s: cx231xx_config - errCode [%d]!\n", | 518 | cx231xx_errdev("%s: cx231xx_config - errCode [%d]!\n", |
496 | __func__, errCode); | 519 | __func__, errCode); |
497 | return errCode; | 520 | return errCode; |
498 | } | 521 | } |
499 | 522 | ||
@@ -501,13 +524,13 @@ static int cx231xx_init_dev(struct cx231xx **devhandle, struct usb_device *udev, | |||
501 | INIT_LIST_HEAD(&dev->video_mode.vidq.active); | 524 | INIT_LIST_HEAD(&dev->video_mode.vidq.active); |
502 | INIT_LIST_HEAD(&dev->video_mode.vidq.queued); | 525 | INIT_LIST_HEAD(&dev->video_mode.vidq.queued); |
503 | 526 | ||
504 | /* init vbi dma queues */ | 527 | /* init vbi dma queues */ |
505 | INIT_LIST_HEAD(&dev->vbi_mode.vidq.active); | 528 | INIT_LIST_HEAD(&dev->vbi_mode.vidq.active); |
506 | INIT_LIST_HEAD(&dev->vbi_mode.vidq.queued); | 529 | INIT_LIST_HEAD(&dev->vbi_mode.vidq.queued); |
507 | 530 | ||
508 | /* Reset other chips required if they are tied up with GPIO pins */ | 531 | /* Reset other chips required if they are tied up with GPIO pins */ |
509 | 532 | ||
510 | cx231xx_add_into_devlist(dev); | 533 | cx231xx_add_into_devlist(dev); |
511 | 534 | ||
512 | retval = cx231xx_register_analog_devices(dev); | 535 | retval = cx231xx_register_analog_devices(dev); |
513 | if (retval < 0) { | 536 | if (retval < 0) { |
@@ -519,7 +542,7 @@ static int cx231xx_init_dev(struct cx231xx **devhandle, struct usb_device *udev, | |||
519 | 542 | ||
520 | return 0; | 543 | return 0; |
521 | 544 | ||
522 | fail_reg_devices: | 545 | fail_reg_devices: |
523 | mutex_unlock(&dev->lock); | 546 | mutex_unlock(&dev->lock); |
524 | return retval; | 547 | return retval; |
525 | } | 548 | } |
@@ -528,8 +551,7 @@ fail_reg_devices: | |||
528 | static void request_module_async(struct work_struct *work) | 551 | static void request_module_async(struct work_struct *work) |
529 | { | 552 | { |
530 | struct cx231xx *dev = container_of(work, | 553 | struct cx231xx *dev = container_of(work, |
531 | struct cx231xx, request_module_wk); | 554 | struct cx231xx, request_module_wk); |
532 | |||
533 | 555 | ||
534 | if (dev->has_alsa_audio) | 556 | if (dev->has_alsa_audio) |
535 | request_module("cx231xx-alsa"); | 557 | request_module("cx231xx-alsa"); |
@@ -548,130 +570,130 @@ static void request_modules(struct cx231xx *dev) | |||
548 | #define request_modules(dev) | 570 | #define request_modules(dev) |
549 | #endif /* CONFIG_MODULES */ | 571 | #endif /* CONFIG_MODULES */ |
550 | 572 | ||
551 | |||
552 | |||
553 | /* | 573 | /* |
554 | * cx231xx_usb_probe() | 574 | * cx231xx_usb_probe() |
555 | * checks for supported devices | 575 | * checks for supported devices |
556 | */ | 576 | */ |
557 | static int cx231xx_usb_probe(struct usb_interface *interface, | 577 | static int cx231xx_usb_probe(struct usb_interface *interface, |
558 | const struct usb_device_id *id) | 578 | const struct usb_device_id *id) |
559 | { | 579 | { |
560 | struct usb_device *udev; | 580 | struct usb_device *udev; |
561 | struct usb_interface *uif; | 581 | struct usb_interface *uif; |
562 | struct cx231xx *dev = NULL; | 582 | struct cx231xx *dev = NULL; |
563 | int retval = -ENODEV; | 583 | int retval = -ENODEV; |
564 | int nr, ifnum; | 584 | int nr, ifnum; |
565 | int i, isoc_pipe = 0; | 585 | int i, isoc_pipe = 0; |
566 | char *speed; | 586 | char *speed; |
567 | char descr[255] = ""; | 587 | char descr[255] = ""; |
568 | struct usb_interface *lif = NULL; | 588 | struct usb_interface *lif = NULL; |
569 | int skip_interface = 0; | 589 | int skip_interface = 0; |
570 | struct usb_interface_assoc_descriptor *assoc_desc; | 590 | struct usb_interface_assoc_descriptor *assoc_desc; |
571 | 591 | ||
572 | udev = usb_get_dev(interface_to_usbdev(interface)); | 592 | udev = usb_get_dev(interface_to_usbdev(interface)); |
573 | ifnum = interface->altsetting[0].desc.bInterfaceNumber; | 593 | ifnum = interface->altsetting[0].desc.bInterfaceNumber; |
574 | 594 | ||
575 | cx231xx_info(": Interface Number %d\n", ifnum); | 595 | cx231xx_info(": Interface Number %d\n", ifnum); |
576 | 596 | ||
577 | /* Interface number 0 - IR interface */ | 597 | /* Interface number 0 - IR interface */ |
578 | if(ifnum == 0 ){ | 598 | if (ifnum == 0) { |
579 | /* Check to see next free device and mark as used */ | 599 | /* Check to see next free device and mark as used */ |
580 | nr = find_first_zero_bit(&cx231xx_devused, CX231XX_MAXBOARDS); | 600 | nr = find_first_zero_bit(&cx231xx_devused, CX231XX_MAXBOARDS); |
581 | cx231xx_devused |= 1<<nr; | 601 | cx231xx_devused |= 1 << nr; |
582 | 602 | ||
583 | if (nr >= CX231XX_MAXBOARDS) { | 603 | if (nr >= CX231XX_MAXBOARDS) { |
584 | cx231xx_info(": Supports only %i cx231xx boards.\n", | 604 | cx231xx_info(": Supports only %i cx231xx boards.\n", |
585 | CX231XX_MAXBOARDS); | 605 | CX231XX_MAXBOARDS); |
586 | cx231xx_devused &= ~(1<<nr); | 606 | cx231xx_devused &= ~(1 << nr); |
587 | return -ENOMEM; | 607 | return -ENOMEM; |
588 | } | 608 | } |
589 | 609 | ||
590 | /* allocate memory for our device state and initialize it */ | 610 | /* allocate memory for our device state and initialize it */ |
591 | dev = kzalloc(sizeof(*dev), GFP_KERNEL); | 611 | dev = kzalloc(sizeof(*dev), GFP_KERNEL); |
592 | if (dev == NULL) { | 612 | if (dev == NULL) { |
593 | cx231xx_err(DRIVER_NAME ": out of memory!\n"); | 613 | cx231xx_err(DRIVER_NAME ": out of memory!\n"); |
594 | cx231xx_devused &= ~(1<<nr); | 614 | cx231xx_devused &= ~(1 << nr); |
595 | return -ENOMEM; | 615 | return -ENOMEM; |
596 | } | 616 | } |
597 | 617 | ||
598 | snprintf(dev->name, 29, "cx231xx #%d", nr); | 618 | snprintf(dev->name, 29, "cx231xx #%d", nr); |
599 | dev->devno = nr; | 619 | dev->devno = nr; |
600 | dev->model = id->driver_info; | 620 | dev->model = id->driver_info; |
601 | dev->video_mode.alt = -1; | 621 | dev->video_mode.alt = -1; |
602 | dev->interface_count++; | 622 | dev->interface_count++; |
603 | 623 | ||
604 | /* reset gpio dir and value */ | 624 | /* reset gpio dir and value */ |
605 | dev->gpio_dir = 0; | 625 | dev->gpio_dir = 0; |
606 | dev->gpio_val = 0; | 626 | dev->gpio_val = 0; |
607 | dev->xc_fw_load_done = 0; | 627 | dev->xc_fw_load_done = 0; |
608 | dev->has_alsa_audio = 1; | 628 | dev->has_alsa_audio = 1; |
609 | dev->power_mode = -1; | 629 | dev->power_mode = -1; |
610 | 630 | ||
611 | dev->vbi_or_sliced_cc_mode = 0; /* 0 - vbi ; 1 -sliced cc mode */ | 631 | dev->vbi_or_sliced_cc_mode = 0; /* 0 - vbi ; 1 -sliced cc mode */ |
612 | 632 | ||
613 | /* get maximum no.of IAD interfaces */ | 633 | /* get maximum no.of IAD interfaces */ |
614 | assoc_desc = udev->actconfig->intf_assoc[0]; | 634 | assoc_desc = udev->actconfig->intf_assoc[0]; |
615 | dev->max_iad_interface_count = assoc_desc->bInterfaceCount; | 635 | dev->max_iad_interface_count = assoc_desc->bInterfaceCount; |
616 | cx231xx_info(": Found IAD interface count %d\n", dev->max_iad_interface_count); | 636 | cx231xx_info(": Found IAD interface count %d\n", |
617 | 637 | dev->max_iad_interface_count); | |
618 | /* init CIR module TBD */ | 638 | |
619 | 639 | /* init CIR module TBD */ | |
620 | /* store the current interface */ | 640 | |
621 | lif = interface; | 641 | /* store the current interface */ |
622 | 642 | lif = interface; | |
623 | } | 643 | |
624 | else if(ifnum == 1 ){ | 644 | } else if (ifnum == 1) { |
625 | 645 | ||
626 | /* Get dev structure first */ | 646 | /* Get dev structure first */ |
627 | dev = usb_get_intfdata(udev->actconfig->interface[0]); | 647 | dev = usb_get_intfdata(udev->actconfig->interface[0]); |
628 | if(dev == NULL){ | 648 | if (dev == NULL) { |
629 | cx231xx_err(DRIVER_NAME ": out of first interface!\n"); | 649 | cx231xx_err(DRIVER_NAME ": out of first interface!\n"); |
630 | return -ENODEV; | 650 | return -ENODEV; |
631 | } | 651 | } |
632 | 652 | ||
633 | /* store the interface 0 back */ | 653 | /* store the interface 0 back */ |
634 | lif = udev->actconfig->interface[0]; | 654 | lif = udev->actconfig->interface[0]; |
635 | 655 | ||
636 | /* increment interface count */ | 656 | /* increment interface count */ |
637 | dev->interface_count++; | 657 | dev->interface_count++; |
638 | 658 | ||
639 | /* get device number */ | 659 | /* get device number */ |
640 | nr = dev->devno; | 660 | nr = dev->devno; |
641 | 661 | ||
642 | assoc_desc = udev->actconfig->intf_assoc[0]; | 662 | assoc_desc = udev->actconfig->intf_assoc[0]; |
643 | if(assoc_desc->bFirstInterface == ifnum){ | 663 | if (assoc_desc->bFirstInterface == ifnum) { |
644 | cx231xx_info(": Found IAD interface match: AV Descriptor Start!! \n"); | 664 | cx231xx_info |
645 | } else { | 665 | (": Found IAD interface match: AV Descriptor Start!! \n"); |
646 | cx231xx_err(DRIVER_NAME " Not found matching interface\n"); | 666 | } else { |
647 | return -ENODEV; | 667 | cx231xx_err(DRIVER_NAME |
648 | } | 668 | " Not found matching interface\n"); |
649 | 669 | return -ENODEV; | |
650 | } | 670 | } |
651 | else if(ifnum >= 2) { | 671 | |
652 | /* Get dev structure first */ | 672 | } else if (ifnum >= 2) { |
653 | dev = usb_get_intfdata(udev->actconfig->interface[0]); | 673 | /* Get dev structure first */ |
654 | if(dev == NULL){ | 674 | dev = usb_get_intfdata(udev->actconfig->interface[0]); |
655 | cx231xx_err(DRIVER_NAME ": out of first interface!\n"); | 675 | if (dev == NULL) { |
656 | return -ENODEV; | 676 | cx231xx_err(DRIVER_NAME ": out of first interface!\n"); |
657 | } | 677 | return -ENODEV; |
658 | 678 | } | |
659 | /* store the interface 0 back */ | 679 | |
660 | lif = udev->actconfig->interface[0]; | 680 | /* store the interface 0 back */ |
661 | 681 | lif = udev->actconfig->interface[0]; | |
662 | /* increment interface count */ | 682 | |
663 | dev->interface_count++; | 683 | /* increment interface count */ |
664 | 684 | dev->interface_count++; | |
665 | /* get device number */ | 685 | |
666 | nr = dev->devno; | 686 | /* get device number */ |
667 | 687 | nr = dev->devno; | |
668 | /* set skip interface */ | 688 | |
669 | if((dev->interface_count -1) != dev->max_iad_interface_count ) | 689 | /* set skip interface */ |
670 | skip_interface = 1; /* set skipping */ | 690 | if ((dev->interface_count - 1) != dev->max_iad_interface_count) |
671 | else{ | 691 | skip_interface = 1; /* set skipping */ |
672 | cx231xx_info(": Found IAD interface number match with AV Device number!! \n"); | 692 | else { |
673 | } | 693 | cx231xx_info |
674 | } | 694 | (": Found IAD interface number match with AV Device number!! \n"); |
695 | } | ||
696 | } | ||
675 | 697 | ||
676 | switch (udev->speed) { | 698 | switch (udev->speed) { |
677 | case USB_SPEED_LOW: | 699 | case USB_SPEED_LOW: |
@@ -700,153 +722,184 @@ static int cx231xx_usb_probe(struct usb_interface *interface, | |||
700 | strlcat(descr, " ", sizeof(descr)); | 722 | strlcat(descr, " ", sizeof(descr)); |
701 | 723 | ||
702 | cx231xx_info("New device %s@ %s Mbps " | 724 | cx231xx_info("New device %s@ %s Mbps " |
703 | "(%04x:%04x, interface %d, class %d)\n", | 725 | "(%04x:%04x, interface %d, class %d)\n", |
704 | descr, | 726 | descr, |
705 | speed, | 727 | speed, |
706 | le16_to_cpu(udev->descriptor.idVendor), | 728 | le16_to_cpu(udev->descriptor.idVendor), |
707 | le16_to_cpu(udev->descriptor.idProduct), | 729 | le16_to_cpu(udev->descriptor.idProduct), |
708 | ifnum, | 730 | ifnum, interface->altsetting->desc.bInterfaceNumber); |
709 | interface->altsetting->desc.bInterfaceNumber); | 731 | |
710 | 732 | /* AV device initialization */ | |
711 | /* AV device initialization */ | 733 | if ((dev->interface_count - 1) == dev->max_iad_interface_count) { |
712 | if((dev->interface_count -1) == dev->max_iad_interface_count ) { | 734 | cx231xx_info(" Calling init_dev\n"); |
713 | cx231xx_info(" Calling init_dev\n"); | 735 | /* allocate device struct */ |
714 | /* allocate device struct */ | 736 | retval = cx231xx_init_dev(&dev, udev, nr); |
715 | retval = cx231xx_init_dev(&dev, udev, nr); | 737 | if (retval) { |
716 | if (retval) { | 738 | cx231xx_devused &= ~(1 << dev->devno); |
717 | cx231xx_devused &= ~(1<<dev->devno); | 739 | kfree(dev); |
718 | kfree(dev); | 740 | |
719 | 741 | return retval; | |
720 | return retval; | 742 | } |
721 | } | 743 | |
722 | 744 | /* compute alternate max packet sizes for video */ | |
723 | /* compute alternate max packet sizes for video */ | 745 | uif = |
724 | uif = udev->actconfig->interface[dev->current_pcb_config.hs_config_info[0].interface_info.video_index+1]; | 746 | udev->actconfig->interface[dev->current_pcb_config. |
725 | 747 | hs_config_info[0].interface_info. | |
726 | dev->video_mode.end_point_addr = le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc.bEndpointAddress); | 748 | video_index + 1]; |
727 | 749 | ||
728 | dev->video_mode.num_alt = uif->num_altsetting; | 750 | dev->video_mode.end_point_addr = |
729 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", dev->video_mode.end_point_addr, | 751 | le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc. |
730 | dev->video_mode.num_alt); | 752 | bEndpointAddress); |
731 | dev->video_mode.alt_max_pkt_size = kmalloc(32 * dev->video_mode.num_alt, GFP_KERNEL); | 753 | |
732 | 754 | dev->video_mode.num_alt = uif->num_altsetting; | |
733 | if (dev->video_mode.alt_max_pkt_size == NULL) { | 755 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", |
734 | cx231xx_errdev("out of memory!\n"); | 756 | dev->video_mode.end_point_addr, |
735 | cx231xx_devused &= ~(1<<nr); | 757 | dev->video_mode.num_alt); |
736 | kfree(dev); | 758 | dev->video_mode.alt_max_pkt_size = |
737 | return -ENOMEM; | 759 | kmalloc(32 * dev->video_mode.num_alt, GFP_KERNEL); |
738 | } | 760 | |
739 | 761 | if (dev->video_mode.alt_max_pkt_size == NULL) { | |
740 | for (i = 0; i < dev->video_mode.num_alt ; i++) { | 762 | cx231xx_errdev("out of memory!\n"); |
741 | u16 tmp = le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].desc. | 763 | cx231xx_devused &= ~(1 << nr); |
742 | wMaxPacketSize); | 764 | kfree(dev); |
743 | dev->video_mode.alt_max_pkt_size[i] = | 765 | return -ENOMEM; |
744 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); | 766 | } |
745 | cx231xx_info("Alternate setting %i, max size= %i\n", i, | 767 | |
746 | dev->video_mode.alt_max_pkt_size[i]); | 768 | for (i = 0; i < dev->video_mode.num_alt; i++) { |
747 | } | 769 | u16 tmp = |
748 | 770 | le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe]. | |
749 | 771 | desc.wMaxPacketSize); | |
750 | /* compute alternate max packet sizes for vbi */ | 772 | dev->video_mode.alt_max_pkt_size[i] = |
751 | uif = udev->actconfig->interface[dev->current_pcb_config.hs_config_info[0].interface_info.vanc_index+1]; | 773 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); |
752 | 774 | cx231xx_info("Alternate setting %i, max size= %i\n", i, | |
753 | dev->vbi_mode.end_point_addr = | 775 | dev->video_mode.alt_max_pkt_size[i]); |
754 | le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc.bEndpointAddress); | 776 | } |
755 | 777 | ||
756 | dev->vbi_mode.num_alt = uif->num_altsetting; | 778 | /* compute alternate max packet sizes for vbi */ |
757 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", dev->vbi_mode.end_point_addr, | 779 | uif = |
758 | dev->vbi_mode.num_alt); | 780 | udev->actconfig->interface[dev->current_pcb_config. |
759 | dev->vbi_mode.alt_max_pkt_size = kmalloc(32 * dev->vbi_mode.num_alt, GFP_KERNEL); | 781 | hs_config_info[0].interface_info. |
760 | 782 | vanc_index + 1]; | |
761 | if (dev->vbi_mode.alt_max_pkt_size == NULL) { | 783 | |
762 | cx231xx_errdev("out of memory!\n"); | 784 | dev->vbi_mode.end_point_addr = |
763 | cx231xx_devused &= ~(1<<nr); | 785 | le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc. |
764 | kfree(dev); | 786 | bEndpointAddress); |
765 | return -ENOMEM; | 787 | |
766 | } | 788 | dev->vbi_mode.num_alt = uif->num_altsetting; |
767 | 789 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", | |
768 | for (i = 0; i < dev->vbi_mode.num_alt ; i++) { | 790 | dev->vbi_mode.end_point_addr, |
769 | u16 tmp = le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].desc. | 791 | dev->vbi_mode.num_alt); |
770 | wMaxPacketSize); | 792 | dev->vbi_mode.alt_max_pkt_size = |
771 | dev->vbi_mode.alt_max_pkt_size[i] = | 793 | kmalloc(32 * dev->vbi_mode.num_alt, GFP_KERNEL); |
772 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); | 794 | |
773 | cx231xx_info("Alternate setting %i, max size= %i\n", i, | 795 | if (dev->vbi_mode.alt_max_pkt_size == NULL) { |
774 | dev->vbi_mode.alt_max_pkt_size[i]); | 796 | cx231xx_errdev("out of memory!\n"); |
775 | } | 797 | cx231xx_devused &= ~(1 << nr); |
776 | 798 | kfree(dev); | |
777 | /* compute alternate max packet sizes for sliced CC */ | 799 | return -ENOMEM; |
778 | uif = udev->actconfig->interface[dev->current_pcb_config.hs_config_info[0].interface_info.hanc_index+1]; | 800 | } |
779 | 801 | ||
780 | dev->sliced_cc_mode.end_point_addr = | 802 | for (i = 0; i < dev->vbi_mode.num_alt; i++) { |
781 | le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc.bEndpointAddress); | 803 | u16 tmp = |
782 | 804 | le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe]. | |
783 | dev->sliced_cc_mode.num_alt = uif->num_altsetting; | 805 | desc.wMaxPacketSize); |
784 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", dev->sliced_cc_mode.end_point_addr, | 806 | dev->vbi_mode.alt_max_pkt_size[i] = |
785 | dev->sliced_cc_mode.num_alt); | 807 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); |
786 | dev->sliced_cc_mode.alt_max_pkt_size = kmalloc(32 * dev->sliced_cc_mode.num_alt, GFP_KERNEL); | 808 | cx231xx_info("Alternate setting %i, max size= %i\n", i, |
787 | 809 | dev->vbi_mode.alt_max_pkt_size[i]); | |
788 | if (dev->sliced_cc_mode.alt_max_pkt_size == NULL) { | 810 | } |
789 | cx231xx_errdev("out of memory!\n"); | 811 | |
790 | cx231xx_devused &= ~(1<<nr); | 812 | /* compute alternate max packet sizes for sliced CC */ |
791 | kfree(dev); | 813 | uif = |
792 | return -ENOMEM; | 814 | udev->actconfig->interface[dev->current_pcb_config. |
793 | } | 815 | hs_config_info[0].interface_info. |
794 | 816 | hanc_index + 1]; | |
795 | for (i = 0; i < dev->sliced_cc_mode.num_alt ; i++) { | 817 | |
796 | u16 tmp = le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].desc. | 818 | dev->sliced_cc_mode.end_point_addr = |
797 | wMaxPacketSize); | 819 | le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc. |
798 | dev->sliced_cc_mode.alt_max_pkt_size[i] = | 820 | bEndpointAddress); |
799 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); | 821 | |
800 | cx231xx_info("Alternate setting %i, max size= %i\n", i, | 822 | dev->sliced_cc_mode.num_alt = uif->num_altsetting; |
801 | dev->sliced_cc_mode.alt_max_pkt_size[i]); | 823 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", |
802 | } | 824 | dev->sliced_cc_mode.end_point_addr, |
803 | 825 | dev->sliced_cc_mode.num_alt); | |
804 | if(dev->current_pcb_config.ts1_source != 0xff ) { | 826 | dev->sliced_cc_mode.alt_max_pkt_size = |
805 | 827 | kmalloc(32 * dev->sliced_cc_mode.num_alt, GFP_KERNEL); | |
806 | /* compute alternate max packet sizes for TS1 */ | 828 | |
807 | uif = udev->actconfig->interface[dev->current_pcb_config.hs_config_info[0].interface_info.ts1_index+1]; | 829 | if (dev->sliced_cc_mode.alt_max_pkt_size == NULL) { |
808 | 830 | cx231xx_errdev("out of memory!\n"); | |
809 | dev->ts1_mode.end_point_addr = | 831 | cx231xx_devused &= ~(1 << nr); |
810 | le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe].desc.bEndpointAddress); | 832 | kfree(dev); |
811 | 833 | return -ENOMEM; | |
812 | dev->ts1_mode.num_alt = uif->num_altsetting; | 834 | } |
813 | cx231xx_info(": EndPoint Addr 0x%x, Alternate settings: %i\n", dev->ts1_mode.end_point_addr, | 835 | |
814 | dev->ts1_mode.num_alt); | 836 | for (i = 0; i < dev->sliced_cc_mode.num_alt; i++) { |
815 | dev->ts1_mode.alt_max_pkt_size = kmalloc(32 * dev->ts1_mode.num_alt, GFP_KERNEL); | 837 | u16 tmp = |
816 | 838 | le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe]. | |
817 | if (dev->ts1_mode.alt_max_pkt_size == NULL) { | 839 | desc.wMaxPacketSize); |
818 | cx231xx_errdev("out of memory!\n"); | 840 | dev->sliced_cc_mode.alt_max_pkt_size[i] = |
819 | cx231xx_devused &= ~(1<<nr); | 841 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); |
820 | kfree(dev); | 842 | cx231xx_info("Alternate setting %i, max size= %i\n", i, |
821 | return -ENOMEM; | 843 | dev->sliced_cc_mode.alt_max_pkt_size[i]); |
822 | } | 844 | } |
823 | 845 | ||
824 | for (i = 0; i < dev->ts1_mode.num_alt ; i++) { | 846 | if (dev->current_pcb_config.ts1_source != 0xff) { |
825 | u16 tmp = le16_to_cpu(uif->altsetting[i].endpoint[isoc_pipe].desc. | 847 | |
826 | wMaxPacketSize); | 848 | /* compute alternate max packet sizes for TS1 */ |
827 | dev->ts1_mode.alt_max_pkt_size[i] = | 849 | uif = |
828 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + 1); | 850 | udev->actconfig->interface[dev->current_pcb_config. |
829 | cx231xx_info("Alternate setting %i, max size= %i\n", i, | 851 | hs_config_info[0]. |
830 | dev->ts1_mode.alt_max_pkt_size[i]); | 852 | interface_info. |
831 | } | 853 | ts1_index + 1]; |
832 | } | 854 | |
833 | 855 | dev->ts1_mode.end_point_addr = | |
834 | } | 856 | le16_to_cpu(uif->altsetting[0].endpoint[isoc_pipe]. |
857 | desc.bEndpointAddress); | ||
858 | |||
859 | dev->ts1_mode.num_alt = uif->num_altsetting; | ||
860 | cx231xx_info | ||
861 | (": EndPoint Addr 0x%x, Alternate settings: %i\n", | ||
862 | dev->ts1_mode.end_point_addr, | ||
863 | dev->ts1_mode.num_alt); | ||
864 | dev->ts1_mode.alt_max_pkt_size = | ||
865 | kmalloc(32 * dev->ts1_mode.num_alt, GFP_KERNEL); | ||
866 | |||
867 | if (dev->ts1_mode.alt_max_pkt_size == NULL) { | ||
868 | cx231xx_errdev("out of memory!\n"); | ||
869 | cx231xx_devused &= ~(1 << nr); | ||
870 | kfree(dev); | ||
871 | return -ENOMEM; | ||
872 | } | ||
873 | |||
874 | for (i = 0; i < dev->ts1_mode.num_alt; i++) { | ||
875 | u16 tmp = | ||
876 | le16_to_cpu(uif->altsetting[i]. | ||
877 | endpoint[isoc_pipe].desc. | ||
878 | wMaxPacketSize); | ||
879 | dev->ts1_mode.alt_max_pkt_size[i] = | ||
880 | (tmp & 0x07ff) * (((tmp & 0x1800) >> 11) + | ||
881 | 1); | ||
882 | cx231xx_info | ||
883 | ("Alternate setting %i, max size= %i\n", i, | ||
884 | dev->ts1_mode.alt_max_pkt_size[i]); | ||
885 | } | ||
886 | } | ||
887 | |||
888 | } | ||
835 | 889 | ||
836 | /* save our data pointer in this interface device */ | 890 | /* save our data pointer in this interface device */ |
837 | usb_set_intfdata(lif, dev); | 891 | usb_set_intfdata(lif, dev); |
838 | 892 | ||
839 | /* load other modules required */ | 893 | /* load other modules required */ |
840 | if((dev->interface_count -1) == dev->max_iad_interface_count ) | 894 | if ((dev->interface_count - 1) == dev->max_iad_interface_count) { |
841 | { | 895 | cx231xx_info("Calling request modules\n"); |
842 | cx231xx_info("Calling request modules\n"); | 896 | request_modules(dev); |
843 | request_modules(dev); | 897 | } |
844 | } | ||
845 | 898 | ||
846 | if(skip_interface ) { | 899 | if (skip_interface) { |
847 | cx231xx_info("Skipping the interface\n"); | 900 | cx231xx_info("Skipping the interface\n"); |
848 | return -ENODEV; | 901 | return -ENODEV; |
849 | } | 902 | } |
850 | 903 | ||
851 | return 0; | 904 | return 0; |
852 | } | 905 | } |
@@ -860,7 +913,7 @@ static void cx231xx_usb_disconnect(struct usb_interface *interface) | |||
860 | { | 913 | { |
861 | struct cx231xx *dev; | 914 | struct cx231xx *dev; |
862 | 915 | ||
863 | dev = usb_get_intfdata(interface); | 916 | dev = usb_get_intfdata(interface); |
864 | usb_set_intfdata(interface, NULL); | 917 | usb_set_intfdata(interface, NULL); |
865 | 918 | ||
866 | if (!dev) | 919 | if (!dev) |
@@ -875,8 +928,7 @@ static void cx231xx_usb_disconnect(struct usb_interface *interface) | |||
875 | if (dev->users) { | 928 | if (dev->users) { |
876 | cx231xx_warn | 929 | cx231xx_warn |
877 | ("device /dev/video%d is open! Deregistration and memory " | 930 | ("device /dev/video%d is open! Deregistration and memory " |
878 | "deallocation are deferred on close.\n", | 931 | "deallocation are deferred on close.\n", dev->vdev->num); |
879 | dev->vdev->num); | ||
880 | 932 | ||
881 | dev->state |= DEV_MISCONFIGURED; | 933 | dev->state |= DEV_MISCONFIGURED; |
882 | cx231xx_uninit_isoc(dev); | 934 | cx231xx_uninit_isoc(dev); |
@@ -888,15 +940,15 @@ static void cx231xx_usb_disconnect(struct usb_interface *interface) | |||
888 | cx231xx_release_resources(dev); | 940 | cx231xx_release_resources(dev); |
889 | } | 941 | } |
890 | 942 | ||
891 | cx231xx_close_extension(dev); | 943 | cx231xx_close_extension(dev); |
892 | 944 | ||
893 | mutex_unlock(&dev->lock); | 945 | mutex_unlock(&dev->lock); |
894 | 946 | ||
895 | if (!dev->users) { | 947 | if (!dev->users) { |
896 | kfree(dev->video_mode.alt_max_pkt_size); | 948 | kfree(dev->video_mode.alt_max_pkt_size); |
897 | kfree(dev->vbi_mode.alt_max_pkt_size); | 949 | kfree(dev->vbi_mode.alt_max_pkt_size); |
898 | kfree(dev->sliced_cc_mode.alt_max_pkt_size); | 950 | kfree(dev->sliced_cc_mode.alt_max_pkt_size); |
899 | kfree(dev->ts1_mode.alt_max_pkt_size); | 951 | kfree(dev->ts1_mode.alt_max_pkt_size); |
900 | kfree(dev); | 952 | kfree(dev); |
901 | } | 953 | } |
902 | } | 954 | } |
@@ -920,7 +972,7 @@ static int __init cx231xx_module_init(void) | |||
920 | result = usb_register(&cx231xx_usb_driver); | 972 | result = usb_register(&cx231xx_usb_driver); |
921 | if (result) | 973 | if (result) |
922 | cx231xx_err(DRIVER_NAME | 974 | cx231xx_err(DRIVER_NAME |
923 | " usb_register failed. Error number %d.\n", result); | 975 | " usb_register failed. Error number %d.\n", result); |
924 | 976 | ||
925 | return result; | 977 | return result; |
926 | } | 978 | } |
diff --git a/drivers/media/video/cx231xx/cx231xx-conf-reg.h b/drivers/media/video/cx231xx/cx231xx-conf-reg.h index 5ccf6bdfe579..a65f99ba109b 100644 --- a/drivers/media/video/cx231xx/cx231xx-conf-reg.h +++ b/drivers/media/video/cx231xx/cx231xx-conf-reg.h | |||
@@ -1,6 +1,6 @@ | |||
1 | /* | 1 | /* |
2 | cx231xx_conf-reg.h - driver for Conexant Cx23100/101/102 USB | 2 | cx231xx_conf-reg.h - driver for Conexant Cx23100/101/102 USB |
3 | video capture devices | 3 | video capture devices |
4 | 4 | ||
5 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 5 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
6 | 6 | ||
@@ -19,7 +19,6 @@ | |||
19 | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 19 | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
20 | */ | 20 | */ |
21 | 21 | ||
22 | |||
23 | #ifndef _POLARIS_REG_H_ | 22 | #ifndef _POLARIS_REG_H_ |
24 | #define _POLARIS_REG_H_ | 23 | #define _POLARIS_REG_H_ |
25 | 24 | ||
@@ -43,30 +42,30 @@ | |||
43 | #define PWR_CTL_EN 0x74 | 42 | #define PWR_CTL_EN 0x74 |
44 | 43 | ||
45 | /* Polaris Endpoints capture mask for register EP_MODE_SET */ | 44 | /* Polaris Endpoints capture mask for register EP_MODE_SET */ |
46 | #define ENABLE_EP1 0x01 /* Bit[0]=1 */ | 45 | #define ENABLE_EP1 0x01 /* Bit[0]=1 */ |
47 | #define ENABLE_EP2 0x02 /* Bit[1]=1 */ | 46 | #define ENABLE_EP2 0x02 /* Bit[1]=1 */ |
48 | #define ENABLE_EP3 0x04 /* Bit[2]=1 */ | 47 | #define ENABLE_EP3 0x04 /* Bit[2]=1 */ |
49 | #define ENABLE_EP4 0x08 /* Bit[3]=1 */ | 48 | #define ENABLE_EP4 0x08 /* Bit[3]=1 */ |
50 | #define ENABLE_EP5 0x10 /* Bit[4]=1 */ | 49 | #define ENABLE_EP5 0x10 /* Bit[4]=1 */ |
51 | #define ENABLE_EP6 0x20 /* Bit[5]=1 */ | 50 | #define ENABLE_EP6 0x20 /* Bit[5]=1 */ |
52 | 51 | ||
53 | /* Bit definition for register PWR_CTL_EN */ | 52 | /* Bit definition for register PWR_CTL_EN */ |
54 | #define PWR_MODE_MASK 0x17f | 53 | #define PWR_MODE_MASK 0x17f |
55 | #define PWR_AV_EN 0x08 /* bit3 */ | 54 | #define PWR_AV_EN 0x08 /* bit3 */ |
56 | #define PWR_ISO_EN 0x40 /* bit6 */ | 55 | #define PWR_ISO_EN 0x40 /* bit6 */ |
57 | #define PWR_AV_MODE 0x30 /* bit4,5 */ | 56 | #define PWR_AV_MODE 0x30 /* bit4,5 */ |
58 | #define PWR_TUNER_EN 0x04 /* bit2 */ | 57 | #define PWR_TUNER_EN 0x04 /* bit2 */ |
59 | #define PWR_DEMOD_EN 0x02 /* bit1 */ | 58 | #define PWR_DEMOD_EN 0x02 /* bit1 */ |
60 | #define I2C_DEMOD_EN 0x01 /* bit0 */ | 59 | #define I2C_DEMOD_EN 0x01 /* bit0 */ |
61 | #define PWR_RESETOUT_EN 0x100 /* bit8 */ | 60 | #define PWR_RESETOUT_EN 0x100 /* bit8 */ |
62 | 61 | ||
63 | typedef enum{ | 62 | typedef enum { |
64 | POLARIS_AVMODE_DEFAULT = 0, | 63 | POLARIS_AVMODE_DEFAULT = 0, |
65 | POLARIS_AVMODE_DIGITAL = 0x10, | 64 | POLARIS_AVMODE_DIGITAL = 0x10, |
66 | POLARIS_AVMODE_ANALOGT_TV = 0x20, | 65 | POLARIS_AVMODE_ANALOGT_TV = 0x20, |
67 | POLARIS_AVMODE_ENXTERNAL_AV = 0x30, | 66 | POLARIS_AVMODE_ENXTERNAL_AV = 0x30, |
68 | 67 | ||
69 | }AV_MODE; | 68 | } AV_MODE; |
70 | 69 | ||
71 | /* Colibri Registers */ | 70 | /* Colibri Registers */ |
72 | 71 | ||
@@ -75,8 +74,6 @@ typedef enum{ | |||
75 | #define EU_IF 0x9 | 74 | #define EU_IF 0x9 |
76 | #define US_IF 0xa | 75 | #define US_IF 0xa |
77 | 76 | ||
78 | |||
79 | |||
80 | #define SUP_BLK_TUNE1 0x00 | 77 | #define SUP_BLK_TUNE1 0x00 |
81 | #define SUP_BLK_TUNE2 0x01 | 78 | #define SUP_BLK_TUNE2 0x01 |
82 | #define SUP_BLK_TUNE3 0x02 | 79 | #define SUP_BLK_TUNE3 0x02 |
@@ -129,7 +126,7 @@ typedef enum{ | |||
129 | #define ADC_INPUT_CH1 0x28 | 126 | #define ADC_INPUT_CH1 0x28 |
130 | #define ADC_INPUT_CH2 0x48 | 127 | #define ADC_INPUT_CH2 0x48 |
131 | #define ADC_INPUT_CH3 0x68 | 128 | #define ADC_INPUT_CH3 0x68 |
132 | #define INPUT_SEL_MASK 0x30 /* [5:4] in_sel */ | 129 | #define INPUT_SEL_MASK 0x30 /* [5:4] in_sel */ |
133 | 130 | ||
134 | #define ADC_NTF_PRECLMP_EN_CH1 0x29 | 131 | #define ADC_NTF_PRECLMP_EN_CH1 0x29 |
135 | #define ADC_NTF_PRECLMP_EN_CH2 0x49 | 132 | #define ADC_NTF_PRECLMP_EN_CH2 0x49 |
@@ -148,12 +145,12 @@ typedef enum{ | |||
148 | #define TESTBUS_CTRL_CH3 0x72 | 145 | #define TESTBUS_CTRL_CH3 0x72 |
149 | 146 | ||
150 | /****************************************************************************** | 147 | /****************************************************************************** |
151 | * DIF registers * | 148 | * DIF registers * |
152 | ******************************************************************************/ | 149 | ******************************************************************************/ |
153 | #define DIRECT_IF_REVB_BASE 0x00300 | 150 | #define DIRECT_IF_REVB_BASE 0x00300 |
154 | 151 | ||
155 | /*****************************************************************************/ | 152 | /*****************************************************************************/ |
156 | #define DIF_PLL_FREQ_WORD (DIRECT_IF_REVB_BASE + 0x00000000) /* Reg Size 32 */ | 153 | #define DIF_PLL_FREQ_WORD (DIRECT_IF_REVB_BASE + 0x00000000) /* Reg Size 32 */ |
157 | /*****************************************************************************/ | 154 | /*****************************************************************************/ |
158 | #define FLD_DIF_PLL_LOCK 0x80000000 | 155 | #define FLD_DIF_PLL_LOCK 0x80000000 |
159 | /* Reserved [30:29] */ | 156 | /* Reserved [30:29] */ |
@@ -161,7 +158,7 @@ typedef enum{ | |||
161 | #define FLD_DIF_PLL_FREQ 0x0FFFFFFF | 158 | #define FLD_DIF_PLL_FREQ 0x0FFFFFFF |
162 | 159 | ||
163 | /*****************************************************************************/ | 160 | /*****************************************************************************/ |
164 | #define DIF_PLL_CTRL (DIRECT_IF_REVB_BASE + 0x00000004) /* Reg Size 32 */ | 161 | #define DIF_PLL_CTRL (DIRECT_IF_REVB_BASE + 0x00000004) /* Reg Size 32 */ |
165 | /*****************************************************************************/ | 162 | /*****************************************************************************/ |
166 | #define FLD_DIF_KD_PD 0xFF000000 | 163 | #define FLD_DIF_KD_PD 0xFF000000 |
167 | /* Reserved [23:20] */ | 164 | /* Reserved [23:20] */ |
@@ -171,7 +168,7 @@ typedef enum{ | |||
171 | #define FLD_DIF_KIS_PD 0x0000000F | 168 | #define FLD_DIF_KIS_PD 0x0000000F |
172 | 169 | ||
173 | /*****************************************************************************/ | 170 | /*****************************************************************************/ |
174 | #define DIF_PLL_CTRL1 (DIRECT_IF_REVB_BASE + 0x00000008) /* Reg Size 32 */ | 171 | #define DIF_PLL_CTRL1 (DIRECT_IF_REVB_BASE + 0x00000008) /* Reg Size 32 */ |
175 | /*****************************************************************************/ | 172 | /*****************************************************************************/ |
176 | #define FLD_DIF_KD_FD 0xFF000000 | 173 | #define FLD_DIF_KD_FD 0xFF000000 |
177 | /* Reserved [23:20] */ | 174 | /* Reserved [23:20] */ |
@@ -181,7 +178,7 @@ typedef enum{ | |||
181 | #define FLD_DIF_KIS_FD 0x0000000F | 178 | #define FLD_DIF_KIS_FD 0x0000000F |
182 | 179 | ||
183 | /*****************************************************************************/ | 180 | /*****************************************************************************/ |
184 | #define DIF_PLL_CTRL2 (DIRECT_IF_REVB_BASE + 0x0000000C) /* Reg Size 32 */ | 181 | #define DIF_PLL_CTRL2 (DIRECT_IF_REVB_BASE + 0x0000000C) /* Reg Size 32 */ |
185 | /*****************************************************************************/ | 182 | /*****************************************************************************/ |
186 | #define FLD_DIF_PLL_AGC_REF 0xFFF00000 | 183 | #define FLD_DIF_PLL_AGC_REF 0xFFF00000 |
187 | #define FLD_DIF_PLL_AGC_KI 0x000F0000 | 184 | #define FLD_DIF_PLL_AGC_KI 0x000F0000 |
@@ -191,7 +188,7 @@ typedef enum{ | |||
191 | #define FLD_DIF_DOWNSMPL_FD 0x000000FF | 188 | #define FLD_DIF_DOWNSMPL_FD 0x000000FF |
192 | 189 | ||
193 | /*****************************************************************************/ | 190 | /*****************************************************************************/ |
194 | #define DIF_PLL_CTRL3 (DIRECT_IF_REVB_BASE + 0x00000010) /* Reg Size 32 */ | 191 | #define DIF_PLL_CTRL3 (DIRECT_IF_REVB_BASE + 0x00000010) /* Reg Size 32 */ |
195 | /*****************************************************************************/ | 192 | /*****************************************************************************/ |
196 | /* Reserved [31:16] */ | 193 | /* Reserved [31:16] */ |
197 | #define FLD_DIF_PLL_AGC_EN 0x00008000 | 194 | #define FLD_DIF_PLL_AGC_EN 0x00008000 |
@@ -199,7 +196,7 @@ typedef enum{ | |||
199 | #define FLD_DIF_PLL_MAN_GAIN 0x00000FFF | 196 | #define FLD_DIF_PLL_MAN_GAIN 0x00000FFF |
200 | 197 | ||
201 | /*****************************************************************************/ | 198 | /*****************************************************************************/ |
202 | #define DIF_AGC_IF_REF (DIRECT_IF_REVB_BASE + 0x00000014) /* Reg Size 32 */ | 199 | #define DIF_AGC_IF_REF (DIRECT_IF_REVB_BASE + 0x00000014) /* Reg Size 32 */ |
203 | /*****************************************************************************/ | 200 | /*****************************************************************************/ |
204 | #define FLD_DIF_K_AGC_RF 0xF0000000 | 201 | #define FLD_DIF_K_AGC_RF 0xF0000000 |
205 | #define FLD_DIF_K_AGC_IF 0x0F000000 | 202 | #define FLD_DIF_K_AGC_IF 0x0F000000 |
@@ -208,40 +205,40 @@ typedef enum{ | |||
208 | #define FLD_DIF_IF_REF 0x00000FFF | 205 | #define FLD_DIF_IF_REF 0x00000FFF |
209 | 206 | ||
210 | /*****************************************************************************/ | 207 | /*****************************************************************************/ |
211 | #define DIF_AGC_CTRL_IF (DIRECT_IF_REVB_BASE + 0x00000018) /* Reg Size 32 */ | 208 | #define DIF_AGC_CTRL_IF (DIRECT_IF_REVB_BASE + 0x00000018) /* Reg Size 32 */ |
212 | /*****************************************************************************/ | 209 | /*****************************************************************************/ |
213 | #define FLD_DIF_IF_MAX 0xFF000000 | 210 | #define FLD_DIF_IF_MAX 0xFF000000 |
214 | #define FLD_DIF_IF_MIN 0x00FF0000 | 211 | #define FLD_DIF_IF_MIN 0x00FF0000 |
215 | #define FLD_DIF_IF_AGC 0x0000FFFF | 212 | #define FLD_DIF_IF_AGC 0x0000FFFF |
216 | 213 | ||
217 | /*****************************************************************************/ | 214 | /*****************************************************************************/ |
218 | #define DIF_AGC_CTRL_INT (DIRECT_IF_REVB_BASE + 0x0000001C) /* Reg Size 32 */ | 215 | #define DIF_AGC_CTRL_INT (DIRECT_IF_REVB_BASE + 0x0000001C) /* Reg Size 32 */ |
219 | /*****************************************************************************/ | 216 | /*****************************************************************************/ |
220 | #define FLD_DIF_INT_MAX 0xFF000000 | 217 | #define FLD_DIF_INT_MAX 0xFF000000 |
221 | #define FLD_DIF_INT_MIN 0x00FF0000 | 218 | #define FLD_DIF_INT_MIN 0x00FF0000 |
222 | #define FLD_DIF_INT_AGC 0x0000FFFF | 219 | #define FLD_DIF_INT_AGC 0x0000FFFF |
223 | 220 | ||
224 | /*****************************************************************************/ | 221 | /*****************************************************************************/ |
225 | #define DIF_AGC_CTRL_RF (DIRECT_IF_REVB_BASE + 0x00000020) /* Reg Size 32 */ | 222 | #define DIF_AGC_CTRL_RF (DIRECT_IF_REVB_BASE + 0x00000020) /* Reg Size 32 */ |
226 | /*****************************************************************************/ | 223 | /*****************************************************************************/ |
227 | #define FLD_DIF_RF_MAX 0xFF000000 | 224 | #define FLD_DIF_RF_MAX 0xFF000000 |
228 | #define FLD_DIF_RF_MIN 0x00FF0000 | 225 | #define FLD_DIF_RF_MIN 0x00FF0000 |
229 | #define FLD_DIF_RF_AGC 0x0000FFFF | 226 | #define FLD_DIF_RF_AGC 0x0000FFFF |
230 | 227 | ||
231 | /*****************************************************************************/ | 228 | /*****************************************************************************/ |
232 | #define DIF_AGC_IF_INT_CURRENT (DIRECT_IF_REVB_BASE + 0x00000024) /* Reg Size 32 */ | 229 | #define DIF_AGC_IF_INT_CURRENT (DIRECT_IF_REVB_BASE + 0x00000024) /* Reg Size 32 */ |
233 | /*****************************************************************************/ | 230 | /*****************************************************************************/ |
234 | #define FLD_DIF_IF_AGC_IN 0xFFFF0000 | 231 | #define FLD_DIF_IF_AGC_IN 0xFFFF0000 |
235 | #define FLD_DIF_INT_AGC_IN 0x0000FFFF | 232 | #define FLD_DIF_INT_AGC_IN 0x0000FFFF |
236 | 233 | ||
237 | /*****************************************************************************/ | 234 | /*****************************************************************************/ |
238 | #define DIF_AGC_RF_CURRENT (DIRECT_IF_REVB_BASE + 0x00000028) /* Reg Size 32 */ | 235 | #define DIF_AGC_RF_CURRENT (DIRECT_IF_REVB_BASE + 0x00000028) /* Reg Size 32 */ |
239 | /*****************************************************************************/ | 236 | /*****************************************************************************/ |
240 | /* Reserved [31:16] */ | 237 | /* Reserved [31:16] */ |
241 | #define FLD_DIF_RF_AGC_IN 0x0000FFFF | 238 | #define FLD_DIF_RF_AGC_IN 0x0000FFFF |
242 | 239 | ||
243 | /*****************************************************************************/ | 240 | /*****************************************************************************/ |
244 | #define DIF_VIDEO_AGC_CTRL (DIRECT_IF_REVB_BASE + 0x0000002C) /* Reg Size 32 */ | 241 | #define DIF_VIDEO_AGC_CTRL (DIRECT_IF_REVB_BASE + 0x0000002C) /* Reg Size 32 */ |
245 | /*****************************************************************************/ | 242 | /*****************************************************************************/ |
246 | #define FLD_DIF_AFD 0xC0000000 | 243 | #define FLD_DIF_AFD 0xC0000000 |
247 | #define FLD_DIF_K_VID_AGC 0x30000000 | 244 | #define FLD_DIF_K_VID_AGC 0x30000000 |
@@ -249,7 +246,7 @@ typedef enum{ | |||
249 | #define FLD_DIF_AGC_GAIN 0x0000FFFF | 246 | #define FLD_DIF_AGC_GAIN 0x0000FFFF |
250 | 247 | ||
251 | /*****************************************************************************/ | 248 | /*****************************************************************************/ |
252 | #define DIF_VID_AUD_OVERRIDE (DIRECT_IF_REVB_BASE + 0x00000030) /* Reg Size 32 */ | 249 | #define DIF_VID_AUD_OVERRIDE (DIRECT_IF_REVB_BASE + 0x00000030) /* Reg Size 32 */ |
253 | /*****************************************************************************/ | 250 | /*****************************************************************************/ |
254 | #define FLD_DIF_AUDIO_AGC_OVERRIDE 0x80000000 | 251 | #define FLD_DIF_AUDIO_AGC_OVERRIDE 0x80000000 |
255 | /* Reserved [30:30] */ | 252 | /* Reserved [30:30] */ |
@@ -259,14 +256,14 @@ typedef enum{ | |||
259 | #define FLD_DIF_VID_MAN_GAIN 0x0000FFFF | 256 | #define FLD_DIF_VID_MAN_GAIN 0x0000FFFF |
260 | 257 | ||
261 | /*****************************************************************************/ | 258 | /*****************************************************************************/ |
262 | #define DIF_AV_SEP_CTRL (DIRECT_IF_REVB_BASE + 0x00000034) /* Reg Size 32 */ | 259 | #define DIF_AV_SEP_CTRL (DIRECT_IF_REVB_BASE + 0x00000034) /* Reg Size 32 */ |
263 | /*****************************************************************************/ | 260 | /*****************************************************************************/ |
264 | #define FLD_DIF_LPF_FREQ 0xC0000000 | 261 | #define FLD_DIF_LPF_FREQ 0xC0000000 |
265 | #define FLD_DIF_AV_PHASE_INC 0x3F000000 | 262 | #define FLD_DIF_AV_PHASE_INC 0x3F000000 |
266 | #define FLD_DIF_AUDIO_FREQ 0x00FFFFFF | 263 | #define FLD_DIF_AUDIO_FREQ 0x00FFFFFF |
267 | 264 | ||
268 | /*****************************************************************************/ | 265 | /*****************************************************************************/ |
269 | #define DIF_COMP_FLT_CTRL (DIRECT_IF_REVB_BASE + 0x00000038) /* Reg Size 32 */ | 266 | #define DIF_COMP_FLT_CTRL (DIRECT_IF_REVB_BASE + 0x00000038) /* Reg Size 32 */ |
270 | /*****************************************************************************/ | 267 | /*****************************************************************************/ |
271 | /* Reserved [31:24] */ | 268 | /* Reserved [31:24] */ |
272 | #define FLD_DIF_IIR23_R2 0x00FF0000 | 269 | #define FLD_DIF_IIR23_R2 0x00FF0000 |
@@ -274,7 +271,7 @@ typedef enum{ | |||
274 | #define FLD_DIF_IIR1_R1 0x000000FF | 271 | #define FLD_DIF_IIR1_R1 0x000000FF |
275 | 272 | ||
276 | /*****************************************************************************/ | 273 | /*****************************************************************************/ |
277 | #define DIF_MISC_CTRL (DIRECT_IF_REVB_BASE + 0x0000003C) /* Reg Size 32 */ | 274 | #define DIF_MISC_CTRL (DIRECT_IF_REVB_BASE + 0x0000003C) /* Reg Size 32 */ |
278 | /*****************************************************************************/ | 275 | /*****************************************************************************/ |
279 | #define FLD_DIF_DIF_BYPASS 0x80000000 | 276 | #define FLD_DIF_DIF_BYPASS 0x80000000 |
280 | #define FLD_DIF_FM_NYQ_GAIN 0x40000000 | 277 | #define FLD_DIF_FM_NYQ_GAIN 0x40000000 |
@@ -299,20 +296,20 @@ typedef enum{ | |||
299 | #define FLD_DIF_RF_IF_LOCK 0x00000001 | 296 | #define FLD_DIF_RF_IF_LOCK 0x00000001 |
300 | 297 | ||
301 | /*****************************************************************************/ | 298 | /*****************************************************************************/ |
302 | #define DIF_SRC_PHASE_INC (DIRECT_IF_REVB_BASE + 0x00000040) /* Reg Size 32 */ | 299 | #define DIF_SRC_PHASE_INC (DIRECT_IF_REVB_BASE + 0x00000040) /* Reg Size 32 */ |
303 | /*****************************************************************************/ | 300 | /*****************************************************************************/ |
304 | /* Reserved [31:29] */ | 301 | /* Reserved [31:29] */ |
305 | #define FLD_DIF_PHASE_INC 0x1FFFFFFF | 302 | #define FLD_DIF_PHASE_INC 0x1FFFFFFF |
306 | 303 | ||
307 | /*****************************************************************************/ | 304 | /*****************************************************************************/ |
308 | #define DIF_SRC_GAIN_CONTROL (DIRECT_IF_REVB_BASE + 0x00000044) /* Reg Size 32 */ | 305 | #define DIF_SRC_GAIN_CONTROL (DIRECT_IF_REVB_BASE + 0x00000044) /* Reg Size 32 */ |
309 | /*****************************************************************************/ | 306 | /*****************************************************************************/ |
310 | /* Reserved [31:16] */ | 307 | /* Reserved [31:16] */ |
311 | #define FLD_DIF_SRC_KI 0x0000FF00 | 308 | #define FLD_DIF_SRC_KI 0x0000FF00 |
312 | #define FLD_DIF_SRC_KD 0x000000FF | 309 | #define FLD_DIF_SRC_KD 0x000000FF |
313 | 310 | ||
314 | /*****************************************************************************/ | 311 | /*****************************************************************************/ |
315 | #define DIF_BPF_COEFF01 (DIRECT_IF_REVB_BASE + 0x00000048) /* Reg Size 32 */ | 312 | #define DIF_BPF_COEFF01 (DIRECT_IF_REVB_BASE + 0x00000048) /* Reg Size 32 */ |
316 | /*****************************************************************************/ | 313 | /*****************************************************************************/ |
317 | /* Reserved [31:19] */ | 314 | /* Reserved [31:19] */ |
318 | #define FLD_DIF_BPF_COEFF_0 0x00070000 | 315 | #define FLD_DIF_BPF_COEFF_0 0x00070000 |
@@ -320,7 +317,7 @@ typedef enum{ | |||
320 | #define FLD_DIF_BPF_COEFF_1 0x0000000F | 317 | #define FLD_DIF_BPF_COEFF_1 0x0000000F |
321 | 318 | ||
322 | /*****************************************************************************/ | 319 | /*****************************************************************************/ |
323 | #define DIF_BPF_COEFF23 (DIRECT_IF_REVB_BASE + 0x0000004c) /* Reg Size 32 */ | 320 | #define DIF_BPF_COEFF23 (DIRECT_IF_REVB_BASE + 0x0000004c) /* Reg Size 32 */ |
324 | /*****************************************************************************/ | 321 | /*****************************************************************************/ |
325 | /* Reserved [31:22] */ | 322 | /* Reserved [31:22] */ |
326 | #define FLD_DIF_BPF_COEFF_2 0x003F0000 | 323 | #define FLD_DIF_BPF_COEFF_2 0x003F0000 |
@@ -328,7 +325,7 @@ typedef enum{ | |||
328 | #define FLD_DIF_BPF_COEFF_3 0x0000007F | 325 | #define FLD_DIF_BPF_COEFF_3 0x0000007F |
329 | 326 | ||
330 | /*****************************************************************************/ | 327 | /*****************************************************************************/ |
331 | #define DIF_BPF_COEFF45 (DIRECT_IF_REVB_BASE + 0x00000050) /* Reg Size 32 */ | 328 | #define DIF_BPF_COEFF45 (DIRECT_IF_REVB_BASE + 0x00000050) /* Reg Size 32 */ |
332 | /*****************************************************************************/ | 329 | /*****************************************************************************/ |
333 | /* Reserved [31:24] */ | 330 | /* Reserved [31:24] */ |
334 | #define FLD_DIF_BPF_COEFF_4 0x00FF0000 | 331 | #define FLD_DIF_BPF_COEFF_4 0x00FF0000 |
@@ -336,7 +333,7 @@ typedef enum{ | |||
336 | #define FLD_DIF_BPF_COEFF_5 0x000000FF | 333 | #define FLD_DIF_BPF_COEFF_5 0x000000FF |
337 | 334 | ||
338 | /*****************************************************************************/ | 335 | /*****************************************************************************/ |
339 | #define DIF_BPF_COEFF67 (DIRECT_IF_REVB_BASE + 0x00000054) /* Reg Size 32 */ | 336 | #define DIF_BPF_COEFF67 (DIRECT_IF_REVB_BASE + 0x00000054) /* Reg Size 32 */ |
340 | /*****************************************************************************/ | 337 | /*****************************************************************************/ |
341 | /* Reserved [31:25] */ | 338 | /* Reserved [31:25] */ |
342 | #define FLD_DIF_BPF_COEFF_6 0x01FF0000 | 339 | #define FLD_DIF_BPF_COEFF_6 0x01FF0000 |
@@ -344,7 +341,7 @@ typedef enum{ | |||
344 | #define FLD_DIF_BPF_COEFF_7 0x000001FF | 341 | #define FLD_DIF_BPF_COEFF_7 0x000001FF |
345 | 342 | ||
346 | /*****************************************************************************/ | 343 | /*****************************************************************************/ |
347 | #define DIF_BPF_COEFF89 (DIRECT_IF_REVB_BASE + 0x00000058) /* Reg Size 32 */ | 344 | #define DIF_BPF_COEFF89 (DIRECT_IF_REVB_BASE + 0x00000058) /* Reg Size 32 */ |
348 | /*****************************************************************************/ | 345 | /*****************************************************************************/ |
349 | /* Reserved [31:26] */ | 346 | /* Reserved [31:26] */ |
350 | #define FLD_DIF_BPF_COEFF_8 0x03FF0000 | 347 | #define FLD_DIF_BPF_COEFF_8 0x03FF0000 |
@@ -352,7 +349,7 @@ typedef enum{ | |||
352 | #define FLD_DIF_BPF_COEFF_9 0x000003FF | 349 | #define FLD_DIF_BPF_COEFF_9 0x000003FF |
353 | 350 | ||
354 | /*****************************************************************************/ | 351 | /*****************************************************************************/ |
355 | #define DIF_BPF_COEFF1011 (DIRECT_IF_REVB_BASE + 0x0000005C) /* Reg Size 32 */ | 352 | #define DIF_BPF_COEFF1011 (DIRECT_IF_REVB_BASE + 0x0000005C) /* Reg Size 32 */ |
356 | /*****************************************************************************/ | 353 | /*****************************************************************************/ |
357 | /* Reserved [31:27] */ | 354 | /* Reserved [31:27] */ |
358 | #define FLD_DIF_BPF_COEFF_10 0x07FF0000 | 355 | #define FLD_DIF_BPF_COEFF_10 0x07FF0000 |
@@ -360,7 +357,7 @@ typedef enum{ | |||
360 | #define FLD_DIF_BPF_COEFF_11 0x000007FF | 357 | #define FLD_DIF_BPF_COEFF_11 0x000007FF |
361 | 358 | ||
362 | /*****************************************************************************/ | 359 | /*****************************************************************************/ |
363 | #define DIF_BPF_COEFF1213 (DIRECT_IF_REVB_BASE + 0x00000060) /* Reg Size 32 */ | 360 | #define DIF_BPF_COEFF1213 (DIRECT_IF_REVB_BASE + 0x00000060) /* Reg Size 32 */ |
364 | /*****************************************************************************/ | 361 | /*****************************************************************************/ |
365 | /* Reserved [31:27] */ | 362 | /* Reserved [31:27] */ |
366 | #define FLD_DIF_BPF_COEFF_12 0x07FF0000 | 363 | #define FLD_DIF_BPF_COEFF_12 0x07FF0000 |
@@ -368,7 +365,7 @@ typedef enum{ | |||
368 | #define FLD_DIF_BPF_COEFF_13 0x00000FFF | 365 | #define FLD_DIF_BPF_COEFF_13 0x00000FFF |
369 | 366 | ||
370 | /*****************************************************************************/ | 367 | /*****************************************************************************/ |
371 | #define DIF_BPF_COEFF1415 (DIRECT_IF_REVB_BASE + 0x00000064) /* Reg Size 32 */ | 368 | #define DIF_BPF_COEFF1415 (DIRECT_IF_REVB_BASE + 0x00000064) /* Reg Size 32 */ |
372 | /*****************************************************************************/ | 369 | /*****************************************************************************/ |
373 | /* Reserved [31:28] */ | 370 | /* Reserved [31:28] */ |
374 | #define FLD_DIF_BPF_COEFF_14 0x0FFF0000 | 371 | #define FLD_DIF_BPF_COEFF_14 0x0FFF0000 |
@@ -376,7 +373,7 @@ typedef enum{ | |||
376 | #define FLD_DIF_BPF_COEFF_15 0x00000FFF | 373 | #define FLD_DIF_BPF_COEFF_15 0x00000FFF |
377 | 374 | ||
378 | /*****************************************************************************/ | 375 | /*****************************************************************************/ |
379 | #define DIF_BPF_COEFF1617 (DIRECT_IF_REVB_BASE + 0x00000068) /* Reg Size 32 */ | 376 | #define DIF_BPF_COEFF1617 (DIRECT_IF_REVB_BASE + 0x00000068) /* Reg Size 32 */ |
380 | /*****************************************************************************/ | 377 | /*****************************************************************************/ |
381 | /* Reserved [31:29] */ | 378 | /* Reserved [31:29] */ |
382 | #define FLD_DIF_BPF_COEFF_16 0x1FFF0000 | 379 | #define FLD_DIF_BPF_COEFF_16 0x1FFF0000 |
@@ -384,7 +381,7 @@ typedef enum{ | |||
384 | #define FLD_DIF_BPF_COEFF_17 0x00001FFF | 381 | #define FLD_DIF_BPF_COEFF_17 0x00001FFF |
385 | 382 | ||
386 | /*****************************************************************************/ | 383 | /*****************************************************************************/ |
387 | #define DIF_BPF_COEFF1819 (DIRECT_IF_REVB_BASE + 0x0000006C) /* Reg Size 32 */ | 384 | #define DIF_BPF_COEFF1819 (DIRECT_IF_REVB_BASE + 0x0000006C) /* Reg Size 32 */ |
388 | /*****************************************************************************/ | 385 | /*****************************************************************************/ |
389 | /* Reserved [31:29] */ | 386 | /* Reserved [31:29] */ |
390 | #define FLD_DIF_BPF_COEFF_18 0x1FFF0000 | 387 | #define FLD_DIF_BPF_COEFF_18 0x1FFF0000 |
@@ -392,7 +389,7 @@ typedef enum{ | |||
392 | #define FLD_DIF_BPF_COEFF_19 0x00001FFF | 389 | #define FLD_DIF_BPF_COEFF_19 0x00001FFF |
393 | 390 | ||
394 | /*****************************************************************************/ | 391 | /*****************************************************************************/ |
395 | #define DIF_BPF_COEFF2021 (DIRECT_IF_REVB_BASE + 0x00000070) /* Reg Size 32 */ | 392 | #define DIF_BPF_COEFF2021 (DIRECT_IF_REVB_BASE + 0x00000070) /* Reg Size 32 */ |
396 | /*****************************************************************************/ | 393 | /*****************************************************************************/ |
397 | /* Reserved [31:29] */ | 394 | /* Reserved [31:29] */ |
398 | #define FLD_DIF_BPF_COEFF_20 0x1FFF0000 | 395 | #define FLD_DIF_BPF_COEFF_20 0x1FFF0000 |
@@ -400,7 +397,7 @@ typedef enum{ | |||
400 | #define FLD_DIF_BPF_COEFF_21 0x00003FFF | 397 | #define FLD_DIF_BPF_COEFF_21 0x00003FFF |
401 | 398 | ||
402 | /*****************************************************************************/ | 399 | /*****************************************************************************/ |
403 | #define DIF_BPF_COEFF2223 (DIRECT_IF_REVB_BASE + 0x00000074) /* Reg Size 32 */ | 400 | #define DIF_BPF_COEFF2223 (DIRECT_IF_REVB_BASE + 0x00000074) /* Reg Size 32 */ |
404 | /*****************************************************************************/ | 401 | /*****************************************************************************/ |
405 | /* Reserved [31:30] */ | 402 | /* Reserved [31:30] */ |
406 | #define FLD_DIF_BPF_COEFF_22 0x3FFF0000 | 403 | #define FLD_DIF_BPF_COEFF_22 0x3FFF0000 |
@@ -408,7 +405,7 @@ typedef enum{ | |||
408 | #define FLD_DIF_BPF_COEFF_23 0x00003FFF | 405 | #define FLD_DIF_BPF_COEFF_23 0x00003FFF |
409 | 406 | ||
410 | /*****************************************************************************/ | 407 | /*****************************************************************************/ |
411 | #define DIF_BPF_COEFF2425 (DIRECT_IF_REVB_BASE + 0x00000078) /* Reg Size 32 */ | 408 | #define DIF_BPF_COEFF2425 (DIRECT_IF_REVB_BASE + 0x00000078) /* Reg Size 32 */ |
412 | /*****************************************************************************/ | 409 | /*****************************************************************************/ |
413 | /* Reserved [31:30] */ | 410 | /* Reserved [31:30] */ |
414 | #define FLD_DIF_BPF_COEFF_24 0x3FFF0000 | 411 | #define FLD_DIF_BPF_COEFF_24 0x3FFF0000 |
@@ -416,7 +413,7 @@ typedef enum{ | |||
416 | #define FLD_DIF_BPF_COEFF_25 0x00003FFF | 413 | #define FLD_DIF_BPF_COEFF_25 0x00003FFF |
417 | 414 | ||
418 | /*****************************************************************************/ | 415 | /*****************************************************************************/ |
419 | #define DIF_BPF_COEFF2627 (DIRECT_IF_REVB_BASE + 0x0000007C) /* Reg Size 32 */ | 416 | #define DIF_BPF_COEFF2627 (DIRECT_IF_REVB_BASE + 0x0000007C) /* Reg Size 32 */ |
420 | /*****************************************************************************/ | 417 | /*****************************************************************************/ |
421 | /* Reserved [31:30] */ | 418 | /* Reserved [31:30] */ |
422 | #define FLD_DIF_BPF_COEFF_26 0x3FFF0000 | 419 | #define FLD_DIF_BPF_COEFF_26 0x3FFF0000 |
@@ -424,7 +421,7 @@ typedef enum{ | |||
424 | #define FLD_DIF_BPF_COEFF_27 0x00003FFF | 421 | #define FLD_DIF_BPF_COEFF_27 0x00003FFF |
425 | 422 | ||
426 | /*****************************************************************************/ | 423 | /*****************************************************************************/ |
427 | #define DIF_BPF_COEFF2829 (DIRECT_IF_REVB_BASE + 0x00000080) /* Reg Size 32 */ | 424 | #define DIF_BPF_COEFF2829 (DIRECT_IF_REVB_BASE + 0x00000080) /* Reg Size 32 */ |
428 | /*****************************************************************************/ | 425 | /*****************************************************************************/ |
429 | /* Reserved [31:30] */ | 426 | /* Reserved [31:30] */ |
430 | #define FLD_DIF_BPF_COEFF_28 0x3FFF0000 | 427 | #define FLD_DIF_BPF_COEFF_28 0x3FFF0000 |
@@ -432,7 +429,7 @@ typedef enum{ | |||
432 | #define FLD_DIF_BPF_COEFF_29 0x00003FFF | 429 | #define FLD_DIF_BPF_COEFF_29 0x00003FFF |
433 | 430 | ||
434 | /*****************************************************************************/ | 431 | /*****************************************************************************/ |
435 | #define DIF_BPF_COEFF3031 (DIRECT_IF_REVB_BASE + 0x00000084) /* Reg Size 32 */ | 432 | #define DIF_BPF_COEFF3031 (DIRECT_IF_REVB_BASE + 0x00000084) /* Reg Size 32 */ |
436 | /*****************************************************************************/ | 433 | /*****************************************************************************/ |
437 | /* Reserved [31:30] */ | 434 | /* Reserved [31:30] */ |
438 | #define FLD_DIF_BPF_COEFF_30 0x3FFF0000 | 435 | #define FLD_DIF_BPF_COEFF_30 0x3FFF0000 |
@@ -440,7 +437,7 @@ typedef enum{ | |||
440 | #define FLD_DIF_BPF_COEFF_31 0x00003FFF | 437 | #define FLD_DIF_BPF_COEFF_31 0x00003FFF |
441 | 438 | ||
442 | /*****************************************************************************/ | 439 | /*****************************************************************************/ |
443 | #define DIF_BPF_COEFF3233 (DIRECT_IF_REVB_BASE + 0x00000088) /* Reg Size 32 */ | 440 | #define DIF_BPF_COEFF3233 (DIRECT_IF_REVB_BASE + 0x00000088) /* Reg Size 32 */ |
444 | /*****************************************************************************/ | 441 | /*****************************************************************************/ |
445 | /* Reserved [31:30] */ | 442 | /* Reserved [31:30] */ |
446 | #define FLD_DIF_BPF_COEFF_32 0x3FFF0000 | 443 | #define FLD_DIF_BPF_COEFF_32 0x3FFF0000 |
@@ -448,7 +445,7 @@ typedef enum{ | |||
448 | #define FLD_DIF_BPF_COEFF_33 0x00003FFF | 445 | #define FLD_DIF_BPF_COEFF_33 0x00003FFF |
449 | 446 | ||
450 | /*****************************************************************************/ | 447 | /*****************************************************************************/ |
451 | #define DIF_BPF_COEFF3435 (DIRECT_IF_REVB_BASE + 0x0000008C) /* Reg Size 32 */ | 448 | #define DIF_BPF_COEFF3435 (DIRECT_IF_REVB_BASE + 0x0000008C) /* Reg Size 32 */ |
452 | /*****************************************************************************/ | 449 | /*****************************************************************************/ |
453 | /* Reserved [31:30] */ | 450 | /* Reserved [31:30] */ |
454 | #define FLD_DIF_BPF_COEFF_34 0x3FFF0000 | 451 | #define FLD_DIF_BPF_COEFF_34 0x3FFF0000 |
@@ -456,20 +453,20 @@ typedef enum{ | |||
456 | #define FLD_DIF_BPF_COEFF_35 0x00003FFF | 453 | #define FLD_DIF_BPF_COEFF_35 0x00003FFF |
457 | 454 | ||
458 | /*****************************************************************************/ | 455 | /*****************************************************************************/ |
459 | #define DIF_BPF_COEFF36 (DIRECT_IF_REVB_BASE + 0x00000090) /* Reg Size 32 */ | 456 | #define DIF_BPF_COEFF36 (DIRECT_IF_REVB_BASE + 0x00000090) /* Reg Size 32 */ |
460 | /*****************************************************************************/ | 457 | /*****************************************************************************/ |
461 | /* Reserved [31:30] */ | 458 | /* Reserved [31:30] */ |
462 | #define FLD_DIF_BPF_COEFF_36 0x3FFF0000 | 459 | #define FLD_DIF_BPF_COEFF_36 0x3FFF0000 |
463 | /* Reserved [15:0] */ | 460 | /* Reserved [15:0] */ |
464 | 461 | ||
465 | /*****************************************************************************/ | 462 | /*****************************************************************************/ |
466 | #define DIF_RPT_VARIANCE (DIRECT_IF_REVB_BASE + 0x00000094) /* Reg Size 32 */ | 463 | #define DIF_RPT_VARIANCE (DIRECT_IF_REVB_BASE + 0x00000094) /* Reg Size 32 */ |
467 | /*****************************************************************************/ | 464 | /*****************************************************************************/ |
468 | /* Reserved [31:20] */ | 465 | /* Reserved [31:20] */ |
469 | #define FLD_DIF_RPT_VARIANCE 0x000FFFFF | 466 | #define FLD_DIF_RPT_VARIANCE 0x000FFFFF |
470 | 467 | ||
471 | /*****************************************************************************/ | 468 | /*****************************************************************************/ |
472 | #define DIF_SOFT_RST_CTRL_REVB (DIRECT_IF_REVB_BASE + 0x00000098) /* Reg Size 32 */ | 469 | #define DIF_SOFT_RST_CTRL_REVB (DIRECT_IF_REVB_BASE + 0x00000098) /* Reg Size 32 */ |
473 | /*****************************************************************************/ | 470 | /*****************************************************************************/ |
474 | /* Reserved [31:8] */ | 471 | /* Reserved [31:8] */ |
475 | #define FLD_DIF_DIF_SOFT_RST 0x00000080 | 472 | #define FLD_DIF_DIF_SOFT_RST 0x00000080 |
@@ -482,10 +479,9 @@ typedef enum{ | |||
482 | #define FLD_DIF_PLL_RST_MSK 0x00000001 | 479 | #define FLD_DIF_PLL_RST_MSK 0x00000001 |
483 | 480 | ||
484 | /*****************************************************************************/ | 481 | /*****************************************************************************/ |
485 | #define DIF_PLL_FREQ_ERR (DIRECT_IF_REVB_BASE + 0x0000009C) /* Reg Size 32 */ | 482 | #define DIF_PLL_FREQ_ERR (DIRECT_IF_REVB_BASE + 0x0000009C) /* Reg Size 32 */ |
486 | /*****************************************************************************/ | 483 | /*****************************************************************************/ |
487 | /* Reserved [31:25] */ | 484 | /* Reserved [31:25] */ |
488 | #define FLD_DIF_CTL_IP 0x01FFFFFF | 485 | #define FLD_DIF_CTL_IP 0x01FFFFFF |
489 | 486 | ||
490 | |||
491 | #endif | 487 | #endif |
diff --git a/drivers/media/video/cx231xx/cx231xx-core.c b/drivers/media/video/cx231xx/cx231xx-core.c index efe0c666043a..874fc5b39863 100644 --- a/drivers/media/video/cx231xx/cx231xx-core.c +++ b/drivers/media/video/cx231xx/cx231xx-core.c | |||
@@ -2,7 +2,7 @@ | |||
2 | cx231xx-core.c - driver for Conexant Cx23100/101/102 USB video capture devices | 2 | cx231xx-core.c - driver for Conexant Cx23100/101/102 USB video capture devices |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on em28xx driver | 5 | Based on em28xx driver |
6 | 6 | ||
7 | This program is free software; you can redistribute it and/or modify | 7 | This program is free software; you can redistribute it and/or modify |
8 | it under the terms of the GNU General Public License as published by | 8 | it under the terms of the GNU General Public License as published by |
@@ -32,8 +32,8 @@ | |||
32 | /* #define ENABLE_DEBUG_ISOC_FRAMES */ | 32 | /* #define ENABLE_DEBUG_ISOC_FRAMES */ |
33 | 33 | ||
34 | static unsigned int core_debug; | 34 | static unsigned int core_debug; |
35 | module_param(core_debug,int,0644); | 35 | module_param(core_debug, int, 0644); |
36 | MODULE_PARM_DESC(core_debug,"enable debug messages [core]"); | 36 | MODULE_PARM_DESC(core_debug, "enable debug messages [core]"); |
37 | 37 | ||
38 | #define cx231xx_coredbg(fmt, arg...) do {\ | 38 | #define cx231xx_coredbg(fmt, arg...) do {\ |
39 | if (core_debug) \ | 39 | if (core_debug) \ |
@@ -41,8 +41,8 @@ MODULE_PARM_DESC(core_debug,"enable debug messages [core]"); | |||
41 | dev->name, __func__ , ##arg); } while (0) | 41 | dev->name, __func__ , ##arg); } while (0) |
42 | 42 | ||
43 | static unsigned int reg_debug; | 43 | static unsigned int reg_debug; |
44 | module_param(reg_debug,int,0644); | 44 | module_param(reg_debug, int, 0644); |
45 | MODULE_PARM_DESC(reg_debug,"enable debug messages [URB reg]"); | 45 | MODULE_PARM_DESC(reg_debug, "enable debug messages [URB reg]"); |
46 | 46 | ||
47 | #define cx231xx_regdbg(fmt, arg...) do {\ | 47 | #define cx231xx_regdbg(fmt, arg...) do {\ |
48 | if (reg_debug) \ | 48 | if (reg_debug) \ |
@@ -59,8 +59,6 @@ MODULE_PARM_DESC(alt, "alternate setting to use for video endpoint"); | |||
59 | printk(KERN_INFO "%s %s :"fmt, \ | 59 | printk(KERN_INFO "%s %s :"fmt, \ |
60 | dev->name, __func__ , ##arg); } while (0) | 60 | dev->name, __func__ , ##arg); } while (0) |
61 | 61 | ||
62 | |||
63 | |||
64 | /************************************************************************************ | 62 | /************************************************************************************ |
65 | * Device control list functions * | 63 | * Device control list functions * |
66 | *************************************************************************************/ | 64 | *************************************************************************************/ |
@@ -69,8 +67,7 @@ static LIST_HEAD(cx231xx_devlist); | |||
69 | static DEFINE_MUTEX(cx231xx_devlist_mutex); | 67 | static DEFINE_MUTEX(cx231xx_devlist_mutex); |
70 | 68 | ||
71 | struct cx231xx *cx231xx_get_device(int minor, | 69 | struct cx231xx *cx231xx_get_device(int minor, |
72 | enum v4l2_buf_type *fh_type, | 70 | enum v4l2_buf_type *fh_type, int *has_radio) |
73 | int *has_radio) | ||
74 | { | 71 | { |
75 | struct cx231xx *h, *dev = NULL; | 72 | struct cx231xx *h, *dev = NULL; |
76 | 73 | ||
@@ -85,8 +82,7 @@ struct cx231xx *cx231xx_get_device(int minor, | |||
85 | dev = h; | 82 | dev = h; |
86 | *fh_type = V4L2_BUF_TYPE_VBI_CAPTURE; | 83 | *fh_type = V4L2_BUF_TYPE_VBI_CAPTURE; |
87 | } | 84 | } |
88 | if (h->radio_dev && | 85 | if (h->radio_dev && h->radio_dev->minor == minor) { |
89 | h->radio_dev->minor == minor) { | ||
90 | dev = h; | 86 | dev = h; |
91 | *has_radio = 1; | 87 | *has_radio = 1; |
92 | } | 88 | } |
@@ -115,9 +111,6 @@ void cx231xx_add_into_devlist(struct cx231xx *dev) | |||
115 | mutex_unlock(&cx231xx_devlist_mutex); | 111 | mutex_unlock(&cx231xx_devlist_mutex); |
116 | }; | 112 | }; |
117 | 113 | ||
118 | |||
119 | |||
120 | |||
121 | static LIST_HEAD(cx231xx_extension_devlist); | 114 | static LIST_HEAD(cx231xx_extension_devlist); |
122 | static DEFINE_MUTEX(cx231xx_extension_devlist_lock); | 115 | static DEFINE_MUTEX(cx231xx_extension_devlist_lock); |
123 | 116 | ||
@@ -137,6 +130,7 @@ int cx231xx_register_extension(struct cx231xx_ops *ops) | |||
137 | mutex_unlock(&cx231xx_devlist_mutex); | 130 | mutex_unlock(&cx231xx_devlist_mutex); |
138 | return 0; | 131 | return 0; |
139 | } | 132 | } |
133 | |||
140 | EXPORT_SYMBOL(cx231xx_register_extension); | 134 | EXPORT_SYMBOL(cx231xx_register_extension); |
141 | 135 | ||
142 | void cx231xx_unregister_extension(struct cx231xx_ops *ops) | 136 | void cx231xx_unregister_extension(struct cx231xx_ops *ops) |
@@ -155,8 +149,8 @@ void cx231xx_unregister_extension(struct cx231xx_ops *ops) | |||
155 | mutex_unlock(&cx231xx_extension_devlist_lock); | 149 | mutex_unlock(&cx231xx_extension_devlist_lock); |
156 | mutex_unlock(&cx231xx_devlist_mutex); | 150 | mutex_unlock(&cx231xx_devlist_mutex); |
157 | } | 151 | } |
158 | EXPORT_SYMBOL(cx231xx_unregister_extension); | ||
159 | 152 | ||
153 | EXPORT_SYMBOL(cx231xx_unregister_extension); | ||
160 | 154 | ||
161 | void cx231xx_init_extension(struct cx231xx *dev) | 155 | void cx231xx_init_extension(struct cx231xx *dev) |
162 | { | 156 | { |
@@ -190,78 +184,82 @@ void cx231xx_close_extension(struct cx231xx *dev) | |||
190 | * U S B related functions * | 184 | * U S B related functions * |
191 | *************************************************************************************/ | 185 | *************************************************************************************/ |
192 | int cx231xx_send_usb_command(struct cx231xx_i2c *i2c_bus, | 186 | int cx231xx_send_usb_command(struct cx231xx_i2c *i2c_bus, |
193 | struct cx231xx_i2c_xfer_data *req_data) | 187 | struct cx231xx_i2c_xfer_data *req_data) |
194 | { | 188 | { |
195 | int status = 0; | 189 | int status = 0; |
196 | struct cx231xx *dev = i2c_bus->dev; | 190 | struct cx231xx *dev = i2c_bus->dev; |
197 | VENDOR_REQUEST_IN ven_req; | 191 | VENDOR_REQUEST_IN ven_req; |
198 | 192 | ||
199 | u8 saddr_len = 0; | 193 | u8 saddr_len = 0; |
200 | u8 _i2c_period = 0; | 194 | u8 _i2c_period = 0; |
201 | u8 _i2c_nostop = 0; | 195 | u8 _i2c_nostop = 0; |
202 | u8 _i2c_reserve = 0; | 196 | u8 _i2c_reserve = 0; |
203 | 197 | ||
204 | /* Get the I2C period, nostop and reserve parameters */ | 198 | /* Get the I2C period, nostop and reserve parameters */ |
205 | _i2c_period = i2c_bus->i2c_period; | 199 | _i2c_period = i2c_bus->i2c_period; |
206 | _i2c_nostop = i2c_bus->i2c_nostop; | 200 | _i2c_nostop = i2c_bus->i2c_nostop; |
207 | _i2c_reserve = i2c_bus->i2c_reserve; | 201 | _i2c_reserve = i2c_bus->i2c_reserve; |
208 | 202 | ||
209 | saddr_len = req_data->saddr_len; | 203 | saddr_len = req_data->saddr_len; |
210 | 204 | ||
211 | /* Set wValue */ | 205 | /* Set wValue */ |
212 | if(saddr_len == 1) /* need check saddr_len == 0 */ | 206 | if (saddr_len == 1) /* need check saddr_len == 0 */ |
213 | ven_req.wValue = req_data->dev_addr<<9|_i2c_period<<4|saddr_len<<2| | 207 | ven_req.wValue = |
214 | _i2c_nostop<<1|I2C_SYNC|_i2c_reserve<<6; | 208 | req_data-> |
215 | else | 209 | dev_addr << 9 | _i2c_period << 4 | saddr_len << 2 | |
216 | ven_req.wValue = req_data->dev_addr<<9|_i2c_period<<4|saddr_len<<2| | 210 | _i2c_nostop << 1 | I2C_SYNC | _i2c_reserve << 6; |
217 | _i2c_nostop<<1|I2C_SYNC|_i2c_reserve<<6; | 211 | else |
218 | 212 | ven_req.wValue = | |
219 | /* set channel number */ | 213 | req_data-> |
220 | if(req_data->direction & I2C_M_RD) | 214 | dev_addr << 9 | _i2c_period << 4 | saddr_len << 2 | |
221 | ven_req.bRequest = i2c_bus->nr + 4; /* channel number, for read, | 215 | _i2c_nostop << 1 | I2C_SYNC | _i2c_reserve << 6; |
222 | spec required channel_num +4 */ | 216 | |
223 | else | 217 | /* set channel number */ |
224 | ven_req.bRequest = i2c_bus->nr; /* channel number, */ | 218 | if (req_data->direction & I2C_M_RD) |
225 | 219 | ven_req.bRequest = i2c_bus->nr + 4; /* channel number, for read, | |
226 | /* set index value */ | 220 | spec required channel_num +4 */ |
227 | switch(saddr_len){ | 221 | else |
228 | case 0: | 222 | ven_req.bRequest = i2c_bus->nr; /* channel number, */ |
229 | ven_req.wIndex = 0; /* need check */ | 223 | |
230 | break; | 224 | /* set index value */ |
231 | case 1: | 225 | switch (saddr_len) { |
232 | ven_req.wIndex = (req_data->saddr_dat & 0xff); | 226 | case 0: |
233 | break; | 227 | ven_req.wIndex = 0; /* need check */ |
234 | case 2: | 228 | break; |
235 | ven_req.wIndex = req_data->saddr_dat; | 229 | case 1: |
236 | break; | 230 | ven_req.wIndex = (req_data->saddr_dat & 0xff); |
237 | } | 231 | break; |
238 | 232 | case 2: | |
239 | /* set wLength value */ | 233 | ven_req.wIndex = req_data->saddr_dat; |
240 | ven_req.wLength = req_data->buf_size; | 234 | break; |
241 | 235 | } | |
242 | /* set bData value */ | 236 | |
243 | ven_req.bData = 0; | 237 | /* set wLength value */ |
244 | 238 | ven_req.wLength = req_data->buf_size; | |
245 | /* set the direction */ | 239 | |
246 | if(req_data->direction){ | 240 | /* set bData value */ |
247 | ven_req.direction = USB_DIR_IN; | 241 | ven_req.bData = 0; |
248 | memset(req_data->p_buffer, 0x00, ven_req.wLength); | 242 | |
249 | } | 243 | /* set the direction */ |
250 | else | 244 | if (req_data->direction) { |
251 | ven_req.direction = USB_DIR_OUT; | 245 | ven_req.direction = USB_DIR_IN; |
252 | 246 | memset(req_data->p_buffer, 0x00, ven_req.wLength); | |
253 | /* set the buffer for read / write */ | 247 | } else |
254 | ven_req.pBuff = req_data->p_buffer; | 248 | ven_req.direction = USB_DIR_OUT; |
255 | 249 | ||
256 | 250 | /* set the buffer for read / write */ | |
257 | 251 | ven_req.pBuff = req_data->p_buffer; | |
258 | /* call common vendor command request */ | 252 | |
259 | status = cx231xx_send_vendor_cmd(dev, &ven_req); | 253 | |
260 | if (status < 0) { | 254 | /* call common vendor command request */ |
261 | cx231xx_info("UsbInterface::sendCommand, output buffer failed with status -%d\n", status); | 255 | status = cx231xx_send_vendor_cmd(dev, &ven_req); |
262 | } | 256 | if (status < 0) { |
263 | 257 | cx231xx_info | |
264 | return status; | 258 | ("UsbInterface::sendCommand, output buffer failed with status -%d\n", |
259 | status); | ||
260 | } | ||
261 | |||
262 | return status; | ||
265 | } | 263 | } |
266 | 264 | ||
267 | EXPORT_SYMBOL_GPL(cx231xx_send_usb_command); | 265 | EXPORT_SYMBOL_GPL(cx231xx_send_usb_command); |
@@ -270,9 +268,9 @@ EXPORT_SYMBOL_GPL(cx231xx_send_usb_command); | |||
270 | * reads data from the usb device specifying bRequest and wValue | 268 | * reads data from the usb device specifying bRequest and wValue |
271 | */ | 269 | */ |
272 | int cx231xx_read_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, | 270 | int cx231xx_read_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, |
273 | char *buf, int len) | 271 | char *buf, int len) |
274 | { | 272 | { |
275 | u8 val = 0; | 273 | u8 val = 0; |
276 | int ret; | 274 | int ret; |
277 | int pipe = usb_rcvctrlpipe(dev->udev, 0); | 275 | int pipe = usb_rcvctrlpipe(dev->udev, 0); |
278 | 276 | ||
@@ -282,35 +280,33 @@ int cx231xx_read_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, | |||
282 | if (len > URB_MAX_CTRL_SIZE) | 280 | if (len > URB_MAX_CTRL_SIZE) |
283 | return -EINVAL; | 281 | return -EINVAL; |
284 | 282 | ||
285 | switch(len) | 283 | switch (len) { |
286 | { | 284 | case 1: |
287 | case 1: | 285 | val = ENABLE_ONE_BYTE; |
288 | val = ENABLE_ONE_BYTE; | 286 | break; |
289 | break; | 287 | case 2: |
290 | case 2: | 288 | val = ENABLE_TWE_BYTE; |
291 | val = ENABLE_TWE_BYTE; | 289 | break; |
292 | break; | 290 | case 3: |
293 | case 3: | 291 | val = ENABLE_THREE_BYTE; |
294 | val = ENABLE_THREE_BYTE; | 292 | break; |
295 | break; | 293 | case 4: |
296 | case 4: | 294 | val = ENABLE_FOUR_BYTE; |
297 | val = ENABLE_FOUR_BYTE; | 295 | break; |
298 | break; | 296 | default: |
299 | default: | 297 | val = 0xFF; /* invalid option */ |
300 | val = 0xFF; /* invalid option */ | 298 | } |
301 | } | 299 | |
302 | 300 | if (val == 0xFF) | |
303 | if(val == 0xFF) | 301 | return -EINVAL; |
304 | return -EINVAL; | ||
305 | 302 | ||
306 | if (reg_debug) { | 303 | if (reg_debug) { |
307 | cx231xx_isocdbg("(pipe 0x%08x): " | 304 | cx231xx_isocdbg("(pipe 0x%08x): " |
308 | "IN: %02x %02x %02x %02x %02x %02x %02x %02x ", | 305 | "IN: %02x %02x %02x %02x %02x %02x %02x %02x ", |
309 | pipe, | 306 | pipe, |
310 | USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE, | 307 | USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE, |
311 | req, 0, val, | 308 | req, 0, val, |
312 | reg & 0xff, reg >> 8, | 309 | reg & 0xff, reg >> 8, len & 0xff, len >> 8); |
313 | len & 0xff, len >> 8); | ||
314 | } | 310 | } |
315 | 311 | ||
316 | /* mutex_lock(&dev->ctrl_urb_lock); */ | 312 | /* mutex_lock(&dev->ctrl_urb_lock); */ |
@@ -340,10 +336,9 @@ int cx231xx_read_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, | |||
340 | return ret; | 336 | return ret; |
341 | } | 337 | } |
342 | 338 | ||
343 | 339 | int cx231xx_send_vendor_cmd(struct cx231xx *dev, VENDOR_REQUEST_IN * ven_req) | |
344 | int cx231xx_send_vendor_cmd(struct cx231xx *dev, VENDOR_REQUEST_IN *ven_req) | ||
345 | { | 340 | { |
346 | int ret; | 341 | int ret; |
347 | int pipe = 0; | 342 | int pipe = 0; |
348 | 343 | ||
349 | if (dev->state & DEV_DISCONNECTED) | 344 | if (dev->state & DEV_DISCONNECTED) |
@@ -352,32 +347,34 @@ int cx231xx_send_vendor_cmd(struct cx231xx *dev, VENDOR_REQUEST_IN *ven_req) | |||
352 | if ((ven_req->wLength > URB_MAX_CTRL_SIZE)) | 347 | if ((ven_req->wLength > URB_MAX_CTRL_SIZE)) |
353 | return -EINVAL; | 348 | return -EINVAL; |
354 | 349 | ||
355 | if(ven_req->direction) | 350 | if (ven_req->direction) |
356 | pipe = usb_rcvctrlpipe(dev->udev, 0); | 351 | pipe = usb_rcvctrlpipe(dev->udev, 0); |
357 | else | 352 | else |
358 | pipe = usb_sndctrlpipe(dev->udev, 0); | 353 | pipe = usb_sndctrlpipe(dev->udev, 0); |
359 | |||
360 | 354 | ||
361 | if (reg_debug) { | 355 | if (reg_debug) { |
362 | int byte; | 356 | int byte; |
363 | 357 | ||
364 | cx231xx_isocdbg("(pipe 0x%08x): " | 358 | cx231xx_isocdbg("(pipe 0x%08x): " |
365 | "OUT: %02x %02x %02x %04x %04x %04x >>>", | 359 | "OUT: %02x %02x %02x %04x %04x %04x >>>", |
366 | pipe, | 360 | pipe, |
367 | ven_req->direction | USB_TYPE_VENDOR | USB_RECIP_DEVICE, | 361 | ven_req-> |
368 | ven_req->bRequest, 0, ven_req->wValue, | 362 | direction | USB_TYPE_VENDOR | USB_RECIP_DEVICE, |
369 | ven_req->wIndex, | 363 | ven_req->bRequest, 0, ven_req->wValue, |
370 | ven_req->wLength); | 364 | ven_req->wIndex, ven_req->wLength); |
371 | 365 | ||
372 | for (byte = 0; byte < ven_req->wLength; byte++) | 366 | for (byte = 0; byte < ven_req->wLength; byte++) |
373 | cx231xx_isocdbg(" %02x", (unsigned char)ven_req->pBuff[byte]); | 367 | cx231xx_isocdbg(" %02x", |
368 | (unsigned char)ven_req->pBuff[byte]); | ||
374 | cx231xx_isocdbg("\n"); | 369 | cx231xx_isocdbg("\n"); |
375 | } | 370 | } |
376 | 371 | ||
377 | /* mutex_lock(&dev->ctrl_urb_lock); */ | 372 | /* mutex_lock(&dev->ctrl_urb_lock); */ |
378 | ret = usb_control_msg(dev->udev, pipe, ven_req->bRequest, | 373 | ret = usb_control_msg(dev->udev, pipe, ven_req->bRequest, |
379 | ven_req->direction | USB_TYPE_VENDOR | USB_RECIP_DEVICE, | 374 | ven_req-> |
380 | ven_req->wValue, ven_req->wIndex, ven_req->pBuff, ven_req->wLength, HZ); | 375 | direction | USB_TYPE_VENDOR | USB_RECIP_DEVICE, |
376 | ven_req->wValue, ven_req->wIndex, ven_req->pBuff, | ||
377 | ven_req->wLength, HZ); | ||
381 | /* mutex_unlock(&dev->ctrl_urb_lock); */ | 378 | /* mutex_unlock(&dev->ctrl_urb_lock); */ |
382 | 379 | ||
383 | return ret; | 380 | return ret; |
@@ -388,9 +385,9 @@ int cx231xx_send_vendor_cmd(struct cx231xx *dev, VENDOR_REQUEST_IN *ven_req) | |||
388 | * sends data to the usb device, specifying bRequest | 385 | * sends data to the usb device, specifying bRequest |
389 | */ | 386 | */ |
390 | int cx231xx_write_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, char *buf, | 387 | int cx231xx_write_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, char *buf, |
391 | int len) | 388 | int len) |
392 | { | 389 | { |
393 | u8 val = 0; | 390 | u8 val = 0; |
394 | int ret; | 391 | int ret; |
395 | int pipe = usb_sndctrlpipe(dev->udev, 0); | 392 | int pipe = usb_sndctrlpipe(dev->udev, 0); |
396 | 393 | ||
@@ -400,37 +397,35 @@ int cx231xx_write_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, char *buf, | |||
400 | if ((len < 1) || (len > URB_MAX_CTRL_SIZE)) | 397 | if ((len < 1) || (len > URB_MAX_CTRL_SIZE)) |
401 | return -EINVAL; | 398 | return -EINVAL; |
402 | 399 | ||
403 | switch(len) | 400 | switch (len) { |
404 | { | 401 | case 1: |
405 | case 1: | 402 | val = ENABLE_ONE_BYTE; |
406 | val = ENABLE_ONE_BYTE; | 403 | break; |
407 | break; | 404 | case 2: |
408 | case 2: | 405 | val = ENABLE_TWE_BYTE; |
409 | val = ENABLE_TWE_BYTE; | 406 | break; |
410 | break; | 407 | case 3: |
411 | case 3: | 408 | val = ENABLE_THREE_BYTE; |
412 | val = ENABLE_THREE_BYTE; | 409 | break; |
413 | break; | 410 | case 4: |
414 | case 4: | 411 | val = ENABLE_FOUR_BYTE; |
415 | val = ENABLE_FOUR_BYTE; | 412 | break; |
416 | break; | 413 | default: |
417 | default: | 414 | val = 0xFF; /* invalid option */ |
418 | val = 0xFF; /* invalid option */ | 415 | } |
419 | } | 416 | |
420 | 417 | if (val == 0xFF) | |
421 | if(val == 0xFF) | 418 | return -EINVAL; |
422 | return -EINVAL; | ||
423 | 419 | ||
424 | if (reg_debug) { | 420 | if (reg_debug) { |
425 | int byte; | 421 | int byte; |
426 | 422 | ||
427 | cx231xx_isocdbg("(pipe 0x%08x): " | 423 | cx231xx_isocdbg("(pipe 0x%08x): " |
428 | "OUT: %02x %02x %02x %02x %02x %02x %02x %02x >>>", | 424 | "OUT: %02x %02x %02x %02x %02x %02x %02x %02x >>>", |
429 | pipe, | 425 | pipe, |
430 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE, | 426 | USB_DIR_OUT | USB_TYPE_VENDOR | |
431 | req, 0, val, | 427 | USB_RECIP_DEVICE, req, 0, val, reg & 0xff, |
432 | reg & 0xff, reg >> 8, | 428 | reg >> 8, len & 0xff, len >> 8); |
433 | len & 0xff, len >> 8); | ||
434 | 429 | ||
435 | for (byte = 0; byte < len; byte++) | 430 | for (byte = 0; byte < len; byte++) |
436 | cx231xx_isocdbg(" %02x", (unsigned char)buf[byte]); | 431 | cx231xx_isocdbg(" %02x", (unsigned char)buf[byte]); |
@@ -447,7 +442,6 @@ int cx231xx_write_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, char *buf, | |||
447 | return ret; | 442 | return ret; |
448 | } | 443 | } |
449 | 444 | ||
450 | |||
451 | /************************************************************************************ | 445 | /************************************************************************************ |
452 | * USB Alternate Setting functions * | 446 | * USB Alternate Setting functions * |
453 | *************************************************************************************/ | 447 | *************************************************************************************/ |
@@ -456,7 +450,7 @@ int cx231xx_set_video_alternate(struct cx231xx *dev) | |||
456 | { | 450 | { |
457 | int errCode, prev_alt = dev->video_mode.alt; | 451 | int errCode, prev_alt = dev->video_mode.alt; |
458 | unsigned int min_pkt_size = dev->width * 2 + 4; | 452 | unsigned int min_pkt_size = dev->width * 2 + 4; |
459 | u32 usb_interface_index = 0; | 453 | u32 usb_interface_index = 0; |
460 | 454 | ||
461 | /* When image size is bigger than a certain value, | 455 | /* When image size is bigger than a certain value, |
462 | the frame size should be increased, otherwise, only | 456 | the frame size should be increased, otherwise, only |
@@ -465,35 +459,44 @@ int cx231xx_set_video_alternate(struct cx231xx *dev) | |||
465 | if (dev->width * 2 * dev->height > 720 * 240 * 2) | 459 | if (dev->width * 2 * dev->height > 720 * 240 * 2) |
466 | min_pkt_size *= 2; | 460 | min_pkt_size *= 2; |
467 | 461 | ||
468 | if(dev->width > 360) { | 462 | if (dev->width > 360) { |
469 | /* resolutions: 720,704,640 */ | 463 | /* resolutions: 720,704,640 */ |
470 | dev->video_mode.alt = 3; | 464 | dev->video_mode.alt = 3; |
471 | } else if(dev->width > 180) { | 465 | } else if (dev->width > 180) { |
472 | /* resolutions: 360,352,320,240 */ | 466 | /* resolutions: 360,352,320,240 */ |
473 | dev->video_mode.alt = 2; | 467 | dev->video_mode.alt = 2; |
474 | } else if(dev->width > 0) { | 468 | } else if (dev->width > 0) { |
475 | /* resolutions: 180,176,160,128,88 */ | 469 | /* resolutions: 180,176,160,128,88 */ |
476 | dev->video_mode.alt = 1; | 470 | dev->video_mode.alt = 1; |
477 | } else { | 471 | } else { |
478 | /* Change to alt0 BULK to release USB bandwidth */ | 472 | /* Change to alt0 BULK to release USB bandwidth */ |
479 | dev->video_mode.alt = 0; | 473 | dev->video_mode.alt = 0; |
480 | } | 474 | } |
481 | 475 | ||
482 | /* Get the correct video interface Index */ | 476 | /* Get the correct video interface Index */ |
483 | usb_interface_index = dev->current_pcb_config.hs_config_info[0].interface_info.video_index+1; | 477 | usb_interface_index = |
478 | dev->current_pcb_config.hs_config_info[0].interface_info. | ||
479 | video_index + 1; | ||
484 | 480 | ||
485 | if (dev->video_mode.alt != prev_alt) { | 481 | if (dev->video_mode.alt != prev_alt) { |
486 | cx231xx_coredbg("minimum isoc packet size: %u (alt=%d)\n", | 482 | cx231xx_coredbg("minimum isoc packet size: %u (alt=%d)\n", |
487 | min_pkt_size, dev->video_mode.alt); | 483 | min_pkt_size, dev->video_mode.alt); |
488 | dev->video_mode.max_pkt_size = dev->video_mode.alt_max_pkt_size[dev->video_mode.alt]; | 484 | dev->video_mode.max_pkt_size = |
485 | dev->video_mode.alt_max_pkt_size[dev->video_mode.alt]; | ||
489 | cx231xx_coredbg("setting alternate %d with wMaxPacketSize=%u\n", | 486 | cx231xx_coredbg("setting alternate %d with wMaxPacketSize=%u\n", |
490 | dev->video_mode.alt, dev->video_mode.max_pkt_size); | 487 | dev->video_mode.alt, |
491 | cx231xx_info(" setting alternate %d with wMaxPacketSize=%u , Interface = %d\n", | 488 | dev->video_mode.max_pkt_size); |
492 | dev->video_mode.alt, dev->video_mode.max_pkt_size, usb_interface_index); | 489 | cx231xx_info |
493 | errCode = usb_set_interface(dev->udev, usb_interface_index, dev->video_mode.alt); | 490 | (" setting alternate %d with wMaxPacketSize=%u , Interface = %d\n", |
491 | dev->video_mode.alt, dev->video_mode.max_pkt_size, | ||
492 | usb_interface_index); | ||
493 | errCode = | ||
494 | usb_set_interface(dev->udev, usb_interface_index, | ||
495 | dev->video_mode.alt); | ||
494 | if (errCode < 0) { | 496 | if (errCode < 0) { |
495 | cx231xx_errdev("cannot change alternate number to %d (error=%i)\n", | 497 | cx231xx_errdev |
496 | dev->video_mode.alt, errCode); | 498 | ("cannot change alternate number to %d (error=%i)\n", |
499 | dev->video_mode.alt, errCode); | ||
497 | return errCode; | 500 | return errCode; |
498 | } | 501 | } |
499 | } | 502 | } |
@@ -502,68 +505,92 @@ int cx231xx_set_video_alternate(struct cx231xx *dev) | |||
502 | 505 | ||
503 | int cx231xx_set_alt_setting(struct cx231xx *dev, u8 index, u8 alt) | 506 | int cx231xx_set_alt_setting(struct cx231xx *dev, u8 index, u8 alt) |
504 | { | 507 | { |
505 | int status = 0; | 508 | int status = 0; |
506 | u32 usb_interface_index = 0; | 509 | u32 usb_interface_index = 0; |
507 | u32 max_pkt_size = 0; | 510 | u32 max_pkt_size = 0; |
508 | 511 | ||
509 | switch(index) { | 512 | switch (index) { |
510 | case INDEX_TS1: | 513 | case INDEX_TS1: |
511 | usb_interface_index = dev->current_pcb_config.hs_config_info[0].interface_info.ts1_index+1; | 514 | usb_interface_index = |
512 | dev->video_mode.alt = alt; | 515 | dev->current_pcb_config.hs_config_info[0].interface_info. |
513 | if(dev->ts1_mode.alt_max_pkt_size != NULL) | 516 | ts1_index + 1; |
514 | max_pkt_size = dev->ts1_mode.max_pkt_size = dev->ts1_mode.alt_max_pkt_size[dev->ts1_mode.alt]; | 517 | dev->video_mode.alt = alt; |
515 | break; | 518 | if (dev->ts1_mode.alt_max_pkt_size != NULL) |
516 | case INDEX_TS2: | 519 | max_pkt_size = dev->ts1_mode.max_pkt_size = |
517 | usb_interface_index = dev->current_pcb_config.hs_config_info[0].interface_info.ts2_index+1; | 520 | dev->ts1_mode.alt_max_pkt_size[dev->ts1_mode.alt]; |
518 | break; | 521 | break; |
519 | case INDEX_AUDIO: | 522 | case INDEX_TS2: |
520 | usb_interface_index = dev->current_pcb_config.hs_config_info[0].interface_info.audio_index+1; | 523 | usb_interface_index = |
521 | dev->adev.alt = alt; | 524 | dev->current_pcb_config.hs_config_info[0].interface_info. |
522 | if( dev->adev.alt_max_pkt_size != NULL) | 525 | ts2_index + 1; |
523 | max_pkt_size = dev->adev.max_pkt_size = dev->adev.alt_max_pkt_size[dev->adev.alt]; | 526 | break; |
524 | break; | 527 | case INDEX_AUDIO: |
525 | case INDEX_VIDEO: | 528 | usb_interface_index = |
526 | usb_interface_index = dev->current_pcb_config.hs_config_info[0].interface_info.video_index+1; | 529 | dev->current_pcb_config.hs_config_info[0].interface_info. |
527 | dev->video_mode.alt = alt; | 530 | audio_index + 1; |
528 | if(dev->video_mode.alt_max_pkt_size != NULL) | 531 | dev->adev.alt = alt; |
529 | max_pkt_size = dev->video_mode.max_pkt_size = dev->video_mode.alt_max_pkt_size[dev->video_mode.alt]; | 532 | if (dev->adev.alt_max_pkt_size != NULL) |
530 | break; | 533 | max_pkt_size = dev->adev.max_pkt_size = |
531 | case INDEX_VANC: | 534 | dev->adev.alt_max_pkt_size[dev->adev.alt]; |
532 | usb_interface_index = dev->current_pcb_config.hs_config_info[0].interface_info.vanc_index+1; | 535 | break; |
533 | dev->vbi_mode.alt = alt; | 536 | case INDEX_VIDEO: |
534 | if(dev->vbi_mode.alt_max_pkt_size != NULL) | 537 | usb_interface_index = |
535 | max_pkt_size = dev->vbi_mode.max_pkt_size = dev->vbi_mode.alt_max_pkt_size[dev->vbi_mode.alt]; | 538 | dev->current_pcb_config.hs_config_info[0].interface_info. |
536 | break; | 539 | video_index + 1; |
537 | case INDEX_HANC: | 540 | dev->video_mode.alt = alt; |
538 | usb_interface_index = dev->current_pcb_config.hs_config_info[0].interface_info.hanc_index+1; | 541 | if (dev->video_mode.alt_max_pkt_size != NULL) |
539 | dev->sliced_cc_mode.alt = alt; | 542 | max_pkt_size = dev->video_mode.max_pkt_size = |
540 | if(dev->sliced_cc_mode.alt_max_pkt_size != NULL) | 543 | dev->video_mode.alt_max_pkt_size[dev->video_mode. |
541 | max_pkt_size = dev->sliced_cc_mode.max_pkt_size = dev->sliced_cc_mode.alt_max_pkt_size[dev->sliced_cc_mode.alt]; | 544 | alt]; |
542 | break; | 545 | break; |
543 | default: | 546 | case INDEX_VANC: |
544 | break; | 547 | usb_interface_index = |
545 | } | 548 | dev->current_pcb_config.hs_config_info[0].interface_info. |
546 | 549 | vanc_index + 1; | |
547 | if(alt > 0 && max_pkt_size == 0 ) { | 550 | dev->vbi_mode.alt = alt; |
548 | cx231xx_errdev("cannot change interface %d alternate number to %d : Max. Pkt size is ZERO\n", | 551 | if (dev->vbi_mode.alt_max_pkt_size != NULL) |
549 | usb_interface_index, alt); | 552 | max_pkt_size = dev->vbi_mode.max_pkt_size = |
550 | return -1; | 553 | dev->vbi_mode.alt_max_pkt_size[dev->vbi_mode.alt]; |
551 | } | 554 | break; |
552 | 555 | case INDEX_HANC: | |
553 | cx231xx_info(" setting alternate %d with wMaxPacketSize=%u , Interface = %d\n", | 556 | usb_interface_index = |
554 | alt, max_pkt_size, usb_interface_index); | 557 | dev->current_pcb_config.hs_config_info[0].interface_info. |
555 | 558 | hanc_index + 1; | |
556 | if(usb_interface_index > 0 ) { | 559 | dev->sliced_cc_mode.alt = alt; |
557 | status = usb_set_interface(dev->udev, usb_interface_index, alt); | 560 | if (dev->sliced_cc_mode.alt_max_pkt_size != NULL) |
561 | max_pkt_size = dev->sliced_cc_mode.max_pkt_size = | ||
562 | dev->sliced_cc_mode.alt_max_pkt_size[dev-> | ||
563 | sliced_cc_mode. | ||
564 | alt]; | ||
565 | break; | ||
566 | default: | ||
567 | break; | ||
568 | } | ||
569 | |||
570 | if (alt > 0 && max_pkt_size == 0) { | ||
571 | cx231xx_errdev | ||
572 | ("cannot change interface %d alternate number to %d : Max. Pkt size is ZERO\n", | ||
573 | usb_interface_index, alt); | ||
574 | return -1; | ||
575 | } | ||
576 | |||
577 | cx231xx_info | ||
578 | (" setting alternate %d with wMaxPacketSize=%u , Interface = %d\n", | ||
579 | alt, max_pkt_size, usb_interface_index); | ||
580 | |||
581 | if (usb_interface_index > 0) { | ||
582 | status = usb_set_interface(dev->udev, usb_interface_index, alt); | ||
558 | if (status < 0) { | 583 | if (status < 0) { |
559 | cx231xx_errdev("cannot change interface %d alternate number to %d (error=%i)\n", | 584 | cx231xx_errdev |
560 | usb_interface_index, alt, status); | 585 | ("cannot change interface %d alternate number to %d (error=%i)\n", |
586 | usb_interface_index, alt, status); | ||
561 | return status; | 587 | return status; |
562 | } | 588 | } |
563 | } | 589 | } |
564 | 590 | ||
565 | return status; | 591 | return status; |
566 | } | 592 | } |
593 | |||
567 | EXPORT_SYMBOL_GPL(cx231xx_set_alt_setting); | 594 | EXPORT_SYMBOL_GPL(cx231xx_set_alt_setting); |
568 | 595 | ||
569 | int cx231xx_gpio_set(struct cx231xx *dev, struct cx231xx_reg_seq *gpio) | 596 | int cx231xx_gpio_set(struct cx231xx *dev, struct cx231xx_reg_seq *gpio) |
@@ -575,10 +602,9 @@ int cx231xx_gpio_set(struct cx231xx *dev, struct cx231xx_reg_seq *gpio) | |||
575 | 602 | ||
576 | /* Send GPIO reset sequences specified at board entry */ | 603 | /* Send GPIO reset sequences specified at board entry */ |
577 | while (gpio->sleep >= 0) { | 604 | while (gpio->sleep >= 0) { |
578 | rc = cx231xx_set_gpio_value(dev, gpio->bit, | 605 | rc = cx231xx_set_gpio_value(dev, gpio->bit, gpio->val); |
579 | gpio->val); | 606 | if (rc < 0) |
580 | if (rc < 0) | 607 | return rc; |
581 | return rc; | ||
582 | 608 | ||
583 | if (gpio->sleep > 0) | 609 | if (gpio->sleep > 0) |
584 | msleep(gpio->sleep); | 610 | msleep(gpio->sleep); |
@@ -594,7 +620,7 @@ int cx231xx_set_mode(struct cx231xx *dev, enum cx231xx_mode set_mode) | |||
594 | return 0; | 620 | return 0; |
595 | 621 | ||
596 | if (set_mode == CX231XX_SUSPEND) { | 622 | if (set_mode == CX231XX_SUSPEND) { |
597 | /* Set the chip in power saving mode */ | 623 | /* Set the chip in power saving mode */ |
598 | dev->mode = set_mode; | 624 | dev->mode = set_mode; |
599 | } | 625 | } |
600 | 626 | ||
@@ -604,13 +630,14 @@ int cx231xx_set_mode(struct cx231xx *dev, enum cx231xx_mode set_mode) | |||
604 | 630 | ||
605 | dev->mode = set_mode; | 631 | dev->mode = set_mode; |
606 | 632 | ||
607 | if (dev->mode == CX231XX_DIGITAL_MODE) { | 633 | if (dev->mode == CX231XX_DIGITAL_MODE) { |
608 | /* Set Digital power mode */ | 634 | /* Set Digital power mode */ |
609 | } else { | 635 | } else { |
610 | /* Set Analog Power mode*/ | 636 | /* Set Analog Power mode */ |
611 | } | 637 | } |
612 | return 0; | 638 | return 0; |
613 | } | 639 | } |
640 | |||
614 | EXPORT_SYMBOL_GPL(cx231xx_set_mode); | 641 | EXPORT_SYMBOL_GPL(cx231xx_set_mode); |
615 | 642 | ||
616 | /************************************************************************************ | 643 | /************************************************************************************ |
@@ -622,23 +649,23 @@ EXPORT_SYMBOL_GPL(cx231xx_set_mode); | |||
622 | */ | 649 | */ |
623 | static void cx231xx_irq_callback(struct urb *urb) | 650 | static void cx231xx_irq_callback(struct urb *urb) |
624 | { | 651 | { |
625 | struct cx231xx_dmaqueue *dma_q = urb->context; | 652 | struct cx231xx_dmaqueue *dma_q = urb->context; |
626 | struct cx231xx_video_mode *vmode = container_of(dma_q, struct cx231xx_video_mode, vidq); | 653 | struct cx231xx_video_mode *vmode = |
627 | struct cx231xx *dev = container_of(vmode, struct cx231xx, video_mode); | 654 | container_of(dma_q, struct cx231xx_video_mode, vidq); |
655 | struct cx231xx *dev = container_of(vmode, struct cx231xx, video_mode); | ||
628 | int rc, i; | 656 | int rc, i; |
629 | 657 | ||
630 | 658 | switch (urb->status) { | |
631 | switch (urb->status) { | 659 | case 0: /* success */ |
632 | case 0: /* success */ | 660 | case -ETIMEDOUT: /* NAK */ |
633 | case -ETIMEDOUT: /* NAK */ | 661 | break; |
634 | break; | 662 | case -ECONNRESET: /* kill */ |
635 | case -ECONNRESET: /* kill */ | 663 | case -ENOENT: |
636 | case -ENOENT: | 664 | case -ESHUTDOWN: |
637 | case -ESHUTDOWN: | 665 | return; |
638 | return; | 666 | default: /* error */ |
639 | default: /* error */ | 667 | cx231xx_isocdbg("urb completition error %d.\n", urb->status); |
640 | cx231xx_isocdbg("urb completition error %d.\n", urb->status); | 668 | break; |
641 | break; | ||
642 | } | 669 | } |
643 | 670 | ||
644 | /* Copy data from URB */ | 671 | /* Copy data from URB */ |
@@ -656,7 +683,7 @@ static void cx231xx_irq_callback(struct urb *urb) | |||
656 | urb->status = usb_submit_urb(urb, GFP_ATOMIC); | 683 | urb->status = usb_submit_urb(urb, GFP_ATOMIC); |
657 | if (urb->status) { | 684 | if (urb->status) { |
658 | cx231xx_isocdbg("urb resubmit failed (error=%i)\n", | 685 | cx231xx_isocdbg("urb resubmit failed (error=%i)\n", |
659 | urb->status); | 686 | urb->status); |
660 | } | 687 | } |
661 | } | 688 | } |
662 | 689 | ||
@@ -674,16 +701,17 @@ void cx231xx_uninit_isoc(struct cx231xx *dev) | |||
674 | for (i = 0; i < dev->video_mode.isoc_ctl.num_bufs; i++) { | 701 | for (i = 0; i < dev->video_mode.isoc_ctl.num_bufs; i++) { |
675 | urb = dev->video_mode.isoc_ctl.urb[i]; | 702 | urb = dev->video_mode.isoc_ctl.urb[i]; |
676 | if (urb) { | 703 | if (urb) { |
677 | if (!irqs_disabled()) | 704 | if (!irqs_disabled()) |
678 | usb_kill_urb(urb); | 705 | usb_kill_urb(urb); |
679 | else | 706 | else |
680 | usb_unlink_urb(urb); | 707 | usb_unlink_urb(urb); |
681 | 708 | ||
682 | if (dev->video_mode.isoc_ctl.transfer_buffer[i]) { | 709 | if (dev->video_mode.isoc_ctl.transfer_buffer[i]) { |
683 | usb_buffer_free(dev->udev, | 710 | usb_buffer_free(dev->udev, |
684 | urb->transfer_buffer_length, | 711 | urb->transfer_buffer_length, |
685 | dev->video_mode.isoc_ctl.transfer_buffer[i], | 712 | dev->video_mode.isoc_ctl. |
686 | urb->transfer_dma); | 713 | transfer_buffer[i], |
714 | urb->transfer_dma); | ||
687 | } | 715 | } |
688 | usb_free_urb(urb); | 716 | usb_free_urb(urb); |
689 | dev->video_mode.isoc_ctl.urb[i] = NULL; | 717 | dev->video_mode.isoc_ctl.urb[i] = NULL; |
@@ -700,14 +728,15 @@ void cx231xx_uninit_isoc(struct cx231xx *dev) | |||
700 | 728 | ||
701 | cx231xx_capture_start(dev, 0, Raw_Video); | 729 | cx231xx_capture_start(dev, 0, Raw_Video); |
702 | } | 730 | } |
731 | |||
703 | EXPORT_SYMBOL_GPL(cx231xx_uninit_isoc); | 732 | EXPORT_SYMBOL_GPL(cx231xx_uninit_isoc); |
704 | 733 | ||
705 | /* | 734 | /* |
706 | * Allocate URBs and start IRQ | 735 | * Allocate URBs and start IRQ |
707 | */ | 736 | */ |
708 | int cx231xx_init_isoc(struct cx231xx *dev, int max_packets, | 737 | int cx231xx_init_isoc(struct cx231xx *dev, int max_packets, |
709 | int num_bufs, int max_pkt_size, | 738 | int num_bufs, int max_pkt_size, |
710 | int (*isoc_copy) (struct cx231xx *dev, struct urb *urb)) | 739 | int (*isoc_copy) (struct cx231xx * dev, struct urb * urb)) |
711 | { | 740 | { |
712 | struct cx231xx_dmaqueue *dma_q = &dev->video_mode.vidq; | 741 | struct cx231xx_dmaqueue *dma_q = &dev->video_mode.vidq; |
713 | int i; | 742 | int i; |
@@ -718,36 +747,36 @@ int cx231xx_init_isoc(struct cx231xx *dev, int max_packets, | |||
718 | 747 | ||
719 | cx231xx_isocdbg("cx231xx: called cx231xx_prepare_isoc\n"); | 748 | cx231xx_isocdbg("cx231xx: called cx231xx_prepare_isoc\n"); |
720 | 749 | ||
721 | dev->video_input = dev->video_input > 2?2:dev->video_input; | 750 | dev->video_input = dev->video_input > 2 ? 2 : dev->video_input; |
722 | |||
723 | cx231xx_info("Setting Video mux to %d\n",dev->video_input); | ||
724 | video_mux(dev, dev->video_input); | ||
725 | 751 | ||
752 | cx231xx_info("Setting Video mux to %d\n", dev->video_input); | ||
753 | video_mux(dev, dev->video_input); | ||
726 | 754 | ||
727 | /* De-allocates all pending stuff */ | 755 | /* De-allocates all pending stuff */ |
728 | cx231xx_uninit_isoc(dev); | 756 | cx231xx_uninit_isoc(dev); |
729 | 757 | ||
730 | dev->video_mode.isoc_ctl.isoc_copy = isoc_copy; | 758 | dev->video_mode.isoc_ctl.isoc_copy = isoc_copy; |
731 | dev->video_mode.isoc_ctl.num_bufs = num_bufs; | 759 | dev->video_mode.isoc_ctl.num_bufs = num_bufs; |
732 | dma_q->pos = 0; | 760 | dma_q->pos = 0; |
733 | dma_q->is_partial_line = 0; | 761 | dma_q->is_partial_line = 0; |
734 | dma_q->last_sav = 0; | 762 | dma_q->last_sav = 0; |
735 | dma_q->current_field = -1; | 763 | dma_q->current_field = -1; |
736 | dma_q->field1_done = 0; | 764 | dma_q->field1_done = 0; |
737 | dma_q->lines_per_field = dev->height/2; | 765 | dma_q->lines_per_field = dev->height / 2; |
738 | dma_q->bytes_left_in_line = dev->width << 1; | 766 | dma_q->bytes_left_in_line = dev->width << 1; |
739 | dma_q->lines_completed = 0; | 767 | dma_q->lines_completed = 0; |
740 | for(i = 0; i < 8 ; i++) | 768 | for (i = 0; i < 8; i++) |
741 | dma_q->partial_buf[i] = 0; | 769 | dma_q->partial_buf[i] = 0; |
742 | 770 | ||
743 | dev->video_mode.isoc_ctl.urb = kzalloc(sizeof(void *)*num_bufs, GFP_KERNEL); | 771 | dev->video_mode.isoc_ctl.urb = |
772 | kzalloc(sizeof(void *) * num_bufs, GFP_KERNEL); | ||
744 | if (!dev->video_mode.isoc_ctl.urb) { | 773 | if (!dev->video_mode.isoc_ctl.urb) { |
745 | cx231xx_errdev("cannot alloc memory for usb buffers\n"); | 774 | cx231xx_errdev("cannot alloc memory for usb buffers\n"); |
746 | return -ENOMEM; | 775 | return -ENOMEM; |
747 | } | 776 | } |
748 | 777 | ||
749 | dev->video_mode.isoc_ctl.transfer_buffer = kzalloc(sizeof(void *)*num_bufs, | 778 | dev->video_mode.isoc_ctl.transfer_buffer = |
750 | GFP_KERNEL); | 779 | kzalloc(sizeof(void *) * num_bufs, GFP_KERNEL); |
751 | if (!dev->video_mode.isoc_ctl.transfer_buffer) { | 780 | if (!dev->video_mode.isoc_ctl.transfer_buffer) { |
752 | cx231xx_errdev("cannot allocate memory for usbtransfer\n"); | 781 | cx231xx_errdev("cannot allocate memory for usbtransfer\n"); |
753 | kfree(dev->video_mode.isoc_ctl.urb); | 782 | kfree(dev->video_mode.isoc_ctl.urb); |
@@ -769,23 +798,25 @@ int cx231xx_init_isoc(struct cx231xx *dev, int max_packets, | |||
769 | } | 798 | } |
770 | dev->video_mode.isoc_ctl.urb[i] = urb; | 799 | dev->video_mode.isoc_ctl.urb[i] = urb; |
771 | 800 | ||
772 | dev->video_mode.isoc_ctl.transfer_buffer[i] = usb_buffer_alloc(dev->udev, | 801 | dev->video_mode.isoc_ctl.transfer_buffer[i] = |
773 | sb_size, GFP_KERNEL, &urb->transfer_dma); | 802 | usb_buffer_alloc(dev->udev, sb_size, GFP_KERNEL, |
803 | &urb->transfer_dma); | ||
774 | if (!dev->video_mode.isoc_ctl.transfer_buffer[i]) { | 804 | if (!dev->video_mode.isoc_ctl.transfer_buffer[i]) { |
775 | cx231xx_err("unable to allocate %i bytes for transfer" | 805 | cx231xx_err("unable to allocate %i bytes for transfer" |
776 | " buffer %i%s\n", | 806 | " buffer %i%s\n", |
777 | sb_size, i, | 807 | sb_size, i, |
778 | in_interrupt()?" while in int":""); | 808 | in_interrupt()? " while in int" : ""); |
779 | cx231xx_uninit_isoc(dev); | 809 | cx231xx_uninit_isoc(dev); |
780 | return -ENOMEM; | 810 | return -ENOMEM; |
781 | } | 811 | } |
782 | memset(dev->video_mode.isoc_ctl.transfer_buffer[i], 0, sb_size); | 812 | memset(dev->video_mode.isoc_ctl.transfer_buffer[i], 0, sb_size); |
783 | 813 | ||
784 | pipe = usb_rcvisocpipe(dev->udev, dev->video_mode.end_point_addr); | 814 | pipe = |
815 | usb_rcvisocpipe(dev->udev, dev->video_mode.end_point_addr); | ||
785 | 816 | ||
786 | usb_fill_int_urb(urb, dev->udev, pipe, | 817 | usb_fill_int_urb(urb, dev->udev, pipe, |
787 | dev->video_mode.isoc_ctl.transfer_buffer[i], sb_size, | 818 | dev->video_mode.isoc_ctl.transfer_buffer[i], |
788 | cx231xx_irq_callback, dma_q, 1); | 819 | sb_size, cx231xx_irq_callback, dma_q, 1); |
789 | 820 | ||
790 | urb->number_of_packets = max_packets; | 821 | urb->number_of_packets = max_packets; |
791 | urb->transfer_flags = URB_ISO_ASAP; | 822 | urb->transfer_flags = URB_ISO_ASAP; |
@@ -794,29 +825,30 @@ int cx231xx_init_isoc(struct cx231xx *dev, int max_packets, | |||
794 | for (j = 0; j < max_packets; j++) { | 825 | for (j = 0; j < max_packets; j++) { |
795 | urb->iso_frame_desc[j].offset = k; | 826 | urb->iso_frame_desc[j].offset = k; |
796 | urb->iso_frame_desc[j].length = | 827 | urb->iso_frame_desc[j].length = |
797 | dev->video_mode.isoc_ctl.max_pkt_size; | 828 | dev->video_mode.isoc_ctl.max_pkt_size; |
798 | k += dev->video_mode.isoc_ctl.max_pkt_size; | 829 | k += dev->video_mode.isoc_ctl.max_pkt_size; |
799 | } | 830 | } |
800 | } | 831 | } |
801 | 832 | ||
802 | init_waitqueue_head(&dma_q->wq); | 833 | init_waitqueue_head(&dma_q->wq); |
803 | 834 | ||
804 | |||
805 | /* submit urbs and enables IRQ */ | 835 | /* submit urbs and enables IRQ */ |
806 | for (i = 0; i < dev->video_mode.isoc_ctl.num_bufs; i++) { | 836 | for (i = 0; i < dev->video_mode.isoc_ctl.num_bufs; i++) { |
807 | rc = usb_submit_urb(dev->video_mode.isoc_ctl.urb[i], GFP_ATOMIC); | 837 | rc = usb_submit_urb(dev->video_mode.isoc_ctl.urb[i], |
838 | GFP_ATOMIC); | ||
808 | if (rc) { | 839 | if (rc) { |
809 | cx231xx_err("submit of urb %i failed (error=%i)\n", i, | 840 | cx231xx_err("submit of urb %i failed (error=%i)\n", i, |
810 | rc); | 841 | rc); |
811 | cx231xx_uninit_isoc(dev); | 842 | cx231xx_uninit_isoc(dev); |
812 | return rc; | 843 | return rc; |
813 | } | 844 | } |
814 | } | 845 | } |
815 | 846 | ||
816 | cx231xx_capture_start(dev, 1, Raw_Video); | 847 | cx231xx_capture_start(dev, 1, Raw_Video); |
817 | 848 | ||
818 | return 0; | 849 | return 0; |
819 | } | 850 | } |
851 | |||
820 | EXPORT_SYMBOL_GPL(cx231xx_init_isoc); | 852 | EXPORT_SYMBOL_GPL(cx231xx_init_isoc); |
821 | 853 | ||
822 | /************************************************************************************ | 854 | /************************************************************************************ |
@@ -824,171 +856,176 @@ EXPORT_SYMBOL_GPL(cx231xx_init_isoc); | |||
824 | *************************************************************************************/ | 856 | *************************************************************************************/ |
825 | int cx231xx_dev_init(struct cx231xx *dev) | 857 | int cx231xx_dev_init(struct cx231xx *dev) |
826 | { | 858 | { |
827 | int errCode = 0; | 859 | int errCode = 0; |
828 | 860 | ||
829 | /* Initialize I2C bus */ | 861 | /* Initialize I2C bus */ |
830 | 862 | ||
831 | /* External Master 1 Bus */ | 863 | /* External Master 1 Bus */ |
832 | dev->i2c_bus[0].nr = 0; | 864 | dev->i2c_bus[0].nr = 0; |
833 | dev->i2c_bus[0].dev = dev; | 865 | dev->i2c_bus[0].dev = dev; |
834 | dev->i2c_bus[0].i2c_period = I2C_SPEED_1M; /* 1MHz */ | 866 | dev->i2c_bus[0].i2c_period = I2C_SPEED_1M; /* 1MHz */ |
835 | dev->i2c_bus[0].i2c_nostop = 0; | 867 | dev->i2c_bus[0].i2c_nostop = 0; |
836 | dev->i2c_bus[0].i2c_reserve = 0; | 868 | dev->i2c_bus[0].i2c_reserve = 0; |
837 | 869 | ||
838 | /* External Master 2 Bus */ | 870 | /* External Master 2 Bus */ |
839 | dev->i2c_bus[1].nr = 1; | 871 | dev->i2c_bus[1].nr = 1; |
840 | dev->i2c_bus[1].dev = dev; | 872 | dev->i2c_bus[1].dev = dev; |
841 | dev->i2c_bus[1].i2c_period = I2C_SPEED_1M; /* 1MHz */ | 873 | dev->i2c_bus[1].i2c_period = I2C_SPEED_1M; /* 1MHz */ |
842 | dev->i2c_bus[1].i2c_nostop = 0; | 874 | dev->i2c_bus[1].i2c_nostop = 0; |
843 | dev->i2c_bus[1].i2c_reserve = 0; | 875 | dev->i2c_bus[1].i2c_reserve = 0; |
844 | 876 | ||
845 | /* Internal Master 3 Bus */ | 877 | /* Internal Master 3 Bus */ |
846 | dev->i2c_bus[2].nr = 2; | 878 | dev->i2c_bus[2].nr = 2; |
847 | dev->i2c_bus[2].dev = dev; | 879 | dev->i2c_bus[2].dev = dev; |
848 | dev->i2c_bus[2].i2c_period = I2C_SPEED_400K; /* 400kHz */ | 880 | dev->i2c_bus[2].i2c_period = I2C_SPEED_400K; /* 400kHz */ |
849 | dev->i2c_bus[2].i2c_nostop = 0; | 881 | dev->i2c_bus[2].i2c_nostop = 0; |
850 | dev->i2c_bus[2].i2c_reserve = 0; | 882 | dev->i2c_bus[2].i2c_reserve = 0; |
851 | 883 | ||
852 | /* register I2C buses */ | 884 | /* register I2C buses */ |
853 | cx231xx_i2c_register(&dev->i2c_bus[0]); | 885 | cx231xx_i2c_register(&dev->i2c_bus[0]); |
854 | cx231xx_i2c_register(&dev->i2c_bus[1]); | 886 | cx231xx_i2c_register(&dev->i2c_bus[1]); |
855 | cx231xx_i2c_register(&dev->i2c_bus[2]); | 887 | cx231xx_i2c_register(&dev->i2c_bus[2]); |
856 | 888 | ||
857 | /* init hardware */ | 889 | /* init hardware */ |
858 | /* Note : with out calling set power mode function, colibri can not be set up correctly */ | 890 | /* Note : with out calling set power mode function, colibri can not be set up correctly */ |
859 | errCode = cx231xx_set_power_mode(dev, POLARIS_AVMODE_ANALOGT_TV); | 891 | errCode = cx231xx_set_power_mode(dev, POLARIS_AVMODE_ANALOGT_TV); |
860 | if (errCode < 0) { | 892 | if (errCode < 0) { |
861 | cx231xx_errdev("%s: cx231xx_set_power_mode : Failed to set Power - errCode [%d]!\n", | 893 | cx231xx_errdev |
862 | __func__, errCode); | 894 | ("%s: cx231xx_set_power_mode : Failed to set Power - errCode [%d]!\n", |
895 | __func__, errCode); | ||
863 | return errCode; | 896 | return errCode; |
864 | } | 897 | } |
865 | 898 | ||
866 | /* initialize Colibri block */ | 899 | /* initialize Colibri block */ |
867 | errCode = cx231xx_colibri_init_super_block(dev, 0x23c); | 900 | errCode = cx231xx_colibri_init_super_block(dev, 0x23c); |
868 | if (errCode < 0) { | 901 | if (errCode < 0) { |
869 | cx231xx_errdev("%s: cx231xx_colibri init super block - errCode [%d]!\n", | 902 | cx231xx_errdev |
870 | __func__, errCode); | 903 | ("%s: cx231xx_colibri init super block - errCode [%d]!\n", |
904 | __func__, errCode); | ||
871 | return errCode; | 905 | return errCode; |
872 | } | 906 | } |
873 | errCode = cx231xx_colibri_init_channels(dev); | 907 | errCode = cx231xx_colibri_init_channels(dev); |
874 | if (errCode < 0) { | 908 | if (errCode < 0) { |
875 | cx231xx_errdev("%s: cx231xx_colibri init channels - errCode [%d]!\n", | 909 | cx231xx_errdev |
876 | __func__, errCode); | 910 | ("%s: cx231xx_colibri init channels - errCode [%d]!\n", |
911 | __func__, errCode); | ||
877 | return errCode; | 912 | return errCode; |
878 | } | 913 | } |
879 | 914 | ||
880 | /* Set DIF in By pass mode */ | 915 | /* Set DIF in By pass mode */ |
881 | errCode = cx231xx_dif_set_standard(dev, DIF_USE_BASEBAND); | 916 | errCode = cx231xx_dif_set_standard(dev, DIF_USE_BASEBAND); |
882 | if (errCode < 0) { | 917 | if (errCode < 0) { |
883 | cx231xx_errdev("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", | 918 | cx231xx_errdev |
884 | __func__, errCode); | 919 | ("%s: cx231xx_dif set to By pass mode - errCode [%d]!\n", |
920 | __func__, errCode); | ||
885 | return errCode; | 921 | return errCode; |
886 | } | 922 | } |
887 | 923 | ||
888 | /* flatiron related functions */ | 924 | /* flatiron related functions */ |
889 | errCode = cx231xx_flatiron_initialize(dev); | 925 | errCode = cx231xx_flatiron_initialize(dev); |
890 | if (errCode < 0) { | 926 | if (errCode < 0) { |
891 | cx231xx_errdev("%s: cx231xx_flatiron initialize - errCode [%d]!\n", | 927 | cx231xx_errdev |
892 | __func__, errCode); | 928 | ("%s: cx231xx_flatiron initialize - errCode [%d]!\n", |
929 | __func__, errCode); | ||
893 | return errCode; | 930 | return errCode; |
894 | } | 931 | } |
895 | 932 | ||
896 | /* init control pins */ | 933 | /* init control pins */ |
897 | errCode = cx231xx_init_ctrl_pin_status(dev); | 934 | errCode = cx231xx_init_ctrl_pin_status(dev); |
898 | if (errCode < 0) { | 935 | if (errCode < 0) { |
899 | cx231xx_errdev("%s: cx231xx_init ctrl pins - errCode [%d]!\n", | 936 | cx231xx_errdev("%s: cx231xx_init ctrl pins - errCode [%d]!\n", |
900 | __func__, errCode); | 937 | __func__, errCode); |
901 | return errCode; | 938 | return errCode; |
902 | } | 939 | } |
903 | 940 | ||
904 | /* set AGC mode to Analog */ | 941 | /* set AGC mode to Analog */ |
905 | errCode = cx231xx_set_agc_analog_digital_mux_select(dev, 1); | 942 | errCode = cx231xx_set_agc_analog_digital_mux_select(dev, 1); |
906 | if (errCode < 0) { | 943 | if (errCode < 0) { |
907 | cx231xx_errdev("%s: cx231xx_AGC mode to Analog - errCode [%d]!\n", | 944 | cx231xx_errdev |
908 | __func__, errCode); | 945 | ("%s: cx231xx_AGC mode to Analog - errCode [%d]!\n", |
946 | __func__, errCode); | ||
909 | return errCode; | 947 | return errCode; |
910 | } | 948 | } |
911 | 949 | ||
912 | /* set all alternate settings to zero initially */ | 950 | /* set all alternate settings to zero initially */ |
913 | cx231xx_set_alt_setting(dev, INDEX_VIDEO, 0); | 951 | cx231xx_set_alt_setting(dev, INDEX_VIDEO, 0); |
914 | cx231xx_set_alt_setting(dev, INDEX_VANC, 0); | 952 | cx231xx_set_alt_setting(dev, INDEX_VANC, 0); |
915 | cx231xx_set_alt_setting(dev, INDEX_HANC, 0); | 953 | cx231xx_set_alt_setting(dev, INDEX_HANC, 0); |
916 | if(dev->board.has_dvb) | 954 | if (dev->board.has_dvb) |
917 | cx231xx_set_alt_setting(dev, INDEX_TS1, 0); | 955 | cx231xx_set_alt_setting(dev, INDEX_TS1, 0); |
918 | 956 | ||
919 | /* set the I2C master port to 3 on channel 1 */ | 957 | /* set the I2C master port to 3 on channel 1 */ |
920 | errCode = cx231xx_enable_i2c_for_tuner(dev, I2C_3); | 958 | errCode = cx231xx_enable_i2c_for_tuner(dev, I2C_3); |
921 | 959 | ||
922 | return errCode; | 960 | return errCode; |
923 | } | 961 | } |
962 | |||
924 | EXPORT_SYMBOL_GPL(cx231xx_dev_init); | 963 | EXPORT_SYMBOL_GPL(cx231xx_dev_init); |
925 | 964 | ||
926 | void cx231xx_dev_uninit(struct cx231xx *dev) | 965 | void cx231xx_dev_uninit(struct cx231xx *dev) |
927 | { | 966 | { |
928 | /* Un Initialize I2C bus */ | 967 | /* Un Initialize I2C bus */ |
929 | cx231xx_i2c_unregister(&dev->i2c_bus[2]); | 968 | cx231xx_i2c_unregister(&dev->i2c_bus[2]); |
930 | cx231xx_i2c_unregister(&dev->i2c_bus[1]); | 969 | cx231xx_i2c_unregister(&dev->i2c_bus[1]); |
931 | cx231xx_i2c_unregister(&dev->i2c_bus[0]); | 970 | cx231xx_i2c_unregister(&dev->i2c_bus[0]); |
932 | } | 971 | } |
933 | EXPORT_SYMBOL_GPL(cx231xx_dev_uninit); | ||
934 | 972 | ||
973 | EXPORT_SYMBOL_GPL(cx231xx_dev_uninit); | ||
935 | 974 | ||
936 | /************************************************************************************ | 975 | /************************************************************************************ |
937 | * G P I O related functions * | 976 | * G P I O related functions * |
938 | *************************************************************************************/ | 977 | *************************************************************************************/ |
939 | int cx231xx_send_gpio_cmd(struct cx231xx *dev, u32 gpio_bit, u8* gpio_val, | 978 | int cx231xx_send_gpio_cmd(struct cx231xx *dev, u32 gpio_bit, u8 * gpio_val, |
940 | u8 len, u8 request, u8 direction) | 979 | u8 len, u8 request, u8 direction) |
941 | { | 980 | { |
942 | int status = 0; | 981 | int status = 0; |
943 | VENDOR_REQUEST_IN ven_req; | 982 | VENDOR_REQUEST_IN ven_req; |
944 | 983 | ||
945 | /* Set wValue */ | 984 | /* Set wValue */ |
946 | ven_req.wValue = (u16)(gpio_bit>>16 & 0xffff); | 985 | ven_req.wValue = (u16) (gpio_bit >> 16 & 0xffff); |
947 | 986 | ||
948 | /* set request */ | 987 | /* set request */ |
949 | if(!request){ | 988 | if (!request) { |
950 | if(direction) | 989 | if (direction) |
951 | ven_req.bRequest = VRT_GET_GPIO; /* 0x8 gpio */ | 990 | ven_req.bRequest = VRT_GET_GPIO; /* 0x8 gpio */ |
952 | else | 991 | else |
953 | ven_req.bRequest = VRT_SET_GPIO; /* 0x9 gpio */ | 992 | ven_req.bRequest = VRT_SET_GPIO; /* 0x9 gpio */ |
954 | } | 993 | } else { |
955 | else { | 994 | if (direction) |
956 | if(direction) | 995 | ven_req.bRequest = VRT_GET_GPIE; /* 0xa gpie */ |
957 | ven_req.bRequest = VRT_GET_GPIE; /* 0xa gpie */ | 996 | else |
958 | else | 997 | ven_req.bRequest = VRT_SET_GPIE; /* 0xb gpie */ |
959 | ven_req.bRequest = VRT_SET_GPIE; /* 0xb gpie */ | 998 | } |
960 | } | ||
961 | |||
962 | /* set index value */ | ||
963 | ven_req.wIndex = (u16)(gpio_bit & 0xffff); | ||
964 | |||
965 | /* set wLength value */ | ||
966 | ven_req.wLength = len; | ||
967 | |||
968 | /* set bData value */ | ||
969 | ven_req.bData = 0; | ||
970 | |||
971 | /* set the buffer for read / write */ | ||
972 | ven_req.pBuff = gpio_val; | ||
973 | 999 | ||
974 | /* set the direction */ | 1000 | /* set index value */ |
975 | if(direction){ | 1001 | ven_req.wIndex = (u16) (gpio_bit & 0xffff); |
976 | ven_req.direction = USB_DIR_IN; | ||
977 | memset(ven_req.pBuff, 0x00, ven_req.wLength); | ||
978 | } | ||
979 | else | ||
980 | ven_req.direction = USB_DIR_OUT; | ||
981 | 1002 | ||
1003 | /* set wLength value */ | ||
1004 | ven_req.wLength = len; | ||
982 | 1005 | ||
1006 | /* set bData value */ | ||
1007 | ven_req.bData = 0; | ||
983 | 1008 | ||
984 | /* call common vendor command request */ | 1009 | /* set the buffer for read / write */ |
985 | status = cx231xx_send_vendor_cmd(dev, &ven_req); | 1010 | ven_req.pBuff = gpio_val; |
986 | if (status < 0) | 1011 | |
987 | { | 1012 | /* set the direction */ |
988 | cx231xx_info("UsbInterface::sendCommand, output buffer failed with status -%d\n", status); | 1013 | if (direction) { |
989 | } | 1014 | ven_req.direction = USB_DIR_IN; |
1015 | memset(ven_req.pBuff, 0x00, ven_req.wLength); | ||
1016 | } else | ||
1017 | ven_req.direction = USB_DIR_OUT; | ||
1018 | |||
1019 | |||
1020 | /* call common vendor command request */ | ||
1021 | status = cx231xx_send_vendor_cmd(dev, &ven_req); | ||
1022 | if (status < 0) { | ||
1023 | cx231xx_info | ||
1024 | ("UsbInterface::sendCommand, output buffer failed with status -%d\n", | ||
1025 | status); | ||
1026 | } | ||
990 | 1027 | ||
991 | return status; | 1028 | return status; |
992 | } | 1029 | } |
993 | 1030 | ||
994 | EXPORT_SYMBOL_GPL(cx231xx_send_gpio_cmd); | 1031 | EXPORT_SYMBOL_GPL(cx231xx_send_gpio_cmd); |
@@ -998,170 +1035,177 @@ EXPORT_SYMBOL_GPL(cx231xx_send_gpio_cmd); | |||
998 | *************************************************************************************/ | 1035 | *************************************************************************************/ |
999 | int cx231xx_mode_register(struct cx231xx *dev, u16 address, u32 mode) | 1036 | int cx231xx_mode_register(struct cx231xx *dev, u16 address, u32 mode) |
1000 | { | 1037 | { |
1001 | u8 value[4] = {0x0, 0x0, 0x0, 0x0}; | 1038 | u8 value[4] = { 0x0, 0x0, 0x0, 0x0 }; |
1002 | u32 tmp =0; | 1039 | u32 tmp = 0; |
1003 | int status = 0; | 1040 | int status = 0; |
1004 | 1041 | ||
1005 | status = cx231xx_read_ctrl_reg(dev,VRT_GET_REGISTER, address,value,4); | 1042 | status = |
1006 | if(status < 0) | 1043 | cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, address, value, 4); |
1007 | return status; | 1044 | if (status < 0) |
1045 | return status; | ||
1008 | 1046 | ||
1009 | tmp = *((u32 *)value); | 1047 | tmp = *((u32 *) value); |
1010 | tmp |= mode; | 1048 | tmp |= mode; |
1011 | 1049 | ||
1012 | value[0]=(u8) tmp; | 1050 | value[0] = (u8) tmp; |
1013 | value[1]=(u8)(tmp>>8); | 1051 | value[1] = (u8) (tmp >> 8); |
1014 | value[2]=(u8)(tmp>>16); | 1052 | value[2] = (u8) (tmp >> 16); |
1015 | value[3]=(u8)(tmp>>24); | 1053 | value[3] = (u8) (tmp >> 24); |
1016 | 1054 | ||
1017 | status = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, address,value,4); | 1055 | status = |
1056 | cx231xx_write_ctrl_reg(dev, VRT_SET_REGISTER, address, value, 4); | ||
1018 | 1057 | ||
1019 | return status; | 1058 | return status; |
1020 | } | 1059 | } |
1021 | 1060 | ||
1022 | /************************************************************************************* | 1061 | /************************************************************************************* |
1023 | * I 2 C Internal C O N T R O L functions * | 1062 | * I 2 C Internal C O N T R O L functions * |
1024 | *************************************************************************************/ | 1063 | *************************************************************************************/ |
1025 | int cx231xx_read_i2c_data(struct cx231xx *dev, u8 dev_addr, u16 saddr, | 1064 | int cx231xx_read_i2c_data(struct cx231xx *dev, u8 dev_addr, u16 saddr, |
1026 | u8 saddr_len, u32 *data, u8 data_len) | 1065 | u8 saddr_len, u32 * data, u8 data_len) |
1027 | { | 1066 | { |
1028 | int status = 0; | 1067 | int status = 0; |
1029 | struct cx231xx_i2c_xfer_data req_data; | 1068 | struct cx231xx_i2c_xfer_data req_data; |
1030 | u8 value[4] ={0,0,0,0}; | 1069 | u8 value[4] = { 0, 0, 0, 0 }; |
1031 | 1070 | ||
1032 | if(saddr_len == 0) | 1071 | if (saddr_len == 0) |
1033 | saddr = 0; | 1072 | saddr = 0; |
1034 | else if(saddr_len == 0) | 1073 | else if (saddr_len == 0) |
1035 | saddr &= 0xff; | 1074 | saddr &= 0xff; |
1036 | 1075 | ||
1037 | /* prepare xfer_data struct */ | 1076 | /* prepare xfer_data struct */ |
1038 | req_data.dev_addr = dev_addr >> 1; | 1077 | req_data.dev_addr = dev_addr >> 1; |
1039 | req_data.direction = I2C_M_RD; | 1078 | req_data.direction = I2C_M_RD; |
1040 | req_data.saddr_len = saddr_len; | 1079 | req_data.saddr_len = saddr_len; |
1041 | req_data.saddr_dat = saddr; | 1080 | req_data.saddr_dat = saddr; |
1042 | req_data.buf_size = data_len; | 1081 | req_data.buf_size = data_len; |
1043 | req_data.p_buffer = (u8*)value; | 1082 | req_data.p_buffer = (u8 *) value; |
1044 | 1083 | ||
1045 | /* usb send command */ | 1084 | /* usb send command */ |
1046 | status = dev->cx231xx_send_usb_command(&dev->i2c_bus[0], &req_data); | 1085 | status = dev->cx231xx_send_usb_command(&dev->i2c_bus[0], &req_data); |
1047 | 1086 | ||
1048 | if(status >= 0) | 1087 | if (status >= 0) { |
1049 | { | 1088 | /* Copy the data read back to main buffer */ |
1050 | /* Copy the data read back to main buffer */ | 1089 | if (data_len == 1) |
1051 | if(data_len == 1) | 1090 | *data = value[0]; |
1052 | *data = value[0]; | 1091 | else |
1053 | else | 1092 | *data = |
1054 | *data = value[0] | value[1] << 8 | value[2] << 16 | value[3] << 24; | 1093 | value[0] | value[1] << 8 | value[2] << 16 | value[3] |
1055 | } | 1094 | << 24; |
1056 | 1095 | } | |
1057 | return status; | 1096 | |
1097 | return status; | ||
1058 | } | 1098 | } |
1059 | 1099 | ||
1060 | int cx231xx_write_i2c_data(struct cx231xx *dev, u8 dev_addr, u16 saddr, | 1100 | int cx231xx_write_i2c_data(struct cx231xx *dev, u8 dev_addr, u16 saddr, |
1061 | u8 saddr_len, u32 data, u8 data_len) | 1101 | u8 saddr_len, u32 data, u8 data_len) |
1062 | { | 1102 | { |
1063 | int status = 0; | 1103 | int status = 0; |
1064 | u8 value[4] ={0,0,0,0}; | 1104 | u8 value[4] = { 0, 0, 0, 0 }; |
1065 | struct cx231xx_i2c_xfer_data req_data; | 1105 | struct cx231xx_i2c_xfer_data req_data; |
1066 | 1106 | ||
1067 | value[0]=(u8)data; | 1107 | value[0] = (u8) data; |
1068 | value[1]=(u8)(data>>8); | 1108 | value[1] = (u8) (data >> 8); |
1069 | value[2]=(u8)(data>>16); | 1109 | value[2] = (u8) (data >> 16); |
1070 | value[3]=(u8)(data>>24); | 1110 | value[3] = (u8) (data >> 24); |
1071 | 1111 | ||
1072 | if(saddr_len == 0) | 1112 | if (saddr_len == 0) |
1073 | saddr = 0; | 1113 | saddr = 0; |
1074 | else if(saddr_len == 0) | 1114 | else if (saddr_len == 0) |
1075 | saddr &= 0xff; | 1115 | saddr &= 0xff; |
1076 | 1116 | ||
1077 | /* prepare xfer_data struct */ | 1117 | /* prepare xfer_data struct */ |
1078 | req_data.dev_addr = dev_addr >> 1; | 1118 | req_data.dev_addr = dev_addr >> 1; |
1079 | req_data.direction = 0; | 1119 | req_data.direction = 0; |
1080 | req_data.saddr_len = saddr_len; | 1120 | req_data.saddr_len = saddr_len; |
1081 | req_data.saddr_dat = saddr; | 1121 | req_data.saddr_dat = saddr; |
1082 | req_data.buf_size = data_len; | 1122 | req_data.buf_size = data_len; |
1083 | req_data.p_buffer = value; | 1123 | req_data.p_buffer = value; |
1084 | 1124 | ||
1085 | /* usb send command */ | 1125 | /* usb send command */ |
1086 | status = dev->cx231xx_send_usb_command(&dev->i2c_bus[0], &req_data); | 1126 | status = dev->cx231xx_send_usb_command(&dev->i2c_bus[0], &req_data); |
1087 | 1127 | ||
1088 | return status; | 1128 | return status; |
1089 | } | 1129 | } |
1090 | 1130 | ||
1091 | int cx231xx_reg_mask_write(struct cx231xx *dev, u8 dev_addr, u8 size, u16 register_address, | 1131 | int cx231xx_reg_mask_write(struct cx231xx *dev, u8 dev_addr, u8 size, |
1092 | u8 bit_start,u8 bit_end, u32 value) | 1132 | u16 register_address, u8 bit_start, u8 bit_end, |
1133 | u32 value) | ||
1093 | { | 1134 | { |
1094 | int status = 0; | 1135 | int status = 0; |
1095 | u32 tmp; | 1136 | u32 tmp; |
1096 | u32 mask = 0; | 1137 | u32 mask = 0; |
1097 | int i; | 1138 | int i; |
1098 | 1139 | ||
1099 | if (bit_start>(size-1) || bit_end>(size-1)) { | 1140 | if (bit_start > (size - 1) || bit_end > (size - 1)) { |
1100 | return -1; | 1141 | return -1; |
1101 | } | 1142 | } |
1102 | |||
1103 | if (size==8){ | ||
1104 | status = cx231xx_read_i2c_data(dev, dev_addr, register_address, 2, &tmp, 1); | ||
1105 | } else { | ||
1106 | status = cx231xx_read_i2c_data(dev, dev_addr, register_address, 2, &tmp, 4); | ||
1107 | } | ||
1108 | |||
1109 | if (status < 0) { | ||
1110 | return status; | ||
1111 | } | ||
1112 | |||
1113 | mask = 1<<bit_end; | ||
1114 | for (i=bit_end; i>bit_start&&i>0; i--) { | ||
1115 | mask = mask + (1<<(i-1)); | ||
1116 | } | ||
1117 | |||
1118 | value <<= bit_start; | ||
1119 | |||
1120 | if (size==8) | ||
1121 | { | ||
1122 | tmp &= ~mask; | ||
1123 | tmp |= value; | ||
1124 | tmp &= 0xff; | ||
1125 | status = cx231xx_write_i2c_data(dev, dev_addr, register_address, 2, tmp, 1); | ||
1126 | } | ||
1127 | else | ||
1128 | { | ||
1129 | tmp &= ~mask; | ||
1130 | tmp |= value; | ||
1131 | status = cx231xx_write_i2c_data(dev, dev_addr, register_address, 2, tmp, 4); | ||
1132 | } | ||
1133 | |||
1134 | return status; | ||
1135 | } | ||
1136 | 1143 | ||
1144 | if (size == 8) { | ||
1145 | status = | ||
1146 | cx231xx_read_i2c_data(dev, dev_addr, register_address, 2, | ||
1147 | &tmp, 1); | ||
1148 | } else { | ||
1149 | status = | ||
1150 | cx231xx_read_i2c_data(dev, dev_addr, register_address, 2, | ||
1151 | &tmp, 4); | ||
1152 | } | ||
1137 | 1153 | ||
1154 | if (status < 0) { | ||
1155 | return status; | ||
1156 | } | ||
1157 | |||
1158 | mask = 1 << bit_end; | ||
1159 | for (i = bit_end; i > bit_start && i > 0; i--) { | ||
1160 | mask = mask + (1 << (i - 1)); | ||
1161 | } | ||
1162 | |||
1163 | value <<= bit_start; | ||
1164 | |||
1165 | if (size == 8) { | ||
1166 | tmp &= ~mask; | ||
1167 | tmp |= value; | ||
1168 | tmp &= 0xff; | ||
1169 | status = | ||
1170 | cx231xx_write_i2c_data(dev, dev_addr, register_address, 2, | ||
1171 | tmp, 1); | ||
1172 | } else { | ||
1173 | tmp &= ~mask; | ||
1174 | tmp |= value; | ||
1175 | status = | ||
1176 | cx231xx_write_i2c_data(dev, dev_addr, register_address, 2, | ||
1177 | tmp, 4); | ||
1178 | } | ||
1179 | |||
1180 | return status; | ||
1181 | } | ||
1138 | 1182 | ||
1139 | int cx231xx_read_modify_write_i2c_dword(struct cx231xx *dev, u8 dev_addr, | 1183 | int cx231xx_read_modify_write_i2c_dword(struct cx231xx *dev, u8 dev_addr, |
1140 | u16 saddr, u32 mask, u32 value) | 1184 | u16 saddr, u32 mask, u32 value) |
1141 | { | 1185 | { |
1142 | u32 temp; | 1186 | u32 temp; |
1143 | int status = 0; | 1187 | int status = 0; |
1144 | 1188 | ||
1145 | status = cx231xx_read_i2c_data(dev, dev_addr, saddr, 2, &temp, 4); | 1189 | status = cx231xx_read_i2c_data(dev, dev_addr, saddr, 2, &temp, 4); |
1146 | 1190 | ||
1147 | if(status < 0) | 1191 | if (status < 0) |
1148 | return status; | 1192 | return status; |
1149 | 1193 | ||
1150 | temp &= ~mask; | 1194 | temp &= ~mask; |
1151 | temp |= value; | 1195 | temp |= value; |
1152 | 1196 | ||
1153 | status = cx231xx_write_i2c_data(dev, dev_addr, saddr, 2, temp, 4); | 1197 | status = cx231xx_write_i2c_data(dev, dev_addr, saddr, 2, temp, 4); |
1154 | 1198 | ||
1155 | return status; | 1199 | return status; |
1156 | } | 1200 | } |
1157 | 1201 | ||
1158 | u32 cx231xx_set_field(u32 field_mask, u32 data) | 1202 | u32 cx231xx_set_field(u32 field_mask, u32 data) |
1159 | { | 1203 | { |
1160 | u32 temp; | 1204 | u32 temp; |
1161 | 1205 | ||
1162 | for (temp = field_mask; (temp & 1) == 0; temp >>= 1) { | 1206 | for (temp = field_mask; (temp & 1) == 0; temp >>= 1) { |
1163 | data <<= 1; | 1207 | data <<= 1; |
1164 | } | 1208 | } |
1165 | 1209 | ||
1166 | return data; | 1210 | return data; |
1167 | } | 1211 | } |
diff --git a/drivers/media/video/cx231xx/cx231xx-dvb.c b/drivers/media/video/cx231xx/cx231xx-dvb.c index 46bdcecb4055..85bee8c35e0e 100644 --- a/drivers/media/video/cx231xx/cx231xx-dvb.c +++ b/drivers/media/video/cx231xx/cx231xx-dvb.c | |||
@@ -2,7 +2,7 @@ | |||
2 | DVB device driver for cx231xx | 2 | DVB device driver for cx231xx |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on em28xx driver | 5 | Based on em28xx driver |
6 | 6 | ||
7 | This program is free software; you can redistribute it and/or modify | 7 | This program is free software; you can redistribute it and/or modify |
8 | it under the terms of the GNU General Public License as published by | 8 | it under the terms of the GNU General Public License as published by |
@@ -29,7 +29,6 @@ | |||
29 | #include "xc5000.h" | 29 | #include "xc5000.h" |
30 | #include "dvb_dummy_fe.h" | 30 | #include "dvb_dummy_fe.h" |
31 | 31 | ||
32 | |||
33 | MODULE_DESCRIPTION("driver for cx231xx based DVB cards"); | 32 | MODULE_DESCRIPTION("driver for cx231xx based DVB cards"); |
34 | MODULE_AUTHOR("Srinivasa Deevi <srinivasa.deevi@conexant.com>"); | 33 | MODULE_AUTHOR("Srinivasa Deevi <srinivasa.deevi@conexant.com>"); |
35 | MODULE_LICENSE("GPL"); | 34 | MODULE_LICENSE("GPL"); |
@@ -50,24 +49,22 @@ if (debug >= level) \ | |||
50 | #define CX231XX_DVB_MAX_PACKETS 64 | 49 | #define CX231XX_DVB_MAX_PACKETS 64 |
51 | 50 | ||
52 | struct cx231xx_dvb { | 51 | struct cx231xx_dvb { |
53 | struct dvb_frontend *frontend; | 52 | struct dvb_frontend *frontend; |
54 | 53 | ||
55 | /* feed count management */ | 54 | /* feed count management */ |
56 | struct mutex lock; | 55 | struct mutex lock; |
57 | int nfeeds; | 56 | int nfeeds; |
58 | 57 | ||
59 | /* general boilerplate stuff */ | 58 | /* general boilerplate stuff */ |
60 | struct dvb_adapter adapter; | 59 | struct dvb_adapter adapter; |
61 | struct dvb_demux demux; | 60 | struct dvb_demux demux; |
62 | struct dmxdev dmxdev; | 61 | struct dmxdev dmxdev; |
63 | struct dmx_frontend fe_hw; | 62 | struct dmx_frontend fe_hw; |
64 | struct dmx_frontend fe_mem; | 63 | struct dmx_frontend fe_mem; |
65 | struct dvb_net net; | 64 | struct dvb_net net; |
66 | }; | 65 | }; |
67 | 66 | ||
68 | 67 | static inline void print_err_status(struct cx231xx *dev, int packet, int status) | |
69 | static inline void print_err_status(struct cx231xx *dev, | ||
70 | int packet, int status) | ||
71 | { | 68 | { |
72 | char *errmsg = "Unknown"; | 69 | char *errmsg = "Unknown"; |
73 | 70 | ||
@@ -149,8 +146,8 @@ static int start_streaming(struct cx231xx_dvb *dvb) | |||
149 | return rc; | 146 | return rc; |
150 | 147 | ||
151 | return cx231xx_init_isoc(dev, CX231XX_DVB_MAX_PACKETS, | 148 | return cx231xx_init_isoc(dev, CX231XX_DVB_MAX_PACKETS, |
152 | CX231XX_DVB_NUM_BUFS, CX231XX_DVB_MAX_PACKETSIZE, | 149 | CX231XX_DVB_NUM_BUFS, |
153 | dvb_isoc_copy); | 150 | CX231XX_DVB_MAX_PACKETSIZE, dvb_isoc_copy); |
154 | } | 151 | } |
155 | 152 | ||
156 | static int stop_streaming(struct cx231xx_dvb *dvb) | 153 | static int stop_streaming(struct cx231xx_dvb *dvb) |
@@ -166,7 +163,7 @@ static int stop_streaming(struct cx231xx_dvb *dvb) | |||
166 | 163 | ||
167 | static int start_feed(struct dvb_demux_feed *feed) | 164 | static int start_feed(struct dvb_demux_feed *feed) |
168 | { | 165 | { |
169 | struct dvb_demux *demux = feed->demux; | 166 | struct dvb_demux *demux = feed->demux; |
170 | struct cx231xx_dvb *dvb = demux->priv; | 167 | struct cx231xx_dvb *dvb = demux->priv; |
171 | int rc, ret; | 168 | int rc, ret; |
172 | 169 | ||
@@ -189,7 +186,7 @@ static int start_feed(struct dvb_demux_feed *feed) | |||
189 | 186 | ||
190 | static int stop_feed(struct dvb_demux_feed *feed) | 187 | static int stop_feed(struct dvb_demux_feed *feed) |
191 | { | 188 | { |
192 | struct dvb_demux *demux = feed->demux; | 189 | struct dvb_demux *demux = feed->demux; |
193 | struct cx231xx_dvb *dvb = demux->priv; | 190 | struct cx231xx_dvb *dvb = demux->priv; |
194 | int err = 0; | 191 | int err = 0; |
195 | 192 | ||
@@ -203,8 +200,6 @@ static int stop_feed(struct dvb_demux_feed *feed) | |||
203 | return err; | 200 | return err; |
204 | } | 201 | } |
205 | 202 | ||
206 | |||
207 | |||
208 | /* ------------------------------------------------------------------ */ | 203 | /* ------------------------------------------------------------------ */ |
209 | static int cx231xx_dvb_bus_ctrl(struct dvb_frontend *fe, int acquire) | 204 | static int cx231xx_dvb_bus_ctrl(struct dvb_frontend *fe, int acquire) |
210 | { | 205 | { |
@@ -218,13 +213,11 @@ static int cx231xx_dvb_bus_ctrl(struct dvb_frontend *fe, int acquire) | |||
218 | 213 | ||
219 | /* ------------------------------------------------------------------ */ | 214 | /* ------------------------------------------------------------------ */ |
220 | 215 | ||
221 | |||
222 | static struct xc5000_config cnxt_rde250_tunerconfig = { | 216 | static struct xc5000_config cnxt_rde250_tunerconfig = { |
223 | .i2c_address = 0x61, | 217 | .i2c_address = 0x61, |
224 | .if_khz = 5380, | 218 | .if_khz = 5380, |
225 | }; | 219 | }; |
226 | 220 | ||
227 | |||
228 | /* ------------------------------------------------------------------ */ | 221 | /* ------------------------------------------------------------------ */ |
229 | #if 0 | 222 | #if 0 |
230 | static int attach_xc5000(u8 addr, struct cx231xx *dev) | 223 | static int attach_xc5000(u8 addr, struct cx231xx *dev) |
@@ -234,13 +227,12 @@ static int attach_xc5000(u8 addr, struct cx231xx *dev) | |||
234 | struct xc5000_config cfg; | 227 | struct xc5000_config cfg; |
235 | 228 | ||
236 | memset(&cfg, 0, sizeof(cfg)); | 229 | memset(&cfg, 0, sizeof(cfg)); |
237 | cfg.i2c_adap = &dev->i2c_bus[1].i2c_adap; | 230 | cfg.i2c_adap = &dev->i2c_bus[1].i2c_adap; |
238 | cfg.i2c_addr = addr; | 231 | cfg.i2c_addr = addr; |
239 | 232 | ||
240 | if (!dev->dvb->frontend) { | 233 | if (!dev->dvb->frontend) { |
241 | printk(KERN_ERR "%s/2: dvb frontend not attached. " | 234 | printk(KERN_ERR "%s/2: dvb frontend not attached. " |
242 | "Can't attach xc5000\n", | 235 | "Can't attach xc5000\n", dev->name); |
243 | dev->name); | ||
244 | return -EINVAL; | 236 | return -EINVAL; |
245 | } | 237 | } |
246 | 238 | ||
@@ -258,65 +250,65 @@ static int attach_xc5000(u8 addr, struct cx231xx *dev) | |||
258 | } | 250 | } |
259 | #endif | 251 | #endif |
260 | 252 | ||
261 | int cx231xx_set_analog_freq(struct cx231xx *dev, u32 freq ) | 253 | int cx231xx_set_analog_freq(struct cx231xx *dev, u32 freq) |
262 | { | 254 | { |
263 | int status = 0; | 255 | int status = 0; |
264 | 256 | ||
265 | if( (dev->dvb != NULL) && (dev->dvb->frontend != NULL) ){ | 257 | if ((dev->dvb != NULL) && (dev->dvb->frontend != NULL)) { |
266 | 258 | ||
267 | struct dvb_tuner_ops *dops = &dev->dvb->frontend->ops.tuner_ops; | 259 | struct dvb_tuner_ops *dops = &dev->dvb->frontend->ops.tuner_ops; |
268 | 260 | ||
269 | if(dops->set_analog_params != NULL) { | 261 | if (dops->set_analog_params != NULL) { |
270 | struct analog_parameters params; | 262 | struct analog_parameters params; |
271 | 263 | ||
272 | params.frequency = freq; | 264 | params.frequency = freq; |
273 | params.std = dev->norm; | 265 | params.std = dev->norm; |
274 | params.mode = 0 ; /* 0- Air; 1 - cable */ | 266 | params.mode = 0; /* 0- Air; 1 - cable */ |
275 | /*params.audmode = ; */ | 267 | /*params.audmode = ; */ |
276 | |||
277 | /* Set the analog parameters to set the frequency */ | ||
278 | cx231xx_info("Setting Frequency for XC5000\n"); | ||
279 | dops->set_analog_params(dev->dvb->frontend, ¶ms); | ||
280 | } | ||
281 | 268 | ||
269 | /* Set the analog parameters to set the frequency */ | ||
270 | cx231xx_info("Setting Frequency for XC5000\n"); | ||
271 | dops->set_analog_params(dev->dvb->frontend, ¶ms); | ||
282 | } | 272 | } |
283 | 273 | ||
274 | } | ||
275 | |||
284 | return status; | 276 | return status; |
285 | } | 277 | } |
286 | 278 | ||
287 | int cx231xx_reset_analog_tuner(struct cx231xx *dev) | 279 | int cx231xx_reset_analog_tuner(struct cx231xx *dev) |
288 | { | 280 | { |
289 | int status = 0; | 281 | int status = 0; |
290 | 282 | ||
291 | if( (dev->dvb != NULL) && (dev->dvb->frontend != NULL) ){ | 283 | if ((dev->dvb != NULL) && (dev->dvb->frontend != NULL)) { |
292 | 284 | ||
293 | struct dvb_tuner_ops *dops = &dev->dvb->frontend->ops.tuner_ops; | 285 | struct dvb_tuner_ops *dops = &dev->dvb->frontend->ops.tuner_ops; |
294 | 286 | ||
295 | if(dops->init != NULL && !dev->xc_fw_load_done) { | 287 | if (dops->init != NULL && !dev->xc_fw_load_done) { |
296 | 288 | ||
297 | cx231xx_info("Reloading firmware for XC5000\n"); | 289 | cx231xx_info("Reloading firmware for XC5000\n"); |
298 | status = dops->init(dev->dvb->frontend); | 290 | status = dops->init(dev->dvb->frontend); |
299 | if(status == 0 ) { | 291 | if (status == 0) { |
300 | dev->xc_fw_load_done = 1; | 292 | dev->xc_fw_load_done = 1; |
301 | cx231xx_info("XC5000 firmware download completed\n"); | 293 | cx231xx_info |
302 | } else { | 294 | ("XC5000 firmware download completed\n"); |
303 | dev->xc_fw_load_done = 0; | 295 | } else { |
304 | cx231xx_info("XC5000 firmware download failed !!!\n"); | 296 | dev->xc_fw_load_done = 0; |
305 | } | 297 | cx231xx_info |
298 | ("XC5000 firmware download failed !!!\n"); | ||
306 | } | 299 | } |
307 | |||
308 | } | 300 | } |
309 | 301 | ||
302 | } | ||
303 | |||
310 | return status; | 304 | return status; |
311 | } | 305 | } |
312 | 306 | ||
313 | |||
314 | /* ------------------------------------------------------------------ */ | 307 | /* ------------------------------------------------------------------ */ |
315 | 308 | ||
316 | static int register_dvb(struct cx231xx_dvb *dvb, | 309 | static int register_dvb(struct cx231xx_dvb *dvb, |
317 | struct module *module, | 310 | struct module *module, |
318 | struct cx231xx *dev, | 311 | struct cx231xx *dev, struct device *device) |
319 | struct device *device) | ||
320 | { | 312 | { |
321 | int result; | 313 | int result; |
322 | 314 | ||
@@ -326,7 +318,8 @@ static int register_dvb(struct cx231xx_dvb *dvb, | |||
326 | result = dvb_register_adapter(&dvb->adapter, dev->name, module, device, | 318 | result = dvb_register_adapter(&dvb->adapter, dev->name, module, device, |
327 | adapter_nr); | 319 | adapter_nr); |
328 | if (result < 0) { | 320 | if (result < 0) { |
329 | printk(KERN_WARNING "%s: dvb_register_adapter failed (errno = %d)\n", | 321 | printk(KERN_WARNING |
322 | "%s: dvb_register_adapter failed (errno = %d)\n", | ||
330 | dev->name, result); | 323 | dev->name, result); |
331 | goto fail_adapter; | 324 | goto fail_adapter; |
332 | } | 325 | } |
@@ -339,20 +332,21 @@ static int register_dvb(struct cx231xx_dvb *dvb, | |||
339 | /* register frontend */ | 332 | /* register frontend */ |
340 | result = dvb_register_frontend(&dvb->adapter, dvb->frontend); | 333 | result = dvb_register_frontend(&dvb->adapter, dvb->frontend); |
341 | if (result < 0) { | 334 | if (result < 0) { |
342 | printk(KERN_WARNING "%s: dvb_register_frontend failed (errno = %d)\n", | 335 | printk(KERN_WARNING |
336 | "%s: dvb_register_frontend failed (errno = %d)\n", | ||
343 | dev->name, result); | 337 | dev->name, result); |
344 | goto fail_frontend; | 338 | goto fail_frontend; |
345 | } | 339 | } |
346 | 340 | ||
347 | /* register demux stuff */ | 341 | /* register demux stuff */ |
348 | dvb->demux.dmx.capabilities = | 342 | dvb->demux.dmx.capabilities = |
349 | DMX_TS_FILTERING | DMX_SECTION_FILTERING | | 343 | DMX_TS_FILTERING | DMX_SECTION_FILTERING | |
350 | DMX_MEMORY_BASED_FILTERING; | 344 | DMX_MEMORY_BASED_FILTERING; |
351 | dvb->demux.priv = dvb; | 345 | dvb->demux.priv = dvb; |
352 | dvb->demux.filternum = 256; | 346 | dvb->demux.filternum = 256; |
353 | dvb->demux.feednum = 256; | 347 | dvb->demux.feednum = 256; |
354 | dvb->demux.start_feed = start_feed; | 348 | dvb->demux.start_feed = start_feed; |
355 | dvb->demux.stop_feed = stop_feed; | 349 | dvb->demux.stop_feed = stop_feed; |
356 | 350 | ||
357 | result = dvb_dmx_init(&dvb->demux); | 351 | result = dvb_dmx_init(&dvb->demux); |
358 | if (result < 0) { | 352 | if (result < 0) { |
@@ -361,8 +355,8 @@ static int register_dvb(struct cx231xx_dvb *dvb, | |||
361 | goto fail_dmx; | 355 | goto fail_dmx; |
362 | } | 356 | } |
363 | 357 | ||
364 | dvb->dmxdev.filternum = 256; | 358 | dvb->dmxdev.filternum = 256; |
365 | dvb->dmxdev.demux = &dvb->demux.dmx; | 359 | dvb->dmxdev.demux = &dvb->demux.dmx; |
366 | dvb->dmxdev.capabilities = 0; | 360 | dvb->dmxdev.capabilities = 0; |
367 | result = dvb_dmxdev_init(&dvb->dmxdev, &dvb->adapter); | 361 | result = dvb_dmxdev_init(&dvb->dmxdev, &dvb->adapter); |
368 | if (result < 0) { | 362 | if (result < 0) { |
@@ -374,7 +368,8 @@ static int register_dvb(struct cx231xx_dvb *dvb, | |||
374 | dvb->fe_hw.source = DMX_FRONTEND_0; | 368 | dvb->fe_hw.source = DMX_FRONTEND_0; |
375 | result = dvb->demux.dmx.add_frontend(&dvb->demux.dmx, &dvb->fe_hw); | 369 | result = dvb->demux.dmx.add_frontend(&dvb->demux.dmx, &dvb->fe_hw); |
376 | if (result < 0) { | 370 | if (result < 0) { |
377 | printk(KERN_WARNING "%s: add_frontend failed (DMX_FRONTEND_0, errno = %d)\n", | 371 | printk(KERN_WARNING |
372 | "%s: add_frontend failed (DMX_FRONTEND_0, errno = %d)\n", | ||
378 | dev->name, result); | 373 | dev->name, result); |
379 | goto fail_fe_hw; | 374 | goto fail_fe_hw; |
380 | } | 375 | } |
@@ -382,15 +377,17 @@ static int register_dvb(struct cx231xx_dvb *dvb, | |||
382 | dvb->fe_mem.source = DMX_MEMORY_FE; | 377 | dvb->fe_mem.source = DMX_MEMORY_FE; |
383 | result = dvb->demux.dmx.add_frontend(&dvb->demux.dmx, &dvb->fe_mem); | 378 | result = dvb->demux.dmx.add_frontend(&dvb->demux.dmx, &dvb->fe_mem); |
384 | if (result < 0) { | 379 | if (result < 0) { |
385 | printk(KERN_WARNING "%s: add_frontend failed (DMX_MEMORY_FE, errno = %d)\n", | 380 | printk(KERN_WARNING |
381 | "%s: add_frontend failed (DMX_MEMORY_FE, errno = %d)\n", | ||
386 | dev->name, result); | 382 | dev->name, result); |
387 | goto fail_fe_mem; | 383 | goto fail_fe_mem; |
388 | } | 384 | } |
389 | 385 | ||
390 | result = dvb->demux.dmx.connect_frontend(&dvb->demux.dmx, &dvb->fe_hw); | 386 | result = dvb->demux.dmx.connect_frontend(&dvb->demux.dmx, &dvb->fe_hw); |
391 | if (result < 0) { | 387 | if (result < 0) { |
392 | printk(KERN_WARNING "%s: connect_frontend failed (errno = %d)\n", | 388 | printk(KERN_WARNING |
393 | dev->name, result); | 389 | "%s: connect_frontend failed (errno = %d)\n", dev->name, |
390 | result); | ||
394 | goto fail_fe_conn; | 391 | goto fail_fe_conn; |
395 | } | 392 | } |
396 | 393 | ||
@@ -398,20 +395,20 @@ static int register_dvb(struct cx231xx_dvb *dvb, | |||
398 | dvb_net_init(&dvb->adapter, &dvb->net, &dvb->demux.dmx); | 395 | dvb_net_init(&dvb->adapter, &dvb->net, &dvb->demux.dmx); |
399 | return 0; | 396 | return 0; |
400 | 397 | ||
401 | fail_fe_conn: | 398 | fail_fe_conn: |
402 | dvb->demux.dmx.remove_frontend(&dvb->demux.dmx, &dvb->fe_mem); | 399 | dvb->demux.dmx.remove_frontend(&dvb->demux.dmx, &dvb->fe_mem); |
403 | fail_fe_mem: | 400 | fail_fe_mem: |
404 | dvb->demux.dmx.remove_frontend(&dvb->demux.dmx, &dvb->fe_hw); | 401 | dvb->demux.dmx.remove_frontend(&dvb->demux.dmx, &dvb->fe_hw); |
405 | fail_fe_hw: | 402 | fail_fe_hw: |
406 | dvb_dmxdev_release(&dvb->dmxdev); | 403 | dvb_dmxdev_release(&dvb->dmxdev); |
407 | fail_dmxdev: | 404 | fail_dmxdev: |
408 | dvb_dmx_release(&dvb->demux); | 405 | dvb_dmx_release(&dvb->demux); |
409 | fail_dmx: | 406 | fail_dmx: |
410 | dvb_unregister_frontend(dvb->frontend); | 407 | dvb_unregister_frontend(dvb->frontend); |
411 | fail_frontend: | 408 | fail_frontend: |
412 | dvb_frontend_detach(dvb->frontend); | 409 | dvb_frontend_detach(dvb->frontend); |
413 | dvb_unregister_adapter(&dvb->adapter); | 410 | dvb_unregister_adapter(&dvb->adapter); |
414 | fail_adapter: | 411 | fail_adapter: |
415 | return result; | 412 | return result; |
416 | } | 413 | } |
417 | 414 | ||
@@ -427,7 +424,6 @@ static void unregister_dvb(struct cx231xx_dvb *dvb) | |||
427 | dvb_unregister_adapter(&dvb->adapter); | 424 | dvb_unregister_adapter(&dvb->adapter); |
428 | } | 425 | } |
429 | 426 | ||
430 | |||
431 | static int dvb_init(struct cx231xx *dev) | 427 | static int dvb_init(struct cx231xx *dev) |
432 | { | 428 | { |
433 | int result = 0; | 429 | int result = 0; |
@@ -446,71 +442,70 @@ static int dvb_init(struct cx231xx *dev) | |||
446 | } | 442 | } |
447 | dev->dvb = dvb; | 443 | dev->dvb = dvb; |
448 | dev->cx231xx_set_analog_freq = cx231xx_set_analog_freq; | 444 | dev->cx231xx_set_analog_freq = cx231xx_set_analog_freq; |
449 | dev->cx231xx_reset_analog_tuner = cx231xx_reset_analog_tuner; | 445 | dev->cx231xx_reset_analog_tuner = cx231xx_reset_analog_tuner; |
450 | 446 | ||
451 | cx231xx_set_mode(dev, CX231XX_DIGITAL_MODE); | 447 | cx231xx_set_mode(dev, CX231XX_DIGITAL_MODE); |
452 | /* init frontend */ | 448 | /* init frontend */ |
453 | switch (dev->model) { | 449 | switch (dev->model) { |
454 | case CX231XX_BOARD_CNXT_RDE_250: | 450 | case CX231XX_BOARD_CNXT_RDE_250: |
455 | 451 | ||
456 | /* dev->dvb->frontend = dvb_attach(s5h1411_attach, | 452 | /* dev->dvb->frontend = dvb_attach(s5h1411_attach, |
457 | &dvico_s5h1411_config, | 453 | &dvico_s5h1411_config, |
458 | &dev->i2c_bus[1].i2c_adap);*/ | 454 | &dev->i2c_bus[1].i2c_adap); */ |
459 | dev->dvb->frontend = dvb_attach(dvb_dummy_fe_ofdm_attach); | 455 | dev->dvb->frontend = dvb_attach(dvb_dummy_fe_ofdm_attach); |
460 | 456 | ||
461 | if(dev->dvb->frontend == NULL) { | 457 | if (dev->dvb->frontend == NULL) { |
462 | printk(DRIVER_NAME ": Failed to attach dummy front end\n"); | 458 | printk(DRIVER_NAME |
463 | result = -EINVAL; | 459 | ": Failed to attach dummy front end\n"); |
464 | goto out_free; | 460 | result = -EINVAL; |
465 | } | 461 | goto out_free; |
466 | 462 | } | |
467 | /* define general-purpose callback pointer */ | 463 | |
468 | dvb->frontend->callback = cx231xx_tuner_callback; | 464 | /* define general-purpose callback pointer */ |
469 | 465 | dvb->frontend->callback = cx231xx_tuner_callback; | |
470 | if(dvb_attach(xc5000_attach, dev->dvb->frontend, | 466 | |
471 | &dev->i2c_bus[1].i2c_adap, | 467 | if (dvb_attach(xc5000_attach, dev->dvb->frontend, |
472 | &cnxt_rde250_tunerconfig) < 0) { | 468 | &dev->i2c_bus[1].i2c_adap, |
473 | result = -EINVAL; | 469 | &cnxt_rde250_tunerconfig) < 0) { |
474 | goto out_free; | 470 | result = -EINVAL; |
475 | } | 471 | goto out_free; |
476 | 472 | } | |
477 | break; | 473 | |
478 | case CX231XX_BOARD_CNXT_RDU_250: | 474 | break; |
479 | 475 | case CX231XX_BOARD_CNXT_RDU_250: | |
480 | dev->dvb->frontend = dvb_attach(dvb_dummy_fe_ofdm_attach); | 476 | |
481 | 477 | dev->dvb->frontend = dvb_attach(dvb_dummy_fe_ofdm_attach); | |
482 | if(dev->dvb->frontend == NULL) { | 478 | |
483 | printk(DRIVER_NAME ": Failed to attach dummy front end\n"); | 479 | if (dev->dvb->frontend == NULL) { |
484 | result = -EINVAL; | 480 | printk(DRIVER_NAME |
485 | goto out_free; | 481 | ": Failed to attach dummy front end\n"); |
486 | } | 482 | result = -EINVAL; |
487 | 483 | goto out_free; | |
488 | /* define general-purpose callback pointer */ | 484 | } |
489 | dvb->frontend->callback = cx231xx_tuner_callback; | 485 | |
490 | 486 | /* define general-purpose callback pointer */ | |
491 | if(dvb_attach(xc5000_attach, dev->dvb->frontend, | 487 | dvb->frontend->callback = cx231xx_tuner_callback; |
492 | &dev->i2c_bus[1].i2c_adap, | 488 | |
493 | &cnxt_rde250_tunerconfig) < 0) { | 489 | if (dvb_attach(xc5000_attach, dev->dvb->frontend, |
494 | result = -EINVAL; | 490 | &dev->i2c_bus[1].i2c_adap, |
495 | goto out_free; | 491 | &cnxt_rde250_tunerconfig) < 0) { |
496 | } | 492 | result = -EINVAL; |
497 | break; | 493 | goto out_free; |
494 | } | ||
495 | break; | ||
498 | 496 | ||
499 | default: | 497 | default: |
500 | printk(KERN_ERR "%s/2: The frontend of your DVB/ATSC card" | 498 | printk(KERN_ERR "%s/2: The frontend of your DVB/ATSC card" |
501 | " isn't supported yet\n", | 499 | " isn't supported yet\n", dev->name); |
502 | dev->name); | ||
503 | break; | 500 | break; |
504 | } | 501 | } |
505 | if (NULL == dvb->frontend) { | 502 | if (NULL == dvb->frontend) { |
506 | printk(KERN_ERR | 503 | printk(KERN_ERR |
507 | "%s/2: frontend initialization failed\n", | 504 | "%s/2: frontend initialization failed\n", dev->name); |
508 | dev->name); | ||
509 | result = -EINVAL; | 505 | result = -EINVAL; |
510 | goto out_free; | 506 | goto out_free; |
511 | } | 507 | } |
512 | 508 | ||
513 | |||
514 | /* register everything */ | 509 | /* register everything */ |
515 | result = register_dvb(dvb, THIS_MODULE, dev, &dev->udev->dev); | 510 | result = register_dvb(dvb, THIS_MODULE, dev, &dev->udev->dev); |
516 | 511 | ||
@@ -521,7 +516,7 @@ static int dvb_init(struct cx231xx *dev) | |||
521 | printk(KERN_INFO "Successfully loaded cx231xx-dvb\n"); | 516 | printk(KERN_INFO "Successfully loaded cx231xx-dvb\n"); |
522 | return 0; | 517 | return 0; |
523 | 518 | ||
524 | out_free: | 519 | out_free: |
525 | cx231xx_set_mode(dev, CX231XX_SUSPEND); | 520 | cx231xx_set_mode(dev, CX231XX_SUSPEND); |
526 | kfree(dvb); | 521 | kfree(dvb); |
527 | dev->dvb = NULL; | 522 | dev->dvb = NULL; |
@@ -544,7 +539,7 @@ static int dvb_fini(struct cx231xx *dev) | |||
544 | } | 539 | } |
545 | 540 | ||
546 | static struct cx231xx_ops dvb_ops = { | 541 | static struct cx231xx_ops dvb_ops = { |
547 | .id = CX231XX_DVB, | 542 | .id = CX231XX_DVB, |
548 | .name = "Cx231xx dvb Extension", | 543 | .name = "Cx231xx dvb Extension", |
549 | .init = dvb_init, | 544 | .init = dvb_init, |
550 | .fini = dvb_fini, | 545 | .fini = dvb_fini, |
@@ -562,4 +557,3 @@ static void __exit cx231xx_dvb_unregister(void) | |||
562 | 557 | ||
563 | module_init(cx231xx_dvb_register); | 558 | module_init(cx231xx_dvb_register); |
564 | module_exit(cx231xx_dvb_unregister); | 559 | module_exit(cx231xx_dvb_unregister); |
565 | |||
diff --git a/drivers/media/video/cx231xx/cx231xx-i2c.c b/drivers/media/video/cx231xx/cx231xx-i2c.c index d75ed6c3c8d7..c250ad27e1d2 100644 --- a/drivers/media/video/cx231xx/cx231xx-i2c.c +++ b/drivers/media/video/cx231xx/cx231xx-i2c.c | |||
@@ -2,8 +2,8 @@ | |||
2 | cx231xx-i2c.c - driver for Conexant Cx23100/101/102 USB video capture devices | 2 | cx231xx-i2c.c - driver for Conexant Cx23100/101/102 USB video capture devices |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on em28xx driver | 5 | Based on em28xx driver |
6 | Based on Cx23885 driver | 6 | Based on Cx23885 driver |
7 | 7 | ||
8 | This program is free software; you can redistribute it and/or modify | 8 | This program is free software; you can redistribute it and/or modify |
9 | it under the terms of the GNU General Public License as published by | 9 | it under the terms of the GNU General Public License as published by |
@@ -29,7 +29,6 @@ | |||
29 | 29 | ||
30 | #include "cx231xx.h" | 30 | #include "cx231xx.h" |
31 | 31 | ||
32 | |||
33 | /* ----------------------------------------------------------- */ | 32 | /* ----------------------------------------------------------- */ |
34 | 33 | ||
35 | static unsigned int i2c_scan; | 34 | static unsigned int i2c_scan; |
@@ -40,7 +39,6 @@ static unsigned int i2c_debug; | |||
40 | module_param(i2c_debug, int, 0644); | 39 | module_param(i2c_debug, int, 0644); |
41 | MODULE_PARM_DESC(i2c_debug, "enable debug messages [i2c]"); | 40 | MODULE_PARM_DESC(i2c_debug, "enable debug messages [i2c]"); |
42 | 41 | ||
43 | |||
44 | #define dprintk1(lvl, fmt, args...) \ | 42 | #define dprintk1(lvl, fmt, args...) \ |
45 | do { \ | 43 | do { \ |
46 | if (i2c_debug >= lvl) { \ | 44 | if (i2c_debug >= lvl) { \ |
@@ -56,116 +54,119 @@ do { \ | |||
56 | } \ | 54 | } \ |
57 | } while (0) | 55 | } while (0) |
58 | 56 | ||
59 | |||
60 | /* | 57 | /* |
61 | * cx231xx_i2c_send_bytes() | 58 | * cx231xx_i2c_send_bytes() |
62 | */ | 59 | */ |
63 | int cx231xx_i2c_send_bytes(struct i2c_adapter *i2c_adap, | 60 | int cx231xx_i2c_send_bytes(struct i2c_adapter *i2c_adap, |
64 | const struct i2c_msg *msg) | 61 | const struct i2c_msg *msg) |
65 | { | 62 | { |
66 | struct cx231xx_i2c *bus = i2c_adap->algo_data; | 63 | struct cx231xx_i2c *bus = i2c_adap->algo_data; |
67 | struct cx231xx *dev = bus->dev; | 64 | struct cx231xx *dev = bus->dev; |
68 | struct cx231xx_i2c_xfer_data req_data; | 65 | struct cx231xx_i2c_xfer_data req_data; |
69 | int status = 0; | 66 | int status = 0; |
70 | u16 size = 0; | 67 | u16 size = 0; |
71 | u8 loop = 0; | 68 | u8 loop = 0; |
72 | u8 saddr_len = 1; | 69 | u8 saddr_len = 1; |
73 | u8 *buf_ptr = NULL; | 70 | u8 *buf_ptr = NULL; |
74 | u16 saddr = 0; | 71 | u16 saddr = 0; |
75 | u8 need_gpio = 0; | 72 | u8 need_gpio = 0; |
76 | 73 | ||
77 | 74 | if ((bus->nr == 1) && (msg->addr == 0x61) | |
78 | if( (bus->nr ==1) && (msg->addr == 0x61) && (dev->tuner_type == TUNER_XC5000) ) { | 75 | && (dev->tuner_type == TUNER_XC5000)) { |
79 | 76 | ||
80 | size = msg->len; | 77 | size = msg->len; |
81 | 78 | ||
82 | if( size == 2 ) { /* register write sub addr*/ | 79 | if (size == 2) { /* register write sub addr */ |
83 | 80 | ||
84 | /* Just writing sub address will cause problem to XC5000 | 81 | /* Just writing sub address will cause problem to XC5000 |
85 | So ignore the request */ | 82 | So ignore the request */ |
86 | return 0; | 83 | return 0; |
87 | 84 | ||
88 | } else if( size == 4 ) { /* register write with sub addr*/ | 85 | } else if (size == 4) { /* register write with sub addr */ |
89 | 86 | ||
90 | if(msg->len >= 2 ) | 87 | if (msg->len >= 2) |
91 | saddr = msg->buf[0] << 8 | msg->buf[1]; | 88 | saddr = msg->buf[0] << 8 | msg->buf[1]; |
92 | else if ( msg->len == 1 ) | 89 | else if (msg->len == 1) |
93 | saddr = msg->buf[0]; | 90 | saddr = msg->buf[0]; |
94 | 91 | ||
95 | switch(saddr) { | 92 | switch (saddr) { |
96 | case 0x0000: /* start tuner calibration mode */ | 93 | case 0x0000: /* start tuner calibration mode */ |
97 | need_gpio = 1; | 94 | need_gpio = 1; |
98 | dev->xc_fw_load_done = 1; /* FW Loading is done */ | 95 | dev->xc_fw_load_done = 1; /* FW Loading is done */ |
99 | break; | 96 | break; |
100 | case 0x000D: /* Set signal source */ | 97 | case 0x000D: /* Set signal source */ |
101 | case 0x0001: /* Set TV standard - Video */ | 98 | case 0x0001: /* Set TV standard - Video */ |
102 | case 0x0002: /* Set TV standard - Audio */ | 99 | case 0x0002: /* Set TV standard - Audio */ |
103 | case 0x0003: /* Set RF Frequency */ | 100 | case 0x0003: /* Set RF Frequency */ |
104 | need_gpio = 1; | 101 | need_gpio = 1; |
105 | break; | 102 | break; |
106 | default: | 103 | default: |
107 | if(dev->xc_fw_load_done) | 104 | if (dev->xc_fw_load_done) |
108 | need_gpio = 1; | 105 | need_gpio = 1; |
109 | break; | 106 | break; |
110 | } | 107 | } |
111 | 108 | ||
112 | if(need_gpio ) { | 109 | if (need_gpio) { |
113 | dprintk1(1, " GPIO W R I T E : addr 0x%x, len %d, saddr 0x%x\n", | 110 | dprintk1(1, |
114 | msg->addr, msg->len, saddr); | 111 | " GPIO W R I T E : addr 0x%x, len %d, saddr 0x%x\n", |
115 | 112 | msg->addr, msg->len, saddr); | |
116 | return dev->cx231xx_gpio_i2c_write(dev, msg->addr, msg->buf, msg->len); | 113 | |
117 | } | 114 | return dev->cx231xx_gpio_i2c_write(dev, |
118 | 115 | msg->addr, | |
119 | } | 116 | msg->buf, |
120 | 117 | msg->len); | |
121 | /* special case for Xc5000 tuner case */ | 118 | } |
122 | saddr_len = 1; | 119 | |
123 | 120 | } | |
124 | /* adjust the length to correct length */ | 121 | |
125 | size -= saddr_len; | 122 | /* special case for Xc5000 tuner case */ |
126 | buf_ptr = (u8*) (msg->buf + 1 ); | 123 | saddr_len = 1; |
127 | 124 | ||
128 | do { | 125 | /* adjust the length to correct length */ |
129 | /* prepare xfer_data struct */ | 126 | size -= saddr_len; |
130 | req_data.dev_addr = msg->addr; | 127 | buf_ptr = (u8 *) (msg->buf + 1); |
131 | req_data.direction = msg->flags; | 128 | |
132 | req_data.saddr_len = saddr_len; | 129 | do { |
133 | req_data.saddr_dat = msg->buf[0]; | 130 | /* prepare xfer_data struct */ |
134 | req_data.buf_size = size > 16 ? 16: size; | 131 | req_data.dev_addr = msg->addr; |
135 | req_data.p_buffer = (u8*)(buf_ptr + loop * 16); | 132 | req_data.direction = msg->flags; |
136 | 133 | req_data.saddr_len = saddr_len; | |
137 | bus->i2c_nostop = (size > 16) ? 1: 0; | 134 | req_data.saddr_dat = msg->buf[0]; |
138 | bus->i2c_reserve = (loop == 0) ? 0: 1; | 135 | req_data.buf_size = size > 16 ? 16 : size; |
139 | 136 | req_data.p_buffer = (u8 *) (buf_ptr + loop * 16); | |
140 | /* usb send command */ | 137 | |
141 | status = dev->cx231xx_send_usb_command(bus, &req_data); | 138 | bus->i2c_nostop = (size > 16) ? 1 : 0; |
142 | loop++; | 139 | bus->i2c_reserve = (loop == 0) ? 0 : 1; |
143 | 140 | ||
144 | if( size >= 16 ) | 141 | /* usb send command */ |
145 | size -= 16; | 142 | status = dev->cx231xx_send_usb_command(bus, &req_data); |
146 | else | 143 | loop++; |
147 | size = 0; | 144 | |
148 | 145 | if (size >= 16) | |
149 | }while( size > 0 ); | 146 | size -= 16; |
150 | 147 | else | |
151 | bus->i2c_nostop = 0; | 148 | size = 0; |
152 | bus->i2c_reserve = 0; | 149 | |
153 | 150 | } while (size > 0); | |
154 | } else { /* regular case */ | 151 | |
155 | 152 | bus->i2c_nostop = 0; | |
156 | /* prepare xfer_data struct */ | 153 | bus->i2c_reserve = 0; |
157 | req_data.dev_addr = msg->addr; | 154 | |
158 | req_data.direction = msg->flags; | 155 | } else { /* regular case */ |
159 | req_data.saddr_len = 0; | 156 | |
160 | req_data.saddr_dat = 0; | 157 | /* prepare xfer_data struct */ |
161 | req_data.buf_size = msg->len; | 158 | req_data.dev_addr = msg->addr; |
162 | req_data.p_buffer = msg->buf; | 159 | req_data.direction = msg->flags; |
163 | 160 | req_data.saddr_len = 0; | |
164 | /* usb send command */ | 161 | req_data.saddr_dat = 0; |
165 | status = dev->cx231xx_send_usb_command(bus, &req_data); | 162 | req_data.buf_size = msg->len; |
166 | } | 163 | req_data.p_buffer = msg->buf; |
167 | 164 | ||
168 | return status < 0 ? status: 0; | 165 | /* usb send command */ |
166 | status = dev->cx231xx_send_usb_command(bus, &req_data); | ||
167 | } | ||
168 | |||
169 | return status < 0 ? status : 0; | ||
169 | } | 170 | } |
170 | 171 | ||
171 | /* | 172 | /* |
@@ -173,75 +174,85 @@ int cx231xx_i2c_send_bytes(struct i2c_adapter *i2c_adap, | |||
173 | * read a byte from the i2c device | 174 | * read a byte from the i2c device |
174 | */ | 175 | */ |
175 | static int cx231xx_i2c_recv_bytes(struct i2c_adapter *i2c_adap, | 176 | static int cx231xx_i2c_recv_bytes(struct i2c_adapter *i2c_adap, |
176 | const struct i2c_msg *msg) | 177 | const struct i2c_msg *msg) |
177 | { | 178 | { |
178 | struct cx231xx_i2c *bus = i2c_adap->algo_data; | 179 | struct cx231xx_i2c *bus = i2c_adap->algo_data; |
179 | struct cx231xx *dev = bus->dev; | 180 | struct cx231xx *dev = bus->dev; |
180 | struct cx231xx_i2c_xfer_data req_data; | 181 | struct cx231xx_i2c_xfer_data req_data; |
181 | int status = 0; | 182 | int status = 0; |
182 | u16 saddr = 0; | 183 | u16 saddr = 0; |
183 | u8 need_gpio = 0; | 184 | u8 need_gpio = 0; |
184 | 185 | ||
185 | if((bus->nr ==1) && (msg->addr == 0x61) && dev->tuner_type == TUNER_XC5000) { | 186 | if ((bus->nr == 1) && (msg->addr == 0x61) |
186 | 187 | && dev->tuner_type == TUNER_XC5000) { | |
187 | if(msg->len == 2 ) | 188 | |
188 | saddr = msg->buf[0] << 8 | msg->buf[1]; | 189 | if (msg->len == 2) |
189 | else if ( msg->len == 1 ) | 190 | saddr = msg->buf[0] << 8 | msg->buf[1]; |
190 | saddr = msg->buf[0]; | 191 | else if (msg->len == 1) |
191 | 192 | saddr = msg->buf[0]; | |
192 | if( dev->xc_fw_load_done) { | 193 | |
193 | 194 | if (dev->xc_fw_load_done) { | |
194 | switch(saddr) { | 195 | |
195 | case 0x0009: /* BUSY check */ | 196 | switch (saddr) { |
196 | dprintk1(1, " GPIO R E A D : Special case BUSY check \n"); | 197 | case 0x0009: /* BUSY check */ |
197 | /* Try to read BUSY register, just set it to zero */ | 198 | dprintk1(1, |
198 | msg->buf[0] = 0; | 199 | " GPIO R E A D : Special case BUSY check \n"); |
199 | if(msg->len == 2 ) | 200 | /* Try to read BUSY register, just set it to zero */ |
200 | msg->buf[1] = 0; | 201 | msg->buf[0] = 0; |
201 | return 0; | 202 | if (msg->len == 2) |
202 | case 0x0004: /* read Lock status */ | 203 | msg->buf[1] = 0; |
203 | need_gpio = 1; | 204 | return 0; |
204 | break; | 205 | case 0x0004: /* read Lock status */ |
205 | 206 | need_gpio = 1; | |
206 | } | 207 | break; |
207 | 208 | ||
208 | if(need_gpio) { | 209 | } |
209 | /* this is a special case to handle Xceive tuner clock stretch issue | 210 | |
210 | with gpio based I2C interface */ | 211 | if (need_gpio) { |
211 | dprintk1(1, " GPIO R E A D : addr 0x%x, len %d, saddr 0x%x\n", | 212 | /* this is a special case to handle Xceive tuner clock stretch issue |
212 | msg->addr, msg->len, msg->buf[0] << 8| msg->buf[1]); | 213 | with gpio based I2C interface */ |
213 | status = dev->cx231xx_gpio_i2c_write(dev, msg->addr, msg->buf, msg->len); | 214 | dprintk1(1, |
214 | status = dev->cx231xx_gpio_i2c_read(dev, msg->addr, msg->buf, msg->len); | 215 | " GPIO R E A D : addr 0x%x, len %d, saddr 0x%x\n", |
215 | return status; | 216 | msg->addr, msg->len, |
216 | } | 217 | msg->buf[0] << 8 | msg->buf[1]); |
217 | } | 218 | status = |
218 | 219 | dev->cx231xx_gpio_i2c_write(dev, msg->addr, | |
219 | /* prepare xfer_data struct */ | 220 | msg->buf, |
220 | req_data.dev_addr = msg->addr; | 221 | msg->len); |
221 | req_data.direction = msg->flags; | 222 | status = |
222 | req_data.saddr_len = msg->len; | 223 | dev->cx231xx_gpio_i2c_read(dev, msg->addr, |
223 | req_data.saddr_dat = msg->buf[0] << 8 | msg->buf[1]; | 224 | msg->buf, |
224 | req_data.buf_size = msg->len; | 225 | msg->len); |
225 | req_data.p_buffer = msg->buf; | 226 | return status; |
226 | 227 | } | |
227 | /* usb send command */ | 228 | } |
228 | status = dev->cx231xx_send_usb_command(bus, &req_data); | 229 | |
229 | 230 | /* prepare xfer_data struct */ | |
230 | } else { | 231 | req_data.dev_addr = msg->addr; |
231 | 232 | req_data.direction = msg->flags; | |
232 | /* prepare xfer_data struct */ | 233 | req_data.saddr_len = msg->len; |
233 | req_data.dev_addr = msg->addr; | 234 | req_data.saddr_dat = msg->buf[0] << 8 | msg->buf[1]; |
234 | req_data.direction = msg->flags; | 235 | req_data.buf_size = msg->len; |
235 | req_data.saddr_len = 0; | 236 | req_data.p_buffer = msg->buf; |
236 | req_data.saddr_dat = 0; | 237 | |
237 | req_data.buf_size = msg->len; | 238 | /* usb send command */ |
238 | req_data.p_buffer = msg->buf; | 239 | status = dev->cx231xx_send_usb_command(bus, &req_data); |
239 | 240 | ||
240 | /* usb send command */ | 241 | } else { |
241 | status = dev->cx231xx_send_usb_command(bus, &req_data); | 242 | |
242 | } | 243 | /* prepare xfer_data struct */ |
243 | 244 | req_data.dev_addr = msg->addr; | |
244 | return status < 0 ? status: 0; | 245 | req_data.direction = msg->flags; |
246 | req_data.saddr_len = 0; | ||
247 | req_data.saddr_dat = 0; | ||
248 | req_data.buf_size = msg->len; | ||
249 | req_data.p_buffer = msg->buf; | ||
250 | |||
251 | /* usb send command */ | ||
252 | status = dev->cx231xx_send_usb_command(bus, &req_data); | ||
253 | } | ||
254 | |||
255 | return status < 0 ? status : 0; | ||
245 | } | 256 | } |
246 | 257 | ||
247 | /* | 258 | /* |
@@ -249,56 +260,65 @@ static int cx231xx_i2c_recv_bytes(struct i2c_adapter *i2c_adap, | |||
249 | * read a byte from the i2c device | 260 | * read a byte from the i2c device |
250 | */ | 261 | */ |
251 | static int cx231xx_i2c_recv_bytes_with_saddr(struct i2c_adapter *i2c_adap, | 262 | static int cx231xx_i2c_recv_bytes_with_saddr(struct i2c_adapter *i2c_adap, |
252 | const struct i2c_msg *msg1, const struct i2c_msg *msg2) | 263 | const struct i2c_msg *msg1, |
264 | const struct i2c_msg *msg2) | ||
253 | { | 265 | { |
254 | struct cx231xx_i2c *bus = i2c_adap->algo_data; | 266 | struct cx231xx_i2c *bus = i2c_adap->algo_data; |
255 | struct cx231xx *dev = bus->dev; | 267 | struct cx231xx *dev = bus->dev; |
256 | struct cx231xx_i2c_xfer_data req_data; | 268 | struct cx231xx_i2c_xfer_data req_data; |
257 | int status = 0; | 269 | int status = 0; |
258 | u16 saddr = 0; | 270 | u16 saddr = 0; |
259 | u8 need_gpio = 0; | 271 | u8 need_gpio = 0; |
260 | 272 | ||
261 | if(msg1->len == 2 ) | 273 | if (msg1->len == 2) |
262 | saddr = msg1->buf[0] << 8 | msg1->buf[1]; | 274 | saddr = msg1->buf[0] << 8 | msg1->buf[1]; |
263 | else if ( msg1->len == 1 ) | 275 | else if (msg1->len == 1) |
264 | saddr = msg1->buf[0]; | 276 | saddr = msg1->buf[0]; |
265 | 277 | ||
266 | if ( (bus->nr ==1) && (msg2->addr == 0x61) && dev->tuner_type == TUNER_XC5000) { | 278 | if ((bus->nr == 1) && (msg2->addr == 0x61) |
267 | 279 | && dev->tuner_type == TUNER_XC5000) { | |
268 | if( (msg2->len < 16) ) { | 280 | |
269 | 281 | if ((msg2->len < 16)) { | |
270 | dprintk1(1, " i2c_read : addr 0x%x, len %d, subaddr 0x%x, leng %d\n", | 282 | |
271 | msg2->addr, msg2->len, saddr, msg1->len); | 283 | dprintk1(1, |
272 | 284 | " i2c_read : addr 0x%x, len %d, subaddr 0x%x, leng %d\n", | |
273 | switch(saddr) { | 285 | msg2->addr, msg2->len, saddr, msg1->len); |
274 | case 0x0008: /* read FW load status */ | 286 | |
275 | need_gpio = 1; | 287 | switch (saddr) { |
276 | break; | 288 | case 0x0008: /* read FW load status */ |
277 | case 0x0004: /* read Lock status */ | 289 | need_gpio = 1; |
278 | need_gpio = 1; | 290 | break; |
279 | break; | 291 | case 0x0004: /* read Lock status */ |
280 | } | 292 | need_gpio = 1; |
281 | 293 | break; | |
282 | if(need_gpio ) { | 294 | } |
283 | status = dev->cx231xx_gpio_i2c_write(dev, msg1->addr, msg1->buf, msg1->len); | 295 | |
284 | status = dev->cx231xx_gpio_i2c_read(dev, msg2->addr, msg2->buf, msg2->len); | 296 | if (need_gpio) { |
285 | return status; | 297 | status = |
286 | } | 298 | dev->cx231xx_gpio_i2c_write(dev, msg1->addr, |
287 | } | 299 | msg1->buf, |
288 | } | 300 | msg1->len); |
289 | 301 | status = | |
290 | /* prepare xfer_data struct */ | 302 | dev->cx231xx_gpio_i2c_read(dev, msg2->addr, |
291 | req_data.dev_addr = msg2->addr; | 303 | msg2->buf, |
292 | req_data.direction = msg2->flags; | 304 | msg2->len); |
293 | req_data.saddr_len = msg1->len; | 305 | return status; |
294 | req_data.saddr_dat = saddr; | 306 | } |
295 | req_data.buf_size = msg2->len; | 307 | } |
296 | req_data.p_buffer = msg2->buf; | 308 | } |
297 | 309 | ||
298 | /* usb send command */ | 310 | /* prepare xfer_data struct */ |
299 | status = dev->cx231xx_send_usb_command(bus, &req_data); | 311 | req_data.dev_addr = msg2->addr; |
300 | 312 | req_data.direction = msg2->flags; | |
301 | return status < 0 ? status: 0; | 313 | req_data.saddr_len = msg1->len; |
314 | req_data.saddr_dat = saddr; | ||
315 | req_data.buf_size = msg2->len; | ||
316 | req_data.p_buffer = msg2->buf; | ||
317 | |||
318 | /* usb send command */ | ||
319 | status = dev->cx231xx_send_usb_command(bus, &req_data); | ||
320 | |||
321 | return status < 0 ? status : 0; | ||
302 | } | 322 | } |
303 | 323 | ||
304 | /* | 324 | /* |
@@ -306,25 +326,25 @@ static int cx231xx_i2c_recv_bytes_with_saddr(struct i2c_adapter *i2c_adap, | |||
306 | * check if there is a i2c_device at the supplied address | 326 | * check if there is a i2c_device at the supplied address |
307 | */ | 327 | */ |
308 | static int cx231xx_i2c_check_for_device(struct i2c_adapter *i2c_adap, | 328 | static int cx231xx_i2c_check_for_device(struct i2c_adapter *i2c_adap, |
309 | const struct i2c_msg *msg) | 329 | const struct i2c_msg *msg) |
310 | { | 330 | { |
311 | struct cx231xx_i2c *bus = i2c_adap->algo_data; | 331 | struct cx231xx_i2c *bus = i2c_adap->algo_data; |
312 | struct cx231xx *dev = bus->dev; | 332 | struct cx231xx *dev = bus->dev; |
313 | struct cx231xx_i2c_xfer_data req_data; | 333 | struct cx231xx_i2c_xfer_data req_data; |
314 | int status = 0; | 334 | int status = 0; |
315 | 335 | ||
316 | /* prepare xfer_data struct */ | 336 | /* prepare xfer_data struct */ |
317 | req_data.dev_addr = msg->addr; | 337 | req_data.dev_addr = msg->addr; |
318 | req_data.direction = msg->flags; | 338 | req_data.direction = msg->flags; |
319 | req_data.saddr_len = 0; | 339 | req_data.saddr_len = 0; |
320 | req_data.saddr_dat = 0; | 340 | req_data.saddr_dat = 0; |
321 | req_data.buf_size = 0; | 341 | req_data.buf_size = 0; |
322 | req_data.p_buffer = NULL; | 342 | req_data.p_buffer = NULL; |
323 | 343 | ||
324 | /* usb send command */ | 344 | /* usb send command */ |
325 | status = dev->cx231xx_send_usb_command(bus, &req_data); | 345 | status = dev->cx231xx_send_usb_command(bus, &req_data); |
326 | 346 | ||
327 | return status < 0 ? status: 0; | 347 | return status < 0 ? status : 0; |
328 | } | 348 | } |
329 | 349 | ||
330 | /* | 350 | /* |
@@ -332,7 +352,7 @@ static int cx231xx_i2c_check_for_device(struct i2c_adapter *i2c_adap, | |||
332 | * the main i2c transfer function | 352 | * the main i2c transfer function |
333 | */ | 353 | */ |
334 | static int cx231xx_i2c_xfer(struct i2c_adapter *i2c_adap, | 354 | static int cx231xx_i2c_xfer(struct i2c_adapter *i2c_adap, |
335 | struct i2c_msg msgs[], int num) | 355 | struct i2c_msg msgs[], int num) |
336 | { | 356 | { |
337 | struct cx231xx_i2c *bus = i2c_adap->algo_data; | 357 | struct cx231xx_i2c *bus = i2c_adap->algo_data; |
338 | struct cx231xx *dev = bus->dev; | 358 | struct cx231xx *dev = bus->dev; |
@@ -348,7 +368,7 @@ static int cx231xx_i2c_xfer(struct i2c_adapter *i2c_adap, | |||
348 | dprintk2(2, "%s %s addr=%x len=%d:", | 368 | dprintk2(2, "%s %s addr=%x len=%d:", |
349 | (msgs[i].flags & I2C_M_RD) ? "read" : "write", | 369 | (msgs[i].flags & I2C_M_RD) ? "read" : "write", |
350 | i == num - 1 ? "stop" : "nonstop", addr, msgs[i].len); | 370 | i == num - 1 ? "stop" : "nonstop", addr, msgs[i].len); |
351 | if (!msgs[i].len) { /* no len: check only for device presence */ | 371 | if (!msgs[i].len) { /* no len: check only for device presence */ |
352 | rc = cx231xx_i2c_check_for_device(i2c_adap, &msgs[i]); | 372 | rc = cx231xx_i2c_check_for_device(i2c_adap, &msgs[i]); |
353 | if (rc < 0) { | 373 | if (rc < 0) { |
354 | dprintk2(2, " no device\n"); | 374 | dprintk2(2, " no device\n"); |
@@ -363,21 +383,24 @@ static int cx231xx_i2c_xfer(struct i2c_adapter *i2c_adap, | |||
363 | printk(" %02x", msgs[i].buf[byte]); | 383 | printk(" %02x", msgs[i].buf[byte]); |
364 | } | 384 | } |
365 | } else if (i + 1 < num && (msgs[i + 1].flags & I2C_M_RD) && | 385 | } else if (i + 1 < num && (msgs[i + 1].flags & I2C_M_RD) && |
366 | msgs[i].addr == msgs[i + 1].addr && (msgs[i].len <= 2) && (bus->nr < 2)) { | 386 | msgs[i].addr == msgs[i + 1].addr |
387 | && (msgs[i].len <= 2) && (bus->nr < 2)) { | ||
367 | /* read bytes */ | 388 | /* read bytes */ |
368 | rc = cx231xx_i2c_recv_bytes_with_saddr(i2c_adap, &msgs[i], &msgs[i+1]); | 389 | rc = cx231xx_i2c_recv_bytes_with_saddr(i2c_adap, |
390 | &msgs[i], | ||
391 | &msgs[i + 1]); | ||
369 | if (i2c_debug >= 2) { | 392 | if (i2c_debug >= 2) { |
370 | for (byte = 0; byte < msgs[i].len; byte++) | 393 | for (byte = 0; byte < msgs[i].len; byte++) |
371 | printk(" %02x", msgs[i].buf[byte]); | 394 | printk(" %02x", msgs[i].buf[byte]); |
372 | } | 395 | } |
373 | i++; | 396 | i++; |
374 | } else { | 397 | } else { |
375 | /* write bytes */ | 398 | /* write bytes */ |
376 | if (i2c_debug >= 2) { | 399 | if (i2c_debug >= 2) { |
377 | for (byte = 0; byte < msgs[i].len; byte++) | 400 | for (byte = 0; byte < msgs[i].len; byte++) |
378 | printk(" %02x", msgs[i].buf[byte]); | 401 | printk(" %02x", msgs[i].buf[byte]); |
379 | } | 402 | } |
380 | rc = cx231xx_i2c_send_bytes(i2c_adap,&msgs[i]); | 403 | rc = cx231xx_i2c_send_bytes(i2c_adap, &msgs[i]); |
381 | } | 404 | } |
382 | if (rc < 0) | 405 | if (rc < 0) |
383 | goto err; | 406 | goto err; |
@@ -386,7 +409,7 @@ static int cx231xx_i2c_xfer(struct i2c_adapter *i2c_adap, | |||
386 | } | 409 | } |
387 | 410 | ||
388 | return num; | 411 | return num; |
389 | err: | 412 | err: |
390 | dprintk2(2, " ERROR: %i\n", rc); | 413 | dprintk2(2, " ERROR: %i\n", rc); |
391 | return rc; | 414 | return rc; |
392 | } | 415 | } |
@@ -408,7 +431,7 @@ static u32 functionality(struct i2c_adapter *adap) | |||
408 | */ | 431 | */ |
409 | static int attach_inform(struct i2c_client *client) | 432 | static int attach_inform(struct i2c_client *client) |
410 | { | 433 | { |
411 | struct cx231xx_i2c *bus = i2c_get_adapdata(client->adapter); | 434 | struct cx231xx_i2c *bus = i2c_get_adapdata(client->adapter); |
412 | struct cx231xx *dev = bus->dev; | 435 | struct cx231xx *dev = bus->dev; |
413 | 436 | ||
414 | switch (client->addr << 1) { | 437 | switch (client->addr << 1) { |
@@ -422,16 +445,16 @@ static int attach_inform(struct i2c_client *client) | |||
422 | dprintk1(1, "attach_inform: eeprom detected.\n"); | 445 | dprintk1(1, "attach_inform: eeprom detected.\n"); |
423 | break; | 446 | break; |
424 | case 0x60: | 447 | case 0x60: |
425 | dprintk1(1, "attach_inform: Colibri detected.\n"); | 448 | dprintk1(1, "attach_inform: Colibri detected.\n"); |
426 | break; | ||
427 | case 0x8e: | ||
428 | { | ||
429 | struct IR_i2c *ir = i2c_get_clientdata(client); | ||
430 | dprintk1(1, "attach_inform: IR detected (%s).\n", | ||
431 | ir->phys); | ||
432 | cx231xx_set_ir(dev, ir); | ||
433 | break; | 449 | break; |
434 | } | 450 | case 0x8e: |
451 | { | ||
452 | struct IR_i2c *ir = i2c_get_clientdata(client); | ||
453 | dprintk1(1, "attach_inform: IR detected (%s).\n", | ||
454 | ir->phys); | ||
455 | cx231xx_set_ir(dev, ir); | ||
456 | break; | ||
457 | } | ||
435 | case 0x80: | 458 | case 0x80: |
436 | case 0x88: | 459 | case 0x88: |
437 | dprintk1(1, "attach_inform: Hammerhead detected.\n"); | 460 | dprintk1(1, "attach_inform: Hammerhead detected.\n"); |
@@ -442,7 +465,7 @@ static int attach_inform(struct i2c_client *client) | |||
442 | dev->tuner_addr = client->addr; | 465 | dev->tuner_addr = client->addr; |
443 | 466 | ||
444 | dprintk1(1, "attach inform: detected I2C address %x\n", | 467 | dprintk1(1, "attach inform: detected I2C address %x\n", |
445 | client->addr << 1); | 468 | client->addr << 1); |
446 | } | 469 | } |
447 | 470 | ||
448 | return 0; | 471 | return 0; |
@@ -454,9 +477,8 @@ static int detach_inform(struct i2c_client *client) | |||
454 | return 0; | 477 | return 0; |
455 | } | 478 | } |
456 | 479 | ||
457 | |||
458 | static struct i2c_algorithm cx231xx_algo = { | 480 | static struct i2c_algorithm cx231xx_algo = { |
459 | .master_xfer = cx231xx_i2c_xfer, | 481 | .master_xfer = cx231xx_i2c_xfer, |
460 | .functionality = functionality, | 482 | .functionality = functionality, |
461 | }; | 483 | }; |
462 | 484 | ||
@@ -466,7 +488,7 @@ static struct i2c_adapter cx231xx_adap_template = { | |||
466 | .name = "cx231xx", | 488 | .name = "cx231xx", |
467 | .id = I2C_HW_B_CX231XX, | 489 | .id = I2C_HW_B_CX231XX, |
468 | .algo = &cx231xx_algo, | 490 | .algo = &cx231xx_algo, |
469 | .client_register = attach_inform, | 491 | .client_register = attach_inform, |
470 | .client_unregister = detach_inform, | 492 | .client_unregister = detach_inform, |
471 | }; | 493 | }; |
472 | 494 | ||
@@ -483,9 +505,9 @@ static struct i2c_client cx231xx_client_template = { | |||
483 | static char *i2c_devs[128] = { | 505 | static char *i2c_devs[128] = { |
484 | [0x60 >> 1] = "colibri", | 506 | [0x60 >> 1] = "colibri", |
485 | [0x88 >> 1] = "hammerhead", | 507 | [0x88 >> 1] = "hammerhead", |
486 | [0x8e >> 1] = "CIR", | 508 | [0x8e >> 1] = "CIR", |
487 | [0x32 >> 1] = "GeminiIII", | 509 | [0x32 >> 1] = "GeminiIII", |
488 | [0x02 >> 1] = "Aquarius", | 510 | [0x02 >> 1] = "Aquarius", |
489 | [0xa0 >> 1] = "eeprom", | 511 | [0xa0 >> 1] = "eeprom", |
490 | [0xc0 >> 1] = "tuner/XC3028", | 512 | [0xc0 >> 1] = "tuner/XC3028", |
491 | [0xc2 >> 1] = "tuner/XC5000", | 513 | [0xc2 >> 1] = "tuner/XC5000", |
@@ -500,23 +522,25 @@ void cx231xx_do_i2c_scan(struct cx231xx *dev, struct i2c_client *c) | |||
500 | unsigned char buf; | 522 | unsigned char buf; |
501 | int i, rc; | 523 | int i, rc; |
502 | 524 | ||
503 | cx231xx_info(": Checking for I2C devices ..\n"); | 525 | cx231xx_info(": Checking for I2C devices ..\n"); |
504 | for (i = 0; i < 128; i++) { | 526 | for (i = 0; i < 128; i++) { |
505 | c->addr = i; | 527 | c->addr = i; |
506 | rc = i2c_master_recv(c, &buf, 0); | 528 | rc = i2c_master_recv(c, &buf, 0); |
507 | if (rc < 0) | 529 | if (rc < 0) |
508 | continue; | 530 | continue; |
509 | cx231xx_info("%s: i2c scan: found device @ 0x%x [%s]\n", | 531 | cx231xx_info("%s: i2c scan: found device @ 0x%x [%s]\n", |
510 | dev->name, i << 1, i2c_devs[i] ? i2c_devs[i] : "???"); | 532 | dev->name, i << 1, |
533 | i2c_devs[i] ? i2c_devs[i] : "???"); | ||
511 | } | 534 | } |
512 | cx231xx_info(": Completed Checking for I2C devices.\n"); | 535 | cx231xx_info(": Completed Checking for I2C devices.\n"); |
513 | } | 536 | } |
514 | 537 | ||
515 | /* | 538 | /* |
516 | * cx231xx_i2c_call_clients() | 539 | * cx231xx_i2c_call_clients() |
517 | * send commands to all attached i2c devices | 540 | * send commands to all attached i2c devices |
518 | */ | 541 | */ |
519 | void cx231xx_i2c_call_clients(struct cx231xx_i2c *bus, unsigned int cmd, void *arg) | 542 | void cx231xx_i2c_call_clients(struct cx231xx_i2c *bus, unsigned int cmd, |
543 | void *arg) | ||
520 | { | 544 | { |
521 | /* struct cx231xx *dev = bus->dev; */ | 545 | /* struct cx231xx *dev = bus->dev; */ |
522 | 546 | ||
@@ -530,23 +554,20 @@ void cx231xx_i2c_call_clients(struct cx231xx_i2c *bus, unsigned int cmd, void *a | |||
530 | */ | 554 | */ |
531 | int cx231xx_i2c_register(struct cx231xx_i2c *bus) | 555 | int cx231xx_i2c_register(struct cx231xx_i2c *bus) |
532 | { | 556 | { |
533 | struct cx231xx *dev = bus->dev; | 557 | struct cx231xx *dev = bus->dev; |
534 | 558 | ||
535 | BUG_ON(!dev->cx231xx_send_usb_command); | 559 | BUG_ON(!dev->cx231xx_send_usb_command); |
536 | 560 | ||
537 | cx231xx_info("%s(bus = %d)\n", __func__, bus->nr); | 561 | cx231xx_info("%s(bus = %d)\n", __func__, bus->nr); |
538 | 562 | ||
539 | memcpy(&bus->i2c_adap, &cx231xx_adap_template, | 563 | memcpy(&bus->i2c_adap, &cx231xx_adap_template, sizeof(bus->i2c_adap)); |
540 | sizeof(bus->i2c_adap)); | 564 | memcpy(&bus->i2c_algo, &cx231xx_algo, sizeof(bus->i2c_algo)); |
541 | memcpy(&bus->i2c_algo, &cx231xx_algo, | ||
542 | sizeof(bus->i2c_algo)); | ||
543 | memcpy(&bus->i2c_client, &cx231xx_client_template, | 565 | memcpy(&bus->i2c_client, &cx231xx_client_template, |
544 | sizeof(bus->i2c_client)); | 566 | sizeof(bus->i2c_client)); |
545 | 567 | ||
546 | bus->i2c_adap.dev.parent = &dev->udev->dev; | 568 | bus->i2c_adap.dev.parent = &dev->udev->dev; |
547 | 569 | ||
548 | strlcpy(bus->i2c_adap.name, bus->dev->name, | 570 | strlcpy(bus->i2c_adap.name, bus->dev->name, sizeof(bus->i2c_adap.name)); |
549 | sizeof(bus->i2c_adap.name)); | ||
550 | 571 | ||
551 | bus->i2c_algo.data = bus; | 572 | bus->i2c_algo.data = bus; |
552 | bus->i2c_adap.algo_data = bus; | 573 | bus->i2c_adap.algo_data = bus; |
@@ -561,7 +582,7 @@ int cx231xx_i2c_register(struct cx231xx_i2c *bus) | |||
561 | cx231xx_do_i2c_scan(dev, &bus->i2c_client); | 582 | cx231xx_do_i2c_scan(dev, &bus->i2c_client); |
562 | } else | 583 | } else |
563 | cx231xx_warn("%s: i2c bus %d register FAILED\n", | 584 | cx231xx_warn("%s: i2c bus %d register FAILED\n", |
564 | dev->name, bus->nr); | 585 | dev->name, bus->nr); |
565 | 586 | ||
566 | return bus->i2c_rc; | 587 | return bus->i2c_rc; |
567 | } | 588 | } |
diff --git a/drivers/media/video/cx231xx/cx231xx-input.c b/drivers/media/video/cx231xx/cx231xx-input.c index fdc37a838d10..68e95ea03b17 100644 --- a/drivers/media/video/cx231xx/cx231xx-input.c +++ b/drivers/media/video/cx231xx/cx231xx-input.c | |||
@@ -2,9 +2,9 @@ | |||
2 | handle cx231xx IR remotes via linux kernel input layer. | 2 | handle cx231xx IR remotes via linux kernel input layer. |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on em28xx driver | 5 | Based on em28xx driver |
6 | 6 | ||
7 | < This is a place holder for IR now.> | 7 | < This is a place holder for IR now.> |
8 | 8 | ||
9 | This program is free software; you can redistribute it and/or modify | 9 | This program is free software; you can redistribute it and/or modify |
10 | it under the terms of the GNU General Public License as published by | 10 | it under the terms of the GNU General Public License as published by |
@@ -30,7 +30,6 @@ | |||
30 | 30 | ||
31 | #include "cx231xx.h" | 31 | #include "cx231xx.h" |
32 | 32 | ||
33 | |||
34 | static unsigned int ir_debug; | 33 | static unsigned int ir_debug; |
35 | module_param(ir_debug, int, 0644); | 34 | module_param(ir_debug, int, 0644); |
36 | MODULE_PARM_DESC(ir_debug, "enable debug messages [IR]"); | 35 | MODULE_PARM_DESC(ir_debug, "enable debug messages [IR]"); |
@@ -71,11 +70,9 @@ struct cx231xx_IR { | |||
71 | unsigned int last_readcount; | 70 | unsigned int last_readcount; |
72 | unsigned int repeat_interval; | 71 | unsigned int repeat_interval; |
73 | 72 | ||
74 | int (*get_key)(struct cx231xx_IR *, struct cx231xx_ir_poll_result *); | 73 | int (*get_key) (struct cx231xx_IR *, struct cx231xx_ir_poll_result *); |
75 | }; | 74 | }; |
76 | 75 | ||
77 | |||
78 | |||
79 | /********************************************************** | 76 | /********************************************************** |
80 | Polling code for cx231xx | 77 | Polling code for cx231xx |
81 | **********************************************************/ | 78 | **********************************************************/ |
@@ -187,17 +184,16 @@ int cx231xx_ir_init(struct cx231xx *dev) | |||
187 | 184 | ||
188 | /* Setup the proper handler based on the chip */ | 185 | /* Setup the proper handler based on the chip */ |
189 | switch (dev->chip_id) { | 186 | switch (dev->chip_id) { |
190 | default: | 187 | default: |
191 | printk("Unrecognized cx231xx chip id: IR not supported\n"); | 188 | printk("Unrecognized cx231xx chip id: IR not supported\n"); |
192 | goto err_out_free; | 189 | goto err_out_free; |
193 | } | 190 | } |
194 | 191 | ||
195 | /* This is how often we ask the chip for IR information */ | 192 | /* This is how often we ask the chip for IR information */ |
196 | ir->polling = 100; /* ms */ | 193 | ir->polling = 100; /* ms */ |
197 | 194 | ||
198 | /* init input device */ | 195 | /* init input device */ |
199 | snprintf(ir->name, sizeof(ir->name), "cx231xx IR (%s)", | 196 | snprintf(ir->name, sizeof(ir->name), "cx231xx IR (%s)", dev->name); |
200 | dev->name); | ||
201 | 197 | ||
202 | usb_make_path(dev->udev, ir->phys, sizeof(ir->phys)); | 198 | usb_make_path(dev->udev, ir->phys, sizeof(ir->phys)); |
203 | strlcat(ir->phys, "/input0", sizeof(ir->phys)); | 199 | strlcat(ir->phys, "/input0", sizeof(ir->phys)); |
@@ -223,10 +219,10 @@ int cx231xx_ir_init(struct cx231xx *dev) | |||
223 | goto err_out_stop; | 219 | goto err_out_stop; |
224 | 220 | ||
225 | return 0; | 221 | return 0; |
226 | err_out_stop: | 222 | err_out_stop: |
227 | cx231xx_ir_stop(ir); | 223 | cx231xx_ir_stop(ir); |
228 | dev->ir = NULL; | 224 | dev->ir = NULL; |
229 | err_out_free: | 225 | err_out_free: |
230 | input_free_device(input_dev); | 226 | input_free_device(input_dev); |
231 | kfree(ir); | 227 | kfree(ir); |
232 | return err; | 228 | return err; |
diff --git a/drivers/media/video/cx231xx/cx231xx-reg.h b/drivers/media/video/cx231xx/cx231xx-reg.h index ef24781418e4..7c8ba4e053e7 100644 --- a/drivers/media/video/cx231xx/cx231xx-reg.h +++ b/drivers/media/video/cx231xx/cx231xx-reg.h | |||
@@ -22,7 +22,7 @@ | |||
22 | #define _CX231XX_REG_H | 22 | #define _CX231XX_REG_H |
23 | 23 | ||
24 | /***************************************************************************** | 24 | /***************************************************************************** |
25 | * VBI codes * | 25 | * VBI codes * |
26 | *****************************************************************************/ | 26 | *****************************************************************************/ |
27 | 27 | ||
28 | #define SAV_ACTIVE_VIDEO_FIELD1 0x80 | 28 | #define SAV_ACTIVE_VIDEO_FIELD1 0x80 |
@@ -37,16 +37,16 @@ | |||
37 | #define SAV_VBLANK_FIELD2 0xE0 | 37 | #define SAV_VBLANK_FIELD2 0xE0 |
38 | #define EAV_VBLANK_FIELD2 0xF0 | 38 | #define EAV_VBLANK_FIELD2 0xF0 |
39 | 39 | ||
40 | #define SAV_VBI_FIELD1 0x20 | 40 | #define SAV_VBI_FIELD1 0x20 |
41 | #define EAV_VBI_FIELD1 0x30 | 41 | #define EAV_VBI_FIELD1 0x30 |
42 | 42 | ||
43 | #define SAV_VBI_FIELD2 0x60 | 43 | #define SAV_VBI_FIELD2 0x60 |
44 | #define EAV_VBI_FIELD2 0x70 | 44 | #define EAV_VBI_FIELD2 0x70 |
45 | 45 | ||
46 | /*****************************************************************************/ | 46 | /*****************************************************************************/ |
47 | /* Audio ADC Registers */ | 47 | /* Audio ADC Registers */ |
48 | #define CH_PWR_CTRL1 0x0000000E | 48 | #define CH_PWR_CTRL1 0x0000000E |
49 | #define CH_PWR_CTRL2 0x0000000F | 49 | #define CH_PWR_CTRL2 0x0000000F |
50 | /*****************************************************************************/ | 50 | /*****************************************************************************/ |
51 | 51 | ||
52 | #define HOST_REG1 0x000 | 52 | #define HOST_REG1 0x000 |
@@ -60,7 +60,6 @@ | |||
60 | /*****************************************************************************/ | 60 | /*****************************************************************************/ |
61 | #define HOST_REG2 0x001 | 61 | #define HOST_REG2 0x001 |
62 | 62 | ||
63 | |||
64 | /*****************************************************************************/ | 63 | /*****************************************************************************/ |
65 | #define HOST_REG3 0x002 | 64 | #define HOST_REG3 0x002 |
66 | 65 | ||
@@ -231,7 +230,6 @@ | |||
231 | /* Reserved [3:1] */ | 230 | /* Reserved [3:1] */ |
232 | #define FLD_CIR_TEST_DIS 0x00000001 | 231 | #define FLD_CIR_TEST_DIS 0x00000001 |
233 | 232 | ||
234 | |||
235 | /*****************************************************************************/ | 233 | /*****************************************************************************/ |
236 | #define TEST_CTRL2 0x148 | 234 | #define TEST_CTRL2 0x148 |
237 | #define FLD_TSXCLK_POL_CTL 0x80000000 | 235 | #define FLD_TSXCLK_POL_CTL 0x80000000 |
@@ -257,7 +255,6 @@ | |||
257 | #define FLD_FLTRN_BIST_TST_DONE 0x00000008 | 255 | #define FLD_FLTRN_BIST_TST_DONE 0x00000008 |
258 | #define FLD_VID_BIST_TST_DONE 0x00000007 | 256 | #define FLD_VID_BIST_TST_DONE 0x00000007 |
259 | 257 | ||
260 | |||
261 | /*****************************************************************************/ | 258 | /*****************************************************************************/ |
262 | /* DirectIF registers definition have been moved to DIF_reg.h */ | 259 | /* DirectIF registers definition have been moved to DIF_reg.h */ |
263 | /*****************************************************************************/ | 260 | /*****************************************************************************/ |
@@ -268,7 +265,7 @@ | |||
268 | #define FLD_AFD_FORCE_PAL 0x04000000 | 265 | #define FLD_AFD_FORCE_PAL 0x04000000 |
269 | #define FLD_AFD_PALM_SEL 0x03000000 | 266 | #define FLD_AFD_PALM_SEL 0x03000000 |
270 | #define FLD_CKILL_MODE 0x00300000 | 267 | #define FLD_CKILL_MODE 0x00300000 |
271 | #define FLD_COMB_NOTCH_MODE 0x00c00000 /* bit[19:18] */ | 268 | #define FLD_COMB_NOTCH_MODE 0x00c00000 /* bit[19:18] */ |
272 | #define FLD_CLR_LOCK_STAT 0x00020000 | 269 | #define FLD_CLR_LOCK_STAT 0x00020000 |
273 | #define FLD_FAST_LOCK_MD 0x00010000 | 270 | #define FLD_FAST_LOCK_MD 0x00010000 |
274 | #define FLD_WCEN 0x00008000 | 271 | #define FLD_WCEN 0x00008000 |
@@ -662,7 +659,6 @@ | |||
662 | #define FLD_PLL_KI 0x00FF0000 | 659 | #define FLD_PLL_KI 0x00FF0000 |
663 | #define FLD_PLL_MAX_OFFSET 0x0000FFFF | 660 | #define FLD_PLL_MAX_OFFSET 0x0000FFFF |
664 | 661 | ||
665 | |||
666 | /*****************************************************************************/ | 662 | /*****************************************************************************/ |
667 | #define HTL_CTRL 0x498 | 663 | #define HTL_CTRL 0x498 |
668 | /* Reserved [31:24] */ | 664 | /* Reserved [31:24] */ |
@@ -771,13 +767,12 @@ | |||
771 | #define FLD_FIELD_PHASE_LIMIT 0x000000F0 | 767 | #define FLD_FIELD_PHASE_LIMIT 0x000000F0 |
772 | #define FLD_HEAD_SW_DET_LIMIT 0x0000000F | 768 | #define FLD_HEAD_SW_DET_LIMIT 0x0000000F |
773 | 769 | ||
774 | |||
775 | /*****************************************************************************/ | 770 | /*****************************************************************************/ |
776 | #define DL_CTL 0x800 | 771 | #define DL_CTL 0x800 |
777 | #define DL_CTL_ADDRESS_LOW 0x800 /* Byte 1 in DL_CTL */ | 772 | #define DL_CTL_ADDRESS_LOW 0x800 /* Byte 1 in DL_CTL */ |
778 | #define DL_CTL_ADDRESS_HIGH 0x801 /* Byte 2 in DL_CTL */ | 773 | #define DL_CTL_ADDRESS_HIGH 0x801 /* Byte 2 in DL_CTL */ |
779 | #define DL_CTL_DATA 0x802 /* Byte 3 in DL_CTL */ | 774 | #define DL_CTL_DATA 0x802 /* Byte 3 in DL_CTL */ |
780 | #define DL_CTL_CONTROL 0x803 /* Byte 4 in DL_CTL */ | 775 | #define DL_CTL_CONTROL 0x803 /* Byte 4 in DL_CTL */ |
781 | /* Reserved [31:5] */ | 776 | /* Reserved [31:5] */ |
782 | #define FLD_START_8051 0x10000000 | 777 | #define FLD_START_8051 0x10000000 |
783 | #define FLD_DL_ENABLE 0x08000000 | 778 | #define FLD_DL_ENABLE 0x08000000 |
@@ -795,8 +790,8 @@ | |||
795 | #define AUD_BUILD_NUM 0x806 | 790 | #define AUD_BUILD_NUM 0x806 |
796 | #define AUD_VER_NUM 0x807 | 791 | #define AUD_VER_NUM 0x807 |
797 | #define STD_DET_CTL 0x808 | 792 | #define STD_DET_CTL 0x808 |
798 | #define STD_DET_CTL_AUD_CTL 0x808 /* Byte 1 in STD_DET_CTL */ | 793 | #define STD_DET_CTL_AUD_CTL 0x808 /* Byte 1 in STD_DET_CTL */ |
799 | #define STD_DET_CTL_PREF_MODE 0x809 /* Byte 2 in STD_DET_CTL */ | 794 | #define STD_DET_CTL_PREF_MODE 0x809 /* Byte 2 in STD_DET_CTL */ |
800 | #define FLD_SPARE_CTL0 0xFF000000 | 795 | #define FLD_SPARE_CTL0 0xFF000000 |
801 | #define FLD_DIS_DBX 0x00800000 | 796 | #define FLD_DIS_DBX 0x00800000 |
802 | #define FLD_DIS_BTSC 0x00400000 | 797 | #define FLD_DIS_BTSC 0x00400000 |
@@ -1424,7 +1419,6 @@ | |||
1424 | #define FLD_I2S_OUT_WS_SEL 0x00000020 | 1419 | #define FLD_I2S_OUT_WS_SEL 0x00000020 |
1425 | #define FLD_I2S_OUT_BCN_DEL 0x0000001F | 1420 | #define FLD_I2S_OUT_BCN_DEL 0x0000001F |
1426 | 1421 | ||
1427 | |||
1428 | /*****************************************************************************/ | 1422 | /*****************************************************************************/ |
1429 | #define AC97_CTL 0x91C | 1423 | #define AC97_CTL 0x91C |
1430 | /* Reserved [31:26] */ | 1424 | /* Reserved [31:26] */ |
@@ -1437,7 +1431,6 @@ | |||
1437 | /* Reserved [7:1] */ | 1431 | /* Reserved [7:1] */ |
1438 | #define FLD_AC97_SHUTDOWN 0x00000001 | 1432 | #define FLD_AC97_SHUTDOWN 0x00000001 |
1439 | 1433 | ||
1440 | |||
1441 | /* Cx231xx redefine */ | 1434 | /* Cx231xx redefine */ |
1442 | #define QPSK_IAGC_CTL1 0x94c | 1435 | #define QPSK_IAGC_CTL1 0x94c |
1443 | #define QPSK_IAGC_CTL2 0x950 | 1436 | #define QPSK_IAGC_CTL2 0x950 |
@@ -1450,7 +1443,6 @@ | |||
1450 | #define QPSK_EQ_CTL 0x96c | 1443 | #define QPSK_EQ_CTL 0x96c |
1451 | #define QPSK_LOCK_CTL 0x970 | 1444 | #define QPSK_LOCK_CTL 0x970 |
1452 | 1445 | ||
1453 | |||
1454 | /*****************************************************************************/ | 1446 | /*****************************************************************************/ |
1455 | #define FM1_DFT_CTL 0x9A8 | 1447 | #define FM1_DFT_CTL 0x9A8 |
1456 | #define FLD_FM1_DFT_THRESHOLD 0xFFFF0000 | 1448 | #define FLD_FM1_DFT_THRESHOLD 0xFFFF0000 |
@@ -1494,8 +1486,6 @@ | |||
1494 | /* Reserved [15:6] */ | 1486 | /* Reserved [15:6] */ |
1495 | #define FLD_AFE_VGA_OUT 0x0000003F | 1487 | #define FLD_AFE_VGA_OUT 0x0000003F |
1496 | 1488 | ||
1497 | |||
1498 | |||
1499 | /*****************************************************************************/ | 1489 | /*****************************************************************************/ |
1500 | #define MTS_GAIN_STATUS 0x9BC | 1490 | #define MTS_GAIN_STATUS 0x9BC |
1501 | /* Reserved [31:14] */ | 1491 | /* Reserved [31:14] */ |
@@ -1538,19 +1528,18 @@ | |||
1538 | #define VID_FMT_SECAM 12 | 1528 | #define VID_FMT_SECAM 12 |
1539 | #define VID_FMT_SECAM_60 13 | 1529 | #define VID_FMT_SECAM_60 13 |
1540 | 1530 | ||
1541 | #define INPUT_MODE_CVBS_0 0 /* INPUT_MODE_VALUE(0) */ | 1531 | #define INPUT_MODE_CVBS_0 0 /* INPUT_MODE_VALUE(0) */ |
1542 | #define INPUT_MODE_YC_1 1 /* INPUT_MODE_VALUE(1) */ | 1532 | #define INPUT_MODE_YC_1 1 /* INPUT_MODE_VALUE(1) */ |
1543 | #define INPUT_MODE_YC2_2 2 /* INPUT_MODE_VALUE(2) */ | 1533 | #define INPUT_MODE_YC2_2 2 /* INPUT_MODE_VALUE(2) */ |
1544 | #define INPUT_MODE_YUV_3 3 /* INPUT_MODE_VALUE(3) */ | 1534 | #define INPUT_MODE_YUV_3 3 /* INPUT_MODE_VALUE(3) */ |
1545 | |||
1546 | 1535 | ||
1547 | #define LUMA_LPF_LOW_BANDPASS 0 /* 0.6Mhz lowpass filter bandwidth */ | 1536 | #define LUMA_LPF_LOW_BANDPASS 0 /* 0.6Mhz lowpass filter bandwidth */ |
1548 | #define LUMA_LPF_MEDIUM_BANDPASS 1 /* 1.0Mhz lowpass filter bandwidth */ | 1537 | #define LUMA_LPF_MEDIUM_BANDPASS 1 /* 1.0Mhz lowpass filter bandwidth */ |
1549 | #define LUMA_LPF_HIGH_BANDPASS 2 /* 1.5Mhz lowpass filter bandwidth */ | 1538 | #define LUMA_LPF_HIGH_BANDPASS 2 /* 1.5Mhz lowpass filter bandwidth */ |
1550 | 1539 | ||
1551 | #define UV_LPF_LOW_BANDPASS 0 /* 0.6Mhz lowpass filter bandwidth */ | 1540 | #define UV_LPF_LOW_BANDPASS 0 /* 0.6Mhz lowpass filter bandwidth */ |
1552 | #define UV_LPF_MEDIUM_BANDPASS 1 /* 1.0Mhz lowpass filter bandwidth */ | 1541 | #define UV_LPF_MEDIUM_BANDPASS 1 /* 1.0Mhz lowpass filter bandwidth */ |
1553 | #define UV_LPF_HIGH_BANDPASS 2 /* 1.5Mhz lowpass filter bandwidth */ | 1542 | #define UV_LPF_HIGH_BANDPASS 2 /* 1.5Mhz lowpass filter bandwidth */ |
1554 | 1543 | ||
1555 | #define TWO_TAP_FILT 0 | 1544 | #define TWO_TAP_FILT 0 |
1556 | #define THREE_TAP_FILT 1 | 1545 | #define THREE_TAP_FILT 1 |
diff --git a/drivers/media/video/cx231xx/cx231xx-vbi.c b/drivers/media/video/cx231xx/cx231xx-vbi.c index e370160973f4..87a77d53faa6 100644 --- a/drivers/media/video/cx231xx/cx231xx-vbi.c +++ b/drivers/media/video/cx231xx/cx231xx-vbi.c | |||
@@ -2,7 +2,7 @@ | |||
2 | cx231xx_vbi.c - driver for Conexant Cx23100/101/102 USB video capture devices | 2 | cx231xx_vbi.c - driver for Conexant Cx23100/101/102 USB video capture devices |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on cx88 driver | 5 | Based on cx88 driver |
6 | 6 | ||
7 | This program is free software; you can redistribute it and/or modify | 7 | This program is free software; you can redistribute it and/or modify |
8 | it under the terms of the GNU General Public License as published by | 8 | it under the terms of the GNU General Public License as published by |
@@ -39,8 +39,7 @@ | |||
39 | #include "cx231xx.h" | 39 | #include "cx231xx.h" |
40 | #include "cx231xx-vbi.h" | 40 | #include "cx231xx-vbi.h" |
41 | 41 | ||
42 | static inline void print_err_status(struct cx231xx *dev, | 42 | static inline void print_err_status(struct cx231xx *dev, int packet, int status) |
43 | int packet, int status) | ||
44 | { | 43 | { |
45 | char *errmsg = "Unknown"; | 44 | char *errmsg = "Unknown"; |
46 | 45 | ||
@@ -71,10 +70,11 @@ static inline void print_err_status(struct cx231xx *dev, | |||
71 | break; | 70 | break; |
72 | } | 71 | } |
73 | if (packet < 0) { | 72 | if (packet < 0) { |
74 | cx231xx_err(DRIVER_NAME "URB status %d [%s].\n", status, errmsg); | 73 | cx231xx_err(DRIVER_NAME "URB status %d [%s].\n", status, |
74 | errmsg); | ||
75 | } else { | 75 | } else { |
76 | cx231xx_err(DRIVER_NAME "URB packet %d, status %d [%s].\n", | 76 | cx231xx_err(DRIVER_NAME "URB packet %d, status %d [%s].\n", |
77 | packet, status, errmsg); | 77 | packet, status, errmsg); |
78 | } | 78 | } |
79 | } | 79 | } |
80 | 80 | ||
@@ -83,12 +83,12 @@ static inline void print_err_status(struct cx231xx *dev, | |||
83 | */ | 83 | */ |
84 | static inline int cx231xx_isoc_vbi_copy(struct cx231xx *dev, struct urb *urb) | 84 | static inline int cx231xx_isoc_vbi_copy(struct cx231xx *dev, struct urb *urb) |
85 | { | 85 | { |
86 | struct cx231xx_buffer *buf; | 86 | struct cx231xx_buffer *buf; |
87 | struct cx231xx_dmaqueue *dma_q = urb->context; | 87 | struct cx231xx_dmaqueue *dma_q = urb->context; |
88 | int rc = 1; | 88 | int rc = 1; |
89 | unsigned char *p_buffer; | 89 | unsigned char *p_buffer; |
90 | u32 bytes_parsed = 0, buffer_size = 0; | 90 | u32 bytes_parsed = 0, buffer_size = 0; |
91 | u8 sav_eav = 0; | 91 | u8 sav_eav = 0; |
92 | 92 | ||
93 | if (!dev) | 93 | if (!dev) |
94 | return 0; | 94 | return 0; |
@@ -104,60 +104,58 @@ static inline int cx231xx_isoc_vbi_copy(struct cx231xx *dev, struct urb *urb) | |||
104 | 104 | ||
105 | buf = dev->vbi_mode.isoc_ctl.buf; | 105 | buf = dev->vbi_mode.isoc_ctl.buf; |
106 | 106 | ||
107 | /* get buffer pointer and length */ | 107 | /* get buffer pointer and length */ |
108 | p_buffer = urb->transfer_buffer; | 108 | p_buffer = urb->transfer_buffer; |
109 | buffer_size = urb->actual_length; | 109 | buffer_size = urb->actual_length; |
110 | 110 | ||
111 | if (buffer_size > 0) { | 111 | if (buffer_size > 0) { |
112 | 112 | ||
113 | bytes_parsed = 0; | 113 | bytes_parsed = 0; |
114 | 114 | ||
115 | if(dma_q->is_partial_line) { | 115 | if (dma_q->is_partial_line) { |
116 | /* Handle the case where we were working on a partial line */ | 116 | /* Handle the case where we were working on a partial line */ |
117 | sav_eav = dma_q->last_sav; | 117 | sav_eav = dma_q->last_sav; |
118 | } else { | 118 | } else { |
119 | /* Check for a SAV/EAV overlapping the buffer boundary */ | 119 | /* Check for a SAV/EAV overlapping the buffer boundary */ |
120 | sav_eav = cx231xx_find_boundary_SAV_EAV(p_buffer, dma_q->partial_buf, &bytes_parsed); | 120 | sav_eav = |
121 | } | 121 | cx231xx_find_boundary_SAV_EAV(p_buffer, |
122 | 122 | dma_q->partial_buf, | |
123 | sav_eav &= 0xF0; | 123 | &bytes_parsed); |
124 | /* Get the first line if we have some portion of an SAV/EAV from the last buffer | 124 | } |
125 | or a partial line */ | 125 | |
126 | if(sav_eav) { | 126 | sav_eav &= 0xF0; |
127 | bytes_parsed += cx231xx_get_vbi_line(dev, dma_q, | 127 | /* Get the first line if we have some portion of an SAV/EAV from the last buffer |
128 | sav_eav, /* SAV/EAV */ | 128 | or a partial line */ |
129 | p_buffer + bytes_parsed, /* p_buffer */ | 129 | if (sav_eav) { |
130 | buffer_size - bytes_parsed); /* buffer size */ | 130 | bytes_parsed += cx231xx_get_vbi_line(dev, dma_q, sav_eav, /* SAV/EAV */ |
131 | } | 131 | p_buffer + bytes_parsed, /* p_buffer */ |
132 | 132 | buffer_size - bytes_parsed); /* buffer size */ | |
133 | /* Now parse data that is completely in this buffer */ | 133 | } |
134 | dma_q->is_partial_line = 0; | 134 | |
135 | 135 | /* Now parse data that is completely in this buffer */ | |
136 | while(bytes_parsed < buffer_size) | 136 | dma_q->is_partial_line = 0; |
137 | { | 137 | |
138 | u32 bytes_used = 0; | 138 | while (bytes_parsed < buffer_size) { |
139 | 139 | u32 bytes_used = 0; | |
140 | sav_eav = cx231xx_find_next_SAV_EAV( | 140 | |
141 | p_buffer + bytes_parsed, /* p_buffer */ | 141 | sav_eav = cx231xx_find_next_SAV_EAV(p_buffer + bytes_parsed, /* p_buffer */ |
142 | buffer_size - bytes_parsed, /* buffer size */ | 142 | buffer_size - bytes_parsed, /* buffer size */ |
143 | &bytes_used); /* Receives bytes used to get SAV/EAV */ | 143 | &bytes_used); /* Receives bytes used to get SAV/EAV */ |
144 | 144 | ||
145 | bytes_parsed += bytes_used; | 145 | bytes_parsed += bytes_used; |
146 | 146 | ||
147 | sav_eav &= 0xF0; | 147 | sav_eav &= 0xF0; |
148 | if(sav_eav && (bytes_parsed < buffer_size)) | 148 | if (sav_eav && (bytes_parsed < buffer_size)) { |
149 | { | 149 | bytes_parsed += cx231xx_get_vbi_line(dev, dma_q, sav_eav, /* SAV/EAV */ |
150 | bytes_parsed += cx231xx_get_vbi_line(dev, dma_q, | 150 | p_buffer + bytes_parsed, /* p_buffer */ |
151 | sav_eav, /* SAV/EAV */ | 151 | buffer_size - bytes_parsed); /* buffer size */ |
152 | p_buffer + bytes_parsed, /* p_buffer */ | 152 | } |
153 | buffer_size - bytes_parsed); /* buffer size */ | 153 | } |
154 | } | 154 | |
155 | } | 155 | /* Save the last four bytes of the buffer so we can check the buffer boundary |
156 | 156 | condition next time */ | |
157 | /* Save the last four bytes of the buffer so we can check the buffer boundary | 157 | memcpy(dma_q->partial_buf, p_buffer + buffer_size - 4, 4); |
158 | condition next time */ | 158 | bytes_parsed = 0; |
159 | memcpy(dma_q->partial_buf, p_buffer + buffer_size - 4, 4); | ||
160 | bytes_parsed = 0; | ||
161 | } | 159 | } |
162 | 160 | ||
163 | return rc; | 161 | return rc; |
@@ -168,25 +166,26 @@ static inline int cx231xx_isoc_vbi_copy(struct cx231xx *dev, struct urb *urb) | |||
168 | ------------------------------------------------------------------*/ | 166 | ------------------------------------------------------------------*/ |
169 | 167 | ||
170 | static int | 168 | static int |
171 | vbi_buffer_setup(struct videobuf_queue *vq, unsigned int *count, unsigned int *size) | 169 | vbi_buffer_setup(struct videobuf_queue *vq, unsigned int *count, |
170 | unsigned int *size) | ||
172 | { | 171 | { |
173 | struct cx231xx_fh *fh = vq->priv_data; | 172 | struct cx231xx_fh *fh = vq->priv_data; |
174 | struct cx231xx *dev = fh->dev; | 173 | struct cx231xx *dev = fh->dev; |
175 | u32 height = 0; | 174 | u32 height = 0; |
176 | 175 | ||
177 | height = ((dev->norm & V4L2_STD_625_50) ? | 176 | height = ((dev->norm & V4L2_STD_625_50) ? |
178 | PAL_VBI_LINES : NTSC_VBI_LINES) ; | 177 | PAL_VBI_LINES : NTSC_VBI_LINES); |
179 | 178 | ||
180 | *size = ( dev->width * height * 2); | 179 | *size = (dev->width * height * 2); |
181 | if (0 == *count) | 180 | if (0 == *count) |
182 | *count = CX231XX_DEF_VBI_BUF; | 181 | *count = CX231XX_DEF_VBI_BUF; |
183 | 182 | ||
184 | if (*count < CX231XX_MIN_BUF) | 183 | if (*count < CX231XX_MIN_BUF) |
185 | *count = CX231XX_MIN_BUF; | 184 | *count = CX231XX_MIN_BUF; |
186 | 185 | ||
187 | /* call VBI setup if required */ | 186 | /* call VBI setup if required */ |
188 | /* cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_FREQUENCY, &f); | 187 | /* cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_FREQUENCY, &f); |
189 | */ | 188 | */ |
190 | 189 | ||
191 | return 0; | 190 | return 0; |
192 | } | 191 | } |
@@ -194,8 +193,8 @@ vbi_buffer_setup(struct videobuf_queue *vq, unsigned int *count, unsigned int *s | |||
194 | /* This is called *without* dev->slock held; please keep it that way */ | 193 | /* This is called *without* dev->slock held; please keep it that way */ |
195 | static void free_buffer(struct videobuf_queue *vq, struct cx231xx_buffer *buf) | 194 | static void free_buffer(struct videobuf_queue *vq, struct cx231xx_buffer *buf) |
196 | { | 195 | { |
197 | struct cx231xx_fh *fh = vq->priv_data; | 196 | struct cx231xx_fh *fh = vq->priv_data; |
198 | struct cx231xx *dev = fh->dev; | 197 | struct cx231xx *dev = fh->dev; |
199 | unsigned long flags = 0; | 198 | unsigned long flags = 0; |
200 | if (in_interrupt()) | 199 | if (in_interrupt()) |
201 | BUG(); | 200 | BUG(); |
@@ -208,7 +207,7 @@ static void free_buffer(struct videobuf_queue *vq, struct cx231xx_buffer *buf) | |||
208 | This should be safe; by the time we get here, the buffer isn't | 207 | This should be safe; by the time we get here, the buffer isn't |
209 | queued anymore. If we ever start marking the buffers as | 208 | queued anymore. If we ever start marking the buffers as |
210 | VIDEOBUF_ACTIVE, it won't be, though. | 209 | VIDEOBUF_ACTIVE, it won't be, though. |
211 | */ | 210 | */ |
212 | spin_lock_irqsave(&dev->vbi_mode.slock, flags); | 211 | spin_lock_irqsave(&dev->vbi_mode.slock, flags); |
213 | if (dev->vbi_mode.isoc_ctl.buf == buf) | 212 | if (dev->vbi_mode.isoc_ctl.buf == buf) |
214 | dev->vbi_mode.isoc_ctl.buf = NULL; | 213 | dev->vbi_mode.isoc_ctl.buf = NULL; |
@@ -220,25 +219,26 @@ static void free_buffer(struct videobuf_queue *vq, struct cx231xx_buffer *buf) | |||
220 | 219 | ||
221 | static int | 220 | static int |
222 | vbi_buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, | 221 | vbi_buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, |
223 | enum v4l2_field field) | 222 | enum v4l2_field field) |
224 | { | 223 | { |
225 | struct cx231xx_fh *fh = vq->priv_data; | 224 | struct cx231xx_fh *fh = vq->priv_data; |
226 | struct cx231xx_buffer *buf = container_of(vb, struct cx231xx_buffer, vb); | 225 | struct cx231xx_buffer *buf = |
227 | struct cx231xx *dev = fh->dev; | 226 | container_of(vb, struct cx231xx_buffer, vb); |
228 | int rc = 0, urb_init = 0; | 227 | struct cx231xx *dev = fh->dev; |
229 | u32 height = 0; | 228 | int rc = 0, urb_init = 0; |
229 | u32 height = 0; | ||
230 | 230 | ||
231 | height = ((dev->norm & V4L2_STD_625_50) ? | 231 | height = ((dev->norm & V4L2_STD_625_50) ? |
232 | PAL_VBI_LINES : NTSC_VBI_LINES) ; | 232 | PAL_VBI_LINES : NTSC_VBI_LINES); |
233 | buf->vb.size = ( (dev->width << 1) * height ); | 233 | buf->vb.size = ((dev->width << 1) * height); |
234 | 234 | ||
235 | if (0 != buf->vb.baddr && buf->vb.bsize < buf->vb.size) | 235 | if (0 != buf->vb.baddr && buf->vb.bsize < buf->vb.size) |
236 | return -EINVAL; | 236 | return -EINVAL; |
237 | 237 | ||
238 | buf->vb.width = dev->width; | 238 | buf->vb.width = dev->width; |
239 | buf->vb.height = height; | 239 | buf->vb.height = height; |
240 | buf->vb.field = field; | 240 | buf->vb.field = field; |
241 | buf->vb.field = V4L2_FIELD_SEQ_TB; | 241 | buf->vb.field = V4L2_FIELD_SEQ_TB; |
242 | 242 | ||
243 | if (VIDEOBUF_NEEDS_INIT == buf->vb.state) { | 243 | if (VIDEOBUF_NEEDS_INIT == buf->vb.state) { |
244 | rc = videobuf_iolock(vq, &buf->vb, NULL); | 244 | rc = videobuf_iolock(vq, &buf->vb, NULL); |
@@ -251,8 +251,9 @@ vbi_buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, | |||
251 | 251 | ||
252 | if (urb_init) { | 252 | if (urb_init) { |
253 | rc = cx231xx_init_vbi_isoc(dev, CX231XX_NUM_VBI_PACKETS, | 253 | rc = cx231xx_init_vbi_isoc(dev, CX231XX_NUM_VBI_PACKETS, |
254 | CX231XX_NUM_VBI_BUFS, dev->vbi_mode.alt_max_pkt_size[0], | 254 | CX231XX_NUM_VBI_BUFS, |
255 | cx231xx_isoc_vbi_copy); | 255 | dev->vbi_mode.alt_max_pkt_size[0], |
256 | cx231xx_isoc_vbi_copy); | ||
256 | if (rc < 0) | 257 | if (rc < 0) |
257 | goto fail; | 258 | goto fail; |
258 | } | 259 | } |
@@ -260,7 +261,7 @@ vbi_buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, | |||
260 | buf->vb.state = VIDEOBUF_PREPARED; | 261 | buf->vb.state = VIDEOBUF_PREPARED; |
261 | return 0; | 262 | return 0; |
262 | 263 | ||
263 | fail: | 264 | fail: |
264 | free_buffer(vq, buf); | 265 | free_buffer(vq, buf); |
265 | return rc; | 266 | return rc; |
266 | } | 267 | } |
@@ -268,10 +269,11 @@ fail: | |||
268 | static void | 269 | static void |
269 | vbi_buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) | 270 | vbi_buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) |
270 | { | 271 | { |
271 | struct cx231xx_buffer *buf = container_of(vb, struct cx231xx_buffer, vb); | 272 | struct cx231xx_buffer *buf = |
272 | struct cx231xx_fh *fh = vq->priv_data; | 273 | container_of(vb, struct cx231xx_buffer, vb); |
273 | struct cx231xx *dev = fh->dev; | 274 | struct cx231xx_fh *fh = vq->priv_data; |
274 | struct cx231xx_dmaqueue *vidq = &dev->vbi_mode.vidq; | 275 | struct cx231xx *dev = fh->dev; |
276 | struct cx231xx_dmaqueue *vidq = &dev->vbi_mode.vidq; | ||
275 | 277 | ||
276 | buf->vb.state = VIDEOBUF_QUEUED; | 278 | buf->vb.state = VIDEOBUF_QUEUED; |
277 | list_add_tail(&buf->vb.queue, &vidq->active); | 279 | list_add_tail(&buf->vb.queue, &vidq->active); |
@@ -279,29 +281,27 @@ vbi_buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) | |||
279 | } | 281 | } |
280 | 282 | ||
281 | static void vbi_buffer_release(struct videobuf_queue *vq, | 283 | static void vbi_buffer_release(struct videobuf_queue *vq, |
282 | struct videobuf_buffer *vb) | 284 | struct videobuf_buffer *vb) |
283 | { | 285 | { |
284 | struct cx231xx_buffer *buf = container_of(vb, struct cx231xx_buffer, vb); | 286 | struct cx231xx_buffer *buf = |
285 | /* | 287 | container_of(vb, struct cx231xx_buffer, vb); |
286 | struct cx231xx_fh *fh = vq->priv_data; | 288 | /* |
287 | struct cx231xx *dev = (struct cx231xx *)fh->dev; | 289 | struct cx231xx_fh *fh = vq->priv_data; |
290 | struct cx231xx *dev = (struct cx231xx *)fh->dev; | ||
288 | 291 | ||
289 | cx231xx_info(DRIVER_NAME "cx231xx: called vbi_buffer_release\n"); | 292 | cx231xx_info(DRIVER_NAME "cx231xx: called vbi_buffer_release\n"); |
290 | */ | 293 | */ |
291 | 294 | ||
292 | free_buffer(vq, buf); | 295 | free_buffer(vq, buf); |
293 | } | 296 | } |
294 | 297 | ||
295 | |||
296 | struct videobuf_queue_ops cx231xx_vbi_qops = { | 298 | struct videobuf_queue_ops cx231xx_vbi_qops = { |
297 | .buf_setup = vbi_buffer_setup, | 299 | .buf_setup = vbi_buffer_setup, |
298 | .buf_prepare = vbi_buffer_prepare, | 300 | .buf_prepare = vbi_buffer_prepare, |
299 | .buf_queue = vbi_buffer_queue, | 301 | .buf_queue = vbi_buffer_queue, |
300 | .buf_release = vbi_buffer_release, | 302 | .buf_release = vbi_buffer_release, |
301 | }; | 303 | }; |
302 | 304 | ||
303 | |||
304 | |||
305 | /* ------------------------------------------------------------------ | 305 | /* ------------------------------------------------------------------ |
306 | URB control | 306 | URB control |
307 | ------------------------------------------------------------------*/ | 307 | ------------------------------------------------------------------*/ |
@@ -311,23 +311,24 @@ struct videobuf_queue_ops cx231xx_vbi_qops = { | |||
311 | */ | 311 | */ |
312 | static void cx231xx_irq_vbi_callback(struct urb *urb) | 312 | static void cx231xx_irq_vbi_callback(struct urb *urb) |
313 | { | 313 | { |
314 | struct cx231xx_dmaqueue *dma_q = urb->context; | 314 | struct cx231xx_dmaqueue *dma_q = urb->context; |
315 | struct cx231xx_video_mode *vmode = container_of(dma_q, struct cx231xx_video_mode, vidq); | 315 | struct cx231xx_video_mode *vmode = |
316 | struct cx231xx *dev = container_of(vmode, struct cx231xx, vbi_mode); | 316 | container_of(dma_q, struct cx231xx_video_mode, vidq); |
317 | struct cx231xx *dev = container_of(vmode, struct cx231xx, vbi_mode); | ||
317 | int rc; | 318 | int rc; |
318 | 319 | ||
319 | 320 | switch (urb->status) { | |
320 | switch (urb->status) { | 321 | case 0: /* success */ |
321 | case 0: /* success */ | 322 | case -ETIMEDOUT: /* NAK */ |
322 | case -ETIMEDOUT: /* NAK */ | 323 | break; |
323 | break; | 324 | case -ECONNRESET: /* kill */ |
324 | case -ECONNRESET: /* kill */ | 325 | case -ENOENT: |
325 | case -ENOENT: | 326 | case -ESHUTDOWN: |
326 | case -ESHUTDOWN: | 327 | return; |
327 | return; | 328 | default: /* error */ |
328 | default: /* error */ | 329 | cx231xx_err(DRIVER_NAME "urb completition error %d.\n", |
329 | cx231xx_err(DRIVER_NAME "urb completition error %d.\n", urb->status); | 330 | urb->status); |
330 | break; | 331 | break; |
331 | } | 332 | } |
332 | 333 | ||
333 | /* Copy data from URB */ | 334 | /* Copy data from URB */ |
@@ -341,7 +342,7 @@ static void cx231xx_irq_vbi_callback(struct urb *urb) | |||
341 | urb->status = usb_submit_urb(urb, GFP_ATOMIC); | 342 | urb->status = usb_submit_urb(urb, GFP_ATOMIC); |
342 | if (urb->status) { | 343 | if (urb->status) { |
343 | cx231xx_err(DRIVER_NAME "urb resubmit failed (error=%i)\n", | 344 | cx231xx_err(DRIVER_NAME "urb resubmit failed (error=%i)\n", |
344 | urb->status); | 345 | urb->status); |
345 | } | 346 | } |
346 | } | 347 | } |
347 | 348 | ||
@@ -353,21 +354,23 @@ void cx231xx_uninit_vbi_isoc(struct cx231xx *dev) | |||
353 | struct urb *urb; | 354 | struct urb *urb; |
354 | int i; | 355 | int i; |
355 | 356 | ||
356 | cx231xx_info(DRIVER_NAME "cx231xx: called cx231xx_uninit_vbi_isoc\n"); | 357 | cx231xx_info(DRIVER_NAME "cx231xx: called cx231xx_uninit_vbi_isoc\n"); |
357 | 358 | ||
358 | dev->vbi_mode.isoc_ctl.nfields = -1; | 359 | dev->vbi_mode.isoc_ctl.nfields = -1; |
359 | for (i = 0; i < dev->vbi_mode.isoc_ctl.num_bufs; i++) { | 360 | for (i = 0; i < dev->vbi_mode.isoc_ctl.num_bufs; i++) { |
360 | urb = dev->vbi_mode.isoc_ctl.urb[i]; | 361 | urb = dev->vbi_mode.isoc_ctl.urb[i]; |
361 | if (urb) { | 362 | if (urb) { |
362 | if (!irqs_disabled()) | 363 | if (!irqs_disabled()) |
363 | usb_kill_urb(urb); | 364 | usb_kill_urb(urb); |
364 | else | 365 | else |
365 | usb_unlink_urb(urb); | 366 | usb_unlink_urb(urb); |
366 | 367 | ||
367 | if (dev->vbi_mode.isoc_ctl.transfer_buffer[i]) { | 368 | if (dev->vbi_mode.isoc_ctl.transfer_buffer[i]) { |
368 | 369 | ||
369 | kfree(dev->vbi_mode.isoc_ctl.transfer_buffer[i]); | 370 | kfree(dev->vbi_mode.isoc_ctl. |
370 | dev->vbi_mode.isoc_ctl.transfer_buffer[i] = NULL; | 371 | transfer_buffer[i]); |
372 | dev->vbi_mode.isoc_ctl.transfer_buffer[i] = | ||
373 | NULL; | ||
371 | } | 374 | } |
372 | usb_free_urb(urb); | 375 | usb_free_urb(urb); |
373 | dev->vbi_mode.isoc_ctl.urb[i] = NULL; | 376 | dev->vbi_mode.isoc_ctl.urb[i] = NULL; |
@@ -384,14 +387,16 @@ void cx231xx_uninit_vbi_isoc(struct cx231xx *dev) | |||
384 | 387 | ||
385 | cx231xx_capture_start(dev, 0, Vbi); | 388 | cx231xx_capture_start(dev, 0, Vbi); |
386 | } | 389 | } |
390 | |||
387 | EXPORT_SYMBOL_GPL(cx231xx_uninit_vbi_isoc); | 391 | EXPORT_SYMBOL_GPL(cx231xx_uninit_vbi_isoc); |
388 | 392 | ||
389 | /* | 393 | /* |
390 | * Allocate URBs and start IRQ | 394 | * Allocate URBs and start IRQ |
391 | */ | 395 | */ |
392 | int cx231xx_init_vbi_isoc(struct cx231xx *dev, int max_packets, | 396 | int cx231xx_init_vbi_isoc(struct cx231xx *dev, int max_packets, |
393 | int num_bufs, int max_pkt_size, | 397 | int num_bufs, int max_pkt_size, |
394 | int (*isoc_copy) (struct cx231xx *dev, struct urb *urb)) | 398 | int (*isoc_copy) (struct cx231xx * dev, |
399 | struct urb * urb)) | ||
395 | { | 400 | { |
396 | struct cx231xx_dmaqueue *dma_q = &dev->vbi_mode.vidq; | 401 | struct cx231xx_dmaqueue *dma_q = &dev->vbi_mode.vidq; |
397 | int i; | 402 | int i; |
@@ -404,31 +409,33 @@ int cx231xx_init_vbi_isoc(struct cx231xx *dev, int max_packets, | |||
404 | /* De-allocates all pending stuff */ | 409 | /* De-allocates all pending stuff */ |
405 | cx231xx_uninit_vbi_isoc(dev); | 410 | cx231xx_uninit_vbi_isoc(dev); |
406 | 411 | ||
407 | /* clear if any halt */ | 412 | /* clear if any halt */ |
408 | usb_clear_halt(dev->udev, usb_rcvbulkpipe(dev->udev, dev->vbi_mode.end_point_addr)); | 413 | usb_clear_halt(dev->udev, |
409 | 414 | usb_rcvbulkpipe(dev->udev, | |
415 | dev->vbi_mode.end_point_addr)); | ||
410 | 416 | ||
411 | dev->vbi_mode.isoc_ctl.isoc_copy = isoc_copy; | 417 | dev->vbi_mode.isoc_ctl.isoc_copy = isoc_copy; |
412 | dev->vbi_mode.isoc_ctl.num_bufs = num_bufs; | 418 | dev->vbi_mode.isoc_ctl.num_bufs = num_bufs; |
413 | dma_q->pos = 0; | 419 | dma_q->pos = 0; |
414 | dma_q->is_partial_line = 0; | 420 | dma_q->is_partial_line = 0; |
415 | dma_q->last_sav = 0; | 421 | dma_q->last_sav = 0; |
416 | dma_q->current_field = -1; | 422 | dma_q->current_field = -1; |
417 | dma_q->bytes_left_in_line = dev->width << 1; | 423 | dma_q->bytes_left_in_line = dev->width << 1; |
418 | dma_q->lines_per_field = ((dev->norm & V4L2_STD_625_50) ? | 424 | dma_q->lines_per_field = ((dev->norm & V4L2_STD_625_50) ? |
419 | PAL_VBI_LINES : NTSC_VBI_LINES) ; | 425 | PAL_VBI_LINES : NTSC_VBI_LINES); |
420 | dma_q->lines_completed = 0; | 426 | dma_q->lines_completed = 0; |
421 | for(i = 0; i < 8 ; i++) | 427 | for (i = 0; i < 8; i++) |
422 | dma_q->partial_buf[i] = 0; | 428 | dma_q->partial_buf[i] = 0; |
423 | 429 | ||
424 | dev->vbi_mode.isoc_ctl.urb = kzalloc(sizeof(void *)*num_bufs, GFP_KERNEL); | 430 | dev->vbi_mode.isoc_ctl.urb = |
431 | kzalloc(sizeof(void *) * num_bufs, GFP_KERNEL); | ||
425 | if (!dev->vbi_mode.isoc_ctl.urb) { | 432 | if (!dev->vbi_mode.isoc_ctl.urb) { |
426 | cx231xx_errdev("cannot alloc memory for usb buffers\n"); | 433 | cx231xx_errdev("cannot alloc memory for usb buffers\n"); |
427 | return -ENOMEM; | 434 | return -ENOMEM; |
428 | } | 435 | } |
429 | 436 | ||
430 | dev->vbi_mode.isoc_ctl.transfer_buffer = kzalloc(sizeof(void *)*num_bufs, | 437 | dev->vbi_mode.isoc_ctl.transfer_buffer = |
431 | GFP_KERNEL); | 438 | kzalloc(sizeof(void *) * num_bufs, GFP_KERNEL); |
432 | if (!dev->vbi_mode.isoc_ctl.transfer_buffer) { | 439 | if (!dev->vbi_mode.isoc_ctl.transfer_buffer) { |
433 | cx231xx_errdev("cannot allocate memory for usbtransfer\n"); | 440 | cx231xx_errdev("cannot allocate memory for usbtransfer\n"); |
434 | kfree(dev->vbi_mode.isoc_ctl.urb); | 441 | kfree(dev->vbi_mode.isoc_ctl.urb); |
@@ -445,27 +452,29 @@ int cx231xx_init_vbi_isoc(struct cx231xx *dev, int max_packets, | |||
445 | 452 | ||
446 | urb = usb_alloc_urb(0, GFP_KERNEL); | 453 | urb = usb_alloc_urb(0, GFP_KERNEL); |
447 | if (!urb) { | 454 | if (!urb) { |
448 | cx231xx_err(DRIVER_NAME ": cannot alloc isoc_ctl.urb %i\n", i); | 455 | cx231xx_err(DRIVER_NAME |
456 | ": cannot alloc isoc_ctl.urb %i\n", i); | ||
449 | cx231xx_uninit_vbi_isoc(dev); | 457 | cx231xx_uninit_vbi_isoc(dev); |
450 | return -ENOMEM; | 458 | return -ENOMEM; |
451 | } | 459 | } |
452 | dev->vbi_mode.isoc_ctl.urb[i] = urb; | 460 | dev->vbi_mode.isoc_ctl.urb[i] = urb; |
453 | urb->transfer_flags = 0; | 461 | urb->transfer_flags = 0; |
454 | 462 | ||
455 | dev->vbi_mode.isoc_ctl.transfer_buffer[i] = kzalloc(sb_size, GFP_KERNEL); | 463 | dev->vbi_mode.isoc_ctl.transfer_buffer[i] = |
464 | kzalloc(sb_size, GFP_KERNEL); | ||
456 | if (!dev->vbi_mode.isoc_ctl.transfer_buffer[i]) { | 465 | if (!dev->vbi_mode.isoc_ctl.transfer_buffer[i]) { |
457 | cx231xx_err(DRIVER_NAME ": unable to allocate %i bytes for transfer" | 466 | cx231xx_err(DRIVER_NAME |
458 | " buffer %i%s\n", | 467 | ": unable to allocate %i bytes for transfer" |
459 | sb_size, i, | 468 | " buffer %i%s\n", sb_size, i, |
460 | in_interrupt()?" while in int":""); | 469 | in_interrupt()? " while in int" : ""); |
461 | cx231xx_uninit_vbi_isoc(dev); | 470 | cx231xx_uninit_vbi_isoc(dev); |
462 | return -ENOMEM; | 471 | return -ENOMEM; |
463 | } | 472 | } |
464 | 473 | ||
465 | pipe = usb_rcvbulkpipe(dev->udev, dev->vbi_mode.end_point_addr); | 474 | pipe = usb_rcvbulkpipe(dev->udev, dev->vbi_mode.end_point_addr); |
466 | usb_fill_bulk_urb(urb, dev->udev, pipe, | 475 | usb_fill_bulk_urb(urb, dev->udev, pipe, |
467 | dev->vbi_mode.isoc_ctl.transfer_buffer[i], sb_size, | 476 | dev->vbi_mode.isoc_ctl.transfer_buffer[i], |
468 | cx231xx_irq_vbi_callback, dma_q); | 477 | sb_size, cx231xx_irq_vbi_callback, dma_q); |
469 | } | 478 | } |
470 | 479 | ||
471 | init_waitqueue_head(&dma_q->wq); | 480 | init_waitqueue_head(&dma_q->wq); |
@@ -474,55 +483,58 @@ int cx231xx_init_vbi_isoc(struct cx231xx *dev, int max_packets, | |||
474 | for (i = 0; i < dev->vbi_mode.isoc_ctl.num_bufs; i++) { | 483 | for (i = 0; i < dev->vbi_mode.isoc_ctl.num_bufs; i++) { |
475 | rc = usb_submit_urb(dev->vbi_mode.isoc_ctl.urb[i], GFP_ATOMIC); | 484 | rc = usb_submit_urb(dev->vbi_mode.isoc_ctl.urb[i], GFP_ATOMIC); |
476 | if (rc) { | 485 | if (rc) { |
477 | cx231xx_err(DRIVER_NAME ": submit of urb %i failed (error=%i)\n", i, | 486 | cx231xx_err(DRIVER_NAME |
478 | rc); | 487 | ": submit of urb %i failed (error=%i)\n", i, |
488 | rc); | ||
479 | cx231xx_uninit_vbi_isoc(dev); | 489 | cx231xx_uninit_vbi_isoc(dev); |
480 | return rc; | 490 | return rc; |
481 | } | 491 | } |
482 | } | 492 | } |
483 | 493 | ||
484 | cx231xx_capture_start(dev, 1, Vbi); | 494 | cx231xx_capture_start(dev, 1, Vbi); |
485 | 495 | ||
486 | return 0; | 496 | return 0; |
487 | } | 497 | } |
488 | EXPORT_SYMBOL_GPL(cx231xx_init_vbi_isoc); | ||
489 | 498 | ||
499 | EXPORT_SYMBOL_GPL(cx231xx_init_vbi_isoc); | ||
490 | 500 | ||
491 | u32 cx231xx_get_vbi_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 501 | u32 cx231xx_get_vbi_line(struct cx231xx * dev, struct cx231xx_dmaqueue * dma_q, |
492 | u8 sav_eav, u8 *p_buffer, u32 buffer_size) | 502 | u8 sav_eav, u8 * p_buffer, u32 buffer_size) |
493 | { | 503 | { |
494 | u32 bytes_copied = 0; | 504 | u32 bytes_copied = 0; |
495 | int current_field = -1; | 505 | int current_field = -1; |
496 | 506 | ||
497 | switch(sav_eav) { | 507 | switch (sav_eav) { |
498 | 508 | ||
499 | case SAV_VBI_FIELD1: | 509 | case SAV_VBI_FIELD1: |
500 | current_field = 1; | 510 | current_field = 1; |
501 | break; | 511 | break; |
502 | 512 | ||
503 | case SAV_VBI_FIELD2: | 513 | case SAV_VBI_FIELD2: |
504 | current_field = 2; | 514 | current_field = 2; |
505 | break; | 515 | break; |
506 | default: | 516 | default: |
507 | break; | 517 | break; |
508 | } | 518 | } |
509 | 519 | ||
510 | if(current_field < 0 ) | 520 | if (current_field < 0) |
511 | return bytes_copied; | 521 | return bytes_copied; |
512 | 522 | ||
513 | dma_q->last_sav = sav_eav; | 523 | dma_q->last_sav = sav_eav; |
514 | 524 | ||
515 | bytes_copied = cx231xx_copy_vbi_line(dev, dma_q, p_buffer, buffer_size, current_field); | 525 | bytes_copied = |
526 | cx231xx_copy_vbi_line(dev, dma_q, p_buffer, buffer_size, | ||
527 | current_field); | ||
516 | 528 | ||
517 | return bytes_copied; | 529 | return bytes_copied; |
518 | } | 530 | } |
519 | 531 | ||
520 | /* | 532 | /* |
521 | * Announces that a buffer were filled and request the next | 533 | * Announces that a buffer were filled and request the next |
522 | */ | 534 | */ |
523 | static inline void vbi_buffer_filled(struct cx231xx *dev, | 535 | static inline void vbi_buffer_filled(struct cx231xx *dev, |
524 | struct cx231xx_dmaqueue *dma_q, | 536 | struct cx231xx_dmaqueue *dma_q, |
525 | struct cx231xx_buffer *buf) | 537 | struct cx231xx_buffer *buf) |
526 | { | 538 | { |
527 | /* Advice that buffer was filled */ | 539 | /* Advice that buffer was filled */ |
528 | /* cx231xx_info(DRIVER_NAME "[%p/%d] wakeup\n", buf, buf->vb.i); */ | 540 | /* cx231xx_info(DRIVER_NAME "[%p/%d] wakeup\n", buf, buf->vb.i); */ |
@@ -537,80 +549,83 @@ static inline void vbi_buffer_filled(struct cx231xx *dev, | |||
537 | wake_up(&buf->vb.done); | 549 | wake_up(&buf->vb.done); |
538 | } | 550 | } |
539 | 551 | ||
540 | u32 cx231xx_copy_vbi_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 552 | u32 cx231xx_copy_vbi_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
541 | u8 *p_line, u32 length, int field_number) | 553 | u8 * p_line, u32 length, int field_number) |
542 | { | 554 | { |
543 | u32 bytes_to_copy; | 555 | u32 bytes_to_copy; |
544 | struct cx231xx_buffer *buf; | 556 | struct cx231xx_buffer *buf; |
545 | u32 _line_size = dev->width * 2; | 557 | u32 _line_size = dev->width * 2; |
546 | 558 | ||
547 | if( dma_q->current_field != field_number ) { | 559 | if (dma_q->current_field != field_number) { |
548 | cx231xx_reset_vbi_buffer(dev, dma_q); | 560 | cx231xx_reset_vbi_buffer(dev, dma_q); |
549 | } | 561 | } |
550 | 562 | ||
551 | /* get the buffer pointer */ | 563 | /* get the buffer pointer */ |
552 | buf = dev->vbi_mode.isoc_ctl.buf; | 564 | buf = dev->vbi_mode.isoc_ctl.buf; |
553 | 565 | ||
554 | /* Remember the field number for next time */ | 566 | /* Remember the field number for next time */ |
555 | dma_q->current_field = field_number; | 567 | dma_q->current_field = field_number; |
556 | 568 | ||
557 | bytes_to_copy = dma_q->bytes_left_in_line; | 569 | bytes_to_copy = dma_q->bytes_left_in_line; |
558 | if(bytes_to_copy > length) | 570 | if (bytes_to_copy > length) |
559 | bytes_to_copy = length; | 571 | bytes_to_copy = length; |
560 | 572 | ||
561 | if(dma_q->lines_completed >= dma_q->lines_per_field) { | 573 | if (dma_q->lines_completed >= dma_q->lines_per_field) { |
562 | dma_q->bytes_left_in_line -= bytes_to_copy; | 574 | dma_q->bytes_left_in_line -= bytes_to_copy; |
563 | dma_q->is_partial_line = (dma_q->bytes_left_in_line == 0) ? 0 : 1; | 575 | dma_q->is_partial_line = |
564 | return 0; | 576 | (dma_q->bytes_left_in_line == 0) ? 0 : 1; |
565 | } | 577 | return 0; |
578 | } | ||
566 | 579 | ||
567 | dma_q->is_partial_line = 1; | 580 | dma_q->is_partial_line = 1; |
568 | 581 | ||
569 | /* If we don't have a buffer, just return the number of bytes we would | 582 | /* If we don't have a buffer, just return the number of bytes we would |
570 | have copied if we had a buffer. */ | 583 | have copied if we had a buffer. */ |
571 | if(!buf) { | 584 | if (!buf) { |
572 | dma_q->bytes_left_in_line -= bytes_to_copy; | 585 | dma_q->bytes_left_in_line -= bytes_to_copy; |
573 | dma_q->is_partial_line = (dma_q->bytes_left_in_line == 0) ? 0 : 1; | 586 | dma_q->is_partial_line = |
574 | return bytes_to_copy; | 587 | (dma_q->bytes_left_in_line == 0) ? 0 : 1; |
575 | } | 588 | return bytes_to_copy; |
589 | } | ||
576 | 590 | ||
577 | /* copy the data to video buffer */ | 591 | /* copy the data to video buffer */ |
578 | cx231xx_do_vbi_copy(dev, dma_q, p_line, bytes_to_copy); | 592 | cx231xx_do_vbi_copy(dev, dma_q, p_line, bytes_to_copy); |
579 | 593 | ||
580 | dma_q->pos += bytes_to_copy; | 594 | dma_q->pos += bytes_to_copy; |
581 | dma_q->bytes_left_in_line -= bytes_to_copy; | 595 | dma_q->bytes_left_in_line -= bytes_to_copy; |
582 | 596 | ||
583 | if(dma_q->bytes_left_in_line == 0) { | 597 | if (dma_q->bytes_left_in_line == 0) { |
584 | 598 | ||
585 | dma_q->bytes_left_in_line = _line_size; | 599 | dma_q->bytes_left_in_line = _line_size; |
586 | dma_q->lines_completed++; | 600 | dma_q->lines_completed++; |
587 | dma_q->is_partial_line = 0; | 601 | dma_q->is_partial_line = 0; |
588 | 602 | ||
589 | if(cx231xx_is_vbi_buffer_done(dev, dma_q) && buf ) { | 603 | if (cx231xx_is_vbi_buffer_done(dev, dma_q) && buf) { |
590 | 604 | ||
591 | vbi_buffer_filled(dev, dma_q, buf); | 605 | vbi_buffer_filled(dev, dma_q, buf); |
592 | 606 | ||
593 | dma_q->pos = 0; | 607 | dma_q->pos = 0; |
594 | buf = NULL; | 608 | buf = NULL; |
595 | dma_q->lines_completed = 0; | 609 | dma_q->lines_completed = 0; |
596 | } | 610 | } |
597 | } | 611 | } |
598 | 612 | ||
599 | return bytes_to_copy; | 613 | return bytes_to_copy; |
600 | } | 614 | } |
601 | 615 | ||
602 | /* | 616 | /* |
603 | * video-buf generic routine to get the next available buffer | 617 | * video-buf generic routine to get the next available buffer |
604 | */ | 618 | */ |
605 | static inline void get_next_vbi_buf(struct cx231xx_dmaqueue *dma_q, | 619 | static inline void get_next_vbi_buf(struct cx231xx_dmaqueue *dma_q, |
606 | struct cx231xx_buffer **buf) | 620 | struct cx231xx_buffer **buf) |
607 | { | 621 | { |
608 | struct cx231xx_video_mode *vmode = container_of(dma_q, struct cx231xx_video_mode, vidq); | 622 | struct cx231xx_video_mode *vmode = |
609 | struct cx231xx *dev = container_of(vmode, struct cx231xx, vbi_mode); | 623 | container_of(dma_q, struct cx231xx_video_mode, vidq); |
624 | struct cx231xx *dev = container_of(vmode, struct cx231xx, vbi_mode); | ||
610 | char *outp; | 625 | char *outp; |
611 | 626 | ||
612 | if (list_empty(&dma_q->active)) { | 627 | if (list_empty(&dma_q->active)) { |
613 | cx231xx_err(DRIVER_NAME ": No active queue to serve\n"); | 628 | cx231xx_err(DRIVER_NAME ": No active queue to serve\n"); |
614 | dev->vbi_mode.isoc_ctl.buf = NULL; | 629 | dev->vbi_mode.isoc_ctl.buf = NULL; |
615 | *buf = NULL; | 630 | *buf = NULL; |
616 | return; | 631 | return; |
@@ -628,66 +643,70 @@ static inline void get_next_vbi_buf(struct cx231xx_dmaqueue *dma_q, | |||
628 | return; | 643 | return; |
629 | } | 644 | } |
630 | 645 | ||
631 | 646 | void cx231xx_reset_vbi_buffer(struct cx231xx *dev, | |
632 | void cx231xx_reset_vbi_buffer(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q) | 647 | struct cx231xx_dmaqueue *dma_q) |
633 | { | 648 | { |
634 | struct cx231xx_buffer *buf; | 649 | struct cx231xx_buffer *buf; |
635 | 650 | ||
636 | buf = dev->vbi_mode.isoc_ctl.buf; | 651 | buf = dev->vbi_mode.isoc_ctl.buf; |
637 | 652 | ||
638 | if(buf == NULL) { | 653 | if (buf == NULL) { |
639 | 654 | ||
640 | /* first try to get the buffer */ | 655 | /* first try to get the buffer */ |
641 | get_next_vbi_buf(dma_q, &buf); | 656 | get_next_vbi_buf(dma_q, &buf); |
642 | 657 | ||
643 | dma_q->pos = 0; | 658 | dma_q->pos = 0; |
644 | dma_q->current_field = -1; | 659 | dma_q->current_field = -1; |
645 | } | 660 | } |
646 | 661 | ||
647 | dma_q->bytes_left_in_line = dev->width << 1; | 662 | dma_q->bytes_left_in_line = dev->width << 1; |
648 | dma_q->lines_completed = 0; | 663 | dma_q->lines_completed = 0; |
649 | } | 664 | } |
650 | 665 | ||
651 | int cx231xx_do_vbi_copy(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 666 | int cx231xx_do_vbi_copy(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
652 | u8 *p_buffer, u32 bytes_to_copy) | 667 | u8 * p_buffer, u32 bytes_to_copy) |
653 | { | 668 | { |
654 | u8 *p_out_buffer = NULL; | 669 | u8 *p_out_buffer = NULL; |
655 | u32 current_line_bytes_copied = 0; | 670 | u32 current_line_bytes_copied = 0; |
656 | struct cx231xx_buffer *buf; | 671 | struct cx231xx_buffer *buf; |
657 | u32 _line_size = dev->width << 1; | 672 | u32 _line_size = dev->width << 1; |
658 | void *startwrite; | 673 | void *startwrite; |
659 | int offset, lencopy; | 674 | int offset, lencopy; |
660 | 675 | ||
661 | buf = dev->vbi_mode.isoc_ctl.buf; | 676 | buf = dev->vbi_mode.isoc_ctl.buf; |
662 | 677 | ||
663 | if (buf == NULL) { | 678 | if (buf == NULL) { |
664 | return -1; | 679 | return -1; |
665 | } | 680 | } |
666 | 681 | ||
667 | p_out_buffer = videobuf_to_vmalloc(&buf->vb); | 682 | p_out_buffer = videobuf_to_vmalloc(&buf->vb); |
668 | 683 | ||
669 | if(dma_q->bytes_left_in_line != _line_size ) { | 684 | if (dma_q->bytes_left_in_line != _line_size) { |
670 | current_line_bytes_copied = _line_size - dma_q->bytes_left_in_line; | 685 | current_line_bytes_copied = |
671 | } | 686 | _line_size - dma_q->bytes_left_in_line; |
687 | } | ||
672 | 688 | ||
673 | offset = ( dma_q->lines_completed * _line_size ) + current_line_bytes_copied; | 689 | offset = |
690 | (dma_q->lines_completed * _line_size) + current_line_bytes_copied; | ||
674 | 691 | ||
675 | /* prepare destination address */ | 692 | /* prepare destination address */ |
676 | startwrite = p_out_buffer + offset; | 693 | startwrite = p_out_buffer + offset; |
677 | 694 | ||
678 | lencopy = dma_q->bytes_left_in_line > bytes_to_copy ? bytes_to_copy : dma_q->bytes_left_in_line; | 695 | lencopy = |
696 | dma_q->bytes_left_in_line > | ||
697 | bytes_to_copy ? bytes_to_copy : dma_q->bytes_left_in_line; | ||
679 | 698 | ||
680 | memcpy(startwrite, p_buffer, lencopy); | 699 | memcpy(startwrite, p_buffer, lencopy); |
681 | 700 | ||
682 | return 0; | 701 | return 0; |
683 | } | 702 | } |
684 | 703 | ||
685 | 704 | u8 cx231xx_is_vbi_buffer_done(struct cx231xx * dev, | |
686 | u8 cx231xx_is_vbi_buffer_done(struct cx231xx *dev,struct cx231xx_dmaqueue *dma_q) | 705 | struct cx231xx_dmaqueue * dma_q) |
687 | { | 706 | { |
688 | u32 height = 0; | 707 | u32 height = 0; |
689 | 708 | ||
690 | height = ((dev->norm & V4L2_STD_625_50) ? | 709 | height = ((dev->norm & V4L2_STD_625_50) ? |
691 | PAL_VBI_LINES : NTSC_VBI_LINES) ; | 710 | PAL_VBI_LINES : NTSC_VBI_LINES); |
692 | return (dma_q->lines_completed == height)?1:0; | 711 | return (dma_q->lines_completed == height) ? 1 : 0; |
693 | } | 712 | } |
diff --git a/drivers/media/video/cx231xx/cx231xx-vbi.h b/drivers/media/video/cx231xx/cx231xx-vbi.h index 2a9e4a1668bf..c0d89b1e2725 100644 --- a/drivers/media/video/cx231xx/cx231xx-vbi.h +++ b/drivers/media/video/cx231xx/cx231xx-vbi.h | |||
@@ -2,7 +2,7 @@ | |||
2 | cx231xx_vbi.h - driver for Conexant Cx23100/101/102 USB video capture devices | 2 | cx231xx_vbi.h - driver for Conexant Cx23100/101/102 USB video capture devices |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on cx88 driver | 5 | Based on cx88 driver |
6 | 6 | ||
7 | This program is free software; you can redistribute it and/or modify | 7 | This program is free software; you can redistribute it and/or modify |
8 | it under the terms of the GNU General Public License as published by | 8 | it under the terms of the GNU General Public License as published by |
@@ -24,8 +24,7 @@ | |||
24 | 24 | ||
25 | extern struct videobuf_queue_ops cx231xx_vbi_qops; | 25 | extern struct videobuf_queue_ops cx231xx_vbi_qops; |
26 | 26 | ||
27 | 27 | #define NTSC_VBI_START_LINE 10 /* line 10 - 21 */ | |
28 | #define NTSC_VBI_START_LINE 10 /* line 10 - 21 */ | ||
29 | #define NTSC_VBI_END_LINE 21 | 28 | #define NTSC_VBI_END_LINE 21 |
30 | #define NTSC_VBI_LINES (NTSC_VBI_END_LINE - NTSC_VBI_START_LINE + 1) | 29 | #define NTSC_VBI_LINES (NTSC_VBI_END_LINE - NTSC_VBI_START_LINE + 1) |
31 | 30 | ||
@@ -41,21 +40,24 @@ extern struct videobuf_queue_ops cx231xx_vbi_qops; | |||
41 | 40 | ||
42 | /* stream functions */ | 41 | /* stream functions */ |
43 | int cx231xx_init_vbi_isoc(struct cx231xx *dev, int max_packets, | 42 | int cx231xx_init_vbi_isoc(struct cx231xx *dev, int max_packets, |
44 | int num_bufs, int max_pkt_size, | 43 | int num_bufs, int max_pkt_size, |
45 | int (*isoc_copy) (struct cx231xx *dev, struct urb *urb)); | 44 | int (*isoc_copy) (struct cx231xx * dev, |
45 | struct urb * urb)); | ||
46 | 46 | ||
47 | void cx231xx_uninit_vbi_isoc(struct cx231xx *dev); | 47 | void cx231xx_uninit_vbi_isoc(struct cx231xx *dev); |
48 | 48 | ||
49 | /* vbi data copy functions */ | 49 | /* vbi data copy functions */ |
50 | u32 cx231xx_get_vbi_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 50 | u32 cx231xx_get_vbi_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
51 | u8 sav_eav, u8 *p_buffer, u32 buffer_size); | 51 | u8 sav_eav, u8 * p_buffer, u32 buffer_size); |
52 | u32 cx231xx_copy_vbi_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 52 | u32 cx231xx_copy_vbi_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
53 | u8 *p_line, u32 length, int field_number); | 53 | u8 * p_line, u32 length, int field_number); |
54 | void cx231xx_reset_vbi_buffer(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q); | 54 | void cx231xx_reset_vbi_buffer(struct cx231xx *dev, |
55 | struct cx231xx_dmaqueue *dma_q); | ||
55 | 56 | ||
56 | int cx231xx_do_vbi_copy(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 57 | int cx231xx_do_vbi_copy(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
57 | u8 *p_buffer, u32 bytes_to_copy); | 58 | u8 * p_buffer, u32 bytes_to_copy); |
58 | 59 | ||
59 | u8 cx231xx_is_vbi_buffer_done(struct cx231xx *dev,struct cx231xx_dmaqueue *dma_q); | 60 | u8 cx231xx_is_vbi_buffer_done(struct cx231xx *dev, |
61 | struct cx231xx_dmaqueue *dma_q); | ||
60 | 62 | ||
61 | #endif | 63 | #endif |
diff --git a/drivers/media/video/cx231xx/cx231xx-video.c b/drivers/media/video/cx231xx/cx231xx-video.c index 3eb5626ead1d..18919e0f0194 100644 --- a/drivers/media/video/cx231xx/cx231xx-video.c +++ b/drivers/media/video/cx231xx/cx231xx-video.c | |||
@@ -2,9 +2,9 @@ | |||
2 | cx231xx-video.c - driver for Conexant Cx23100/101/102 USB video capture devices | 2 | cx231xx-video.c - driver for Conexant Cx23100/101/102 USB video capture devices |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on em28xx driver | 5 | Based on em28xx driver |
6 | Based on cx23885 driver | 6 | Based on cx23885 driver |
7 | Based on cx88 driver | 7 | Based on cx88 driver |
8 | 8 | ||
9 | This program is free software; you can redistribute it and/or modify | 9 | This program is free software; you can redistribute it and/or modify |
10 | it under the terms of the GNU General Public License as published by | 10 | it under the terms of the GNU General Public License as published by |
@@ -21,7 +21,6 @@ | |||
21 | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 21 | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
22 | */ | 22 | */ |
23 | 23 | ||
24 | |||
25 | #include <linux/init.h> | 24 | #include <linux/init.h> |
26 | #include <linux/list.h> | 25 | #include <linux/list.h> |
27 | #include <linux/module.h> | 26 | #include <linux/module.h> |
@@ -44,11 +43,9 @@ | |||
44 | #include "cx231xx.h" | 43 | #include "cx231xx.h" |
45 | #include "cx231xx-vbi.h" | 44 | #include "cx231xx-vbi.h" |
46 | 45 | ||
47 | |||
48 | #define DRIVER_AUTHOR "Srinivasa Deevi <srinivasa.deevi@conexant.com>" | 46 | #define DRIVER_AUTHOR "Srinivasa Deevi <srinivasa.deevi@conexant.com>" |
49 | #define DRIVER_DESC "Conexant cx231xx based USB video device driver" | 47 | #define DRIVER_DESC "Conexant cx231xx based USB video device driver" |
50 | 48 | ||
51 | |||
52 | #define cx231xx_videodbg(fmt, arg...) do {\ | 49 | #define cx231xx_videodbg(fmt, arg...) do {\ |
53 | if (video_debug) \ | 50 | if (video_debug) \ |
54 | printk(KERN_INFO "%s %s :"fmt, \ | 51 | printk(KERN_INFO "%s %s :"fmt, \ |
@@ -70,138 +67,133 @@ MODULE_AUTHOR(DRIVER_AUTHOR); | |||
70 | MODULE_DESCRIPTION(DRIVER_DESC); | 67 | MODULE_DESCRIPTION(DRIVER_DESC); |
71 | MODULE_LICENSE("GPL"); | 68 | MODULE_LICENSE("GPL"); |
72 | 69 | ||
73 | |||
74 | |||
75 | static unsigned int card[] = {[0 ... (CX231XX_MAXBOARDS - 1)] = UNSET }; | 70 | static unsigned int card[] = {[0 ... (CX231XX_MAXBOARDS - 1)] = UNSET }; |
76 | static unsigned int video_nr[] = {[0 ... (CX231XX_MAXBOARDS - 1)] = UNSET }; | 71 | static unsigned int video_nr[] = {[0 ... (CX231XX_MAXBOARDS - 1)] = UNSET }; |
77 | static unsigned int vbi_nr[] = {[0 ... (CX231XX_MAXBOARDS - 1)] = UNSET }; | 72 | static unsigned int vbi_nr[] = {[0 ... (CX231XX_MAXBOARDS - 1)] = UNSET }; |
78 | static unsigned int radio_nr[] = {[0 ... (CX231XX_MAXBOARDS - 1)] = UNSET }; | 73 | static unsigned int radio_nr[] = {[0 ... (CX231XX_MAXBOARDS - 1)] = UNSET }; |
79 | 74 | ||
80 | module_param_array(card, int, NULL, 0444); | 75 | module_param_array(card, int, NULL, 0444); |
81 | module_param_array(video_nr, int, NULL, 0444); | 76 | module_param_array(video_nr, int, NULL, 0444); |
82 | module_param_array(vbi_nr, int, NULL, 0444); | 77 | module_param_array(vbi_nr, int, NULL, 0444); |
83 | module_param_array(radio_nr, int, NULL, 0444); | 78 | module_param_array(radio_nr, int, NULL, 0444); |
84 | 79 | ||
85 | MODULE_PARM_DESC(card, "card type"); | 80 | MODULE_PARM_DESC(card, "card type"); |
86 | MODULE_PARM_DESC(video_nr, "video device numbers"); | 81 | MODULE_PARM_DESC(video_nr, "video device numbers"); |
87 | MODULE_PARM_DESC(vbi_nr, "vbi device numbers"); | 82 | MODULE_PARM_DESC(vbi_nr, "vbi device numbers"); |
88 | MODULE_PARM_DESC(radio_nr, "radio device numbers"); | 83 | MODULE_PARM_DESC(radio_nr, "radio device numbers"); |
89 | 84 | ||
90 | static unsigned int video_debug; | 85 | static unsigned int video_debug; |
91 | module_param(video_debug, int, 0644); | 86 | module_param(video_debug, int, 0644); |
92 | MODULE_PARM_DESC(video_debug, "enable debug messages [video]"); | 87 | MODULE_PARM_DESC(video_debug, "enable debug messages [video]"); |
93 | 88 | ||
94 | |||
95 | |||
96 | /* supported video standards */ | 89 | /* supported video standards */ |
97 | static struct cx231xx_fmt format[] = { | 90 | static struct cx231xx_fmt format[] = { |
98 | { | 91 | { |
99 | .name = "16bpp YUY2, 4:2:2, packed", | 92 | .name = "16bpp YUY2, 4:2:2, packed", |
100 | .fourcc = V4L2_PIX_FMT_YUYV, | 93 | .fourcc = V4L2_PIX_FMT_YUYV, |
101 | .depth = 16, | 94 | .depth = 16, |
102 | .reg = 0, | 95 | .reg = 0, |
103 | }, | 96 | }, |
104 | }; | 97 | }; |
105 | 98 | ||
106 | |||
107 | /* supported controls */ | 99 | /* supported controls */ |
108 | /* Common to all boards */ | 100 | /* Common to all boards */ |
109 | 101 | ||
110 | /* ------------------------------------------------------------------- */ | 102 | /* ------------------------------------------------------------------- */ |
111 | 103 | ||
112 | static const struct v4l2_queryctrl no_ctl = { | 104 | static const struct v4l2_queryctrl no_ctl = { |
113 | .name = "42", | 105 | .name = "42", |
114 | .flags = V4L2_CTRL_FLAG_DISABLED, | 106 | .flags = V4L2_CTRL_FLAG_DISABLED, |
115 | }; | 107 | }; |
116 | 108 | ||
117 | static struct cx231xx_ctrl cx231xx_ctls[] = { | 109 | static struct cx231xx_ctrl cx231xx_ctls[] = { |
118 | /* --- video --- */ | 110 | /* --- video --- */ |
119 | { | 111 | { |
120 | .v = { | 112 | .v = { |
121 | .id = V4L2_CID_BRIGHTNESS, | 113 | .id = V4L2_CID_BRIGHTNESS, |
122 | .name = "Brightness", | 114 | .name = "Brightness", |
123 | .minimum = 0x00, | 115 | .minimum = 0x00, |
124 | .maximum = 0xff, | 116 | .maximum = 0xff, |
125 | .step = 1, | 117 | .step = 1, |
126 | .default_value = 0x7f, | 118 | .default_value = 0x7f, |
127 | .type = V4L2_CTRL_TYPE_INTEGER, | 119 | .type = V4L2_CTRL_TYPE_INTEGER, |
128 | }, | 120 | }, |
129 | .off = 128, | 121 | .off = 128, |
130 | .reg = LUMA_CTRL, | 122 | .reg = LUMA_CTRL, |
131 | .mask = 0x00ff, | 123 | .mask = 0x00ff, |
132 | .shift = 0, | 124 | .shift = 0, |
133 | }, { | 125 | }, { |
134 | .v = { | 126 | .v = { |
135 | .id = V4L2_CID_CONTRAST, | 127 | .id = V4L2_CID_CONTRAST, |
136 | .name = "Contrast", | 128 | .name = "Contrast", |
137 | .minimum = 0, | 129 | .minimum = 0, |
138 | .maximum = 0xff, | 130 | .maximum = 0xff, |
139 | .step = 1, | 131 | .step = 1, |
140 | .default_value = 0x3f, | 132 | .default_value = 0x3f, |
141 | .type = V4L2_CTRL_TYPE_INTEGER, | 133 | .type = V4L2_CTRL_TYPE_INTEGER, |
142 | }, | 134 | }, |
143 | .off = 0, | 135 | .off = 0, |
144 | .reg = LUMA_CTRL, | 136 | .reg = LUMA_CTRL, |
145 | .mask = 0xff00, | 137 | .mask = 0xff00, |
146 | .shift = 8, | 138 | .shift = 8, |
147 | }, { | 139 | }, { |
148 | .v = { | 140 | .v = { |
149 | .id = V4L2_CID_HUE, | 141 | .id = V4L2_CID_HUE, |
150 | .name = "Hue", | 142 | .name = "Hue", |
151 | .minimum = 0, | 143 | .minimum = 0, |
152 | .maximum = 0xff, | 144 | .maximum = 0xff, |
153 | .step = 1, | 145 | .step = 1, |
154 | .default_value = 0x7f, | 146 | .default_value = 0x7f, |
155 | .type = V4L2_CTRL_TYPE_INTEGER, | 147 | .type = V4L2_CTRL_TYPE_INTEGER, |
156 | }, | 148 | }, |
157 | .off = 128, | 149 | .off = 128, |
158 | .reg = CHROMA_CTRL, | 150 | .reg = CHROMA_CTRL, |
159 | .mask = 0xff0000, | 151 | .mask = 0xff0000, |
160 | .shift = 16, | 152 | .shift = 16, |
161 | }, { | 153 | }, { |
162 | /* strictly, this only describes only U saturation. | 154 | /* strictly, this only describes only U saturation. |
163 | * V saturation is handled specially through code. | 155 | * V saturation is handled specially through code. |
164 | */ | 156 | */ |
165 | .v = { | 157 | .v = { |
166 | .id = V4L2_CID_SATURATION, | 158 | .id = V4L2_CID_SATURATION, |
167 | .name = "Saturation", | 159 | .name = "Saturation", |
168 | .minimum = 0, | 160 | .minimum = 0, |
169 | .maximum = 0xff, | 161 | .maximum = 0xff, |
170 | .step = 1, | 162 | .step = 1, |
171 | .default_value = 0x7f, | 163 | .default_value = 0x7f, |
172 | .type = V4L2_CTRL_TYPE_INTEGER, | 164 | .type = V4L2_CTRL_TYPE_INTEGER, |
173 | }, | 165 | }, |
174 | .off = 0, | 166 | .off = 0, |
175 | .reg = CHROMA_CTRL, | 167 | .reg = CHROMA_CTRL, |
176 | .mask = 0x00ff, | 168 | .mask = 0x00ff, |
177 | .shift = 0, | 169 | .shift = 0, |
178 | }, { | 170 | }, { |
179 | /* --- audio --- */ | 171 | /* --- audio --- */ |
180 | .v = { | 172 | .v = { |
181 | .id = V4L2_CID_AUDIO_MUTE, | 173 | .id = V4L2_CID_AUDIO_MUTE, |
182 | .name = "Mute", | 174 | .name = "Mute", |
183 | .minimum = 0, | 175 | .minimum = 0, |
184 | .maximum = 1, | 176 | .maximum = 1, |
185 | .default_value = 1, | 177 | .default_value = 1, |
186 | .type = V4L2_CTRL_TYPE_BOOLEAN, | 178 | .type = V4L2_CTRL_TYPE_BOOLEAN, |
187 | }, | 179 | }, |
188 | .reg = PATH1_CTL1, | 180 | .reg = PATH1_CTL1, |
189 | .mask = (0x1f << 24), | 181 | .mask = (0x1f << 24), |
190 | .shift = 24, | 182 | .shift = 24, |
191 | }, { | 183 | }, { |
192 | .v = { | 184 | .v = { |
193 | .id = V4L2_CID_AUDIO_VOLUME, | 185 | .id = V4L2_CID_AUDIO_VOLUME, |
194 | .name = "Volume", | 186 | .name = "Volume", |
195 | .minimum = 0, | 187 | .minimum = 0, |
196 | .maximum = 0x3f, | 188 | .maximum = 0x3f, |
197 | .step = 1, | 189 | .step = 1, |
198 | .default_value = 0x3f, | 190 | .default_value = 0x3f, |
199 | .type = V4L2_CTRL_TYPE_INTEGER, | 191 | .type = V4L2_CTRL_TYPE_INTEGER, |
200 | }, | 192 | }, |
201 | .reg = PATH1_VOL_CTL, | 193 | .reg = PATH1_VOL_CTL, |
202 | .mask = 0xff, | 194 | .mask = 0xff, |
203 | .shift = 0, | 195 | .shift = 0, |
204 | } | 196 | } |
205 | }; | 197 | }; |
206 | static const int CX231XX_CTLS = ARRAY_SIZE(cx231xx_ctls); | 198 | static const int CX231XX_CTLS = ARRAY_SIZE(cx231xx_ctls); |
207 | 199 | ||
@@ -224,7 +216,6 @@ static const u32 *ctrl_classes[] = { | |||
224 | NULL | 216 | NULL |
225 | }; | 217 | }; |
226 | 218 | ||
227 | |||
228 | /* ------------------------------------------------------------------ | 219 | /* ------------------------------------------------------------------ |
229 | Video buffer and parser functions | 220 | Video buffer and parser functions |
230 | ------------------------------------------------------------------*/ | 221 | ------------------------------------------------------------------*/ |
@@ -233,8 +224,8 @@ static const u32 *ctrl_classes[] = { | |||
233 | * Announces that a buffer were filled and request the next | 224 | * Announces that a buffer were filled and request the next |
234 | */ | 225 | */ |
235 | static inline void buffer_filled(struct cx231xx *dev, | 226 | static inline void buffer_filled(struct cx231xx *dev, |
236 | struct cx231xx_dmaqueue *dma_q, | 227 | struct cx231xx_dmaqueue *dma_q, |
237 | struct cx231xx_buffer *buf) | 228 | struct cx231xx_buffer *buf) |
238 | { | 229 | { |
239 | /* Advice that buffer was filled */ | 230 | /* Advice that buffer was filled */ |
240 | cx231xx_isocdbg("[%p/%d] wakeup\n", buf, buf->vb.i); | 231 | cx231xx_isocdbg("[%p/%d] wakeup\n", buf, buf->vb.i); |
@@ -248,9 +239,7 @@ static inline void buffer_filled(struct cx231xx *dev, | |||
248 | wake_up(&buf->vb.done); | 239 | wake_up(&buf->vb.done); |
249 | } | 240 | } |
250 | 241 | ||
251 | 242 | static inline void print_err_status(struct cx231xx *dev, int packet, int status) | |
252 | static inline void print_err_status(struct cx231xx *dev, | ||
253 | int packet, int status) | ||
254 | { | 243 | { |
255 | char *errmsg = "Unknown"; | 244 | char *errmsg = "Unknown"; |
256 | 245 | ||
@@ -281,10 +270,10 @@ static inline void print_err_status(struct cx231xx *dev, | |||
281 | break; | 270 | break; |
282 | } | 271 | } |
283 | if (packet < 0) { | 272 | if (packet < 0) { |
284 | cx231xx_isocdbg("URB status %d [%s].\n", status, errmsg); | 273 | cx231xx_isocdbg("URB status %d [%s].\n", status, errmsg); |
285 | } else { | 274 | } else { |
286 | cx231xx_isocdbg("URB packet %d, status %d [%s].\n", | 275 | cx231xx_isocdbg("URB packet %d, status %d [%s].\n", |
287 | packet, status, errmsg); | 276 | packet, status, errmsg); |
288 | } | 277 | } |
289 | } | 278 | } |
290 | 279 | ||
@@ -292,14 +281,14 @@ static inline void print_err_status(struct cx231xx *dev, | |||
292 | * video-buf generic routine to get the next available buffer | 281 | * video-buf generic routine to get the next available buffer |
293 | */ | 282 | */ |
294 | static inline void get_next_buf(struct cx231xx_dmaqueue *dma_q, | 283 | static inline void get_next_buf(struct cx231xx_dmaqueue *dma_q, |
295 | struct cx231xx_buffer **buf) | 284 | struct cx231xx_buffer **buf) |
296 | { | 285 | { |
297 | struct cx231xx_video_mode *vmode = container_of(dma_q, struct cx231xx_video_mode, vidq); | 286 | struct cx231xx_video_mode *vmode = |
298 | struct cx231xx *dev = container_of(vmode, struct cx231xx, video_mode); | 287 | container_of(dma_q, struct cx231xx_video_mode, vidq); |
288 | struct cx231xx *dev = container_of(vmode, struct cx231xx, video_mode); | ||
299 | 289 | ||
300 | char *outp; | 290 | char *outp; |
301 | 291 | ||
302 | |||
303 | if (list_empty(&dma_q->active)) { | 292 | if (list_empty(&dma_q->active)) { |
304 | cx231xx_isocdbg("No active queue to serve\n"); | 293 | cx231xx_isocdbg("No active queue to serve\n"); |
305 | dev->video_mode.isoc_ctl.buf = NULL; | 294 | dev->video_mode.isoc_ctl.buf = NULL; |
@@ -324,13 +313,13 @@ static inline void get_next_buf(struct cx231xx_dmaqueue *dma_q, | |||
324 | */ | 313 | */ |
325 | static inline int cx231xx_isoc_copy(struct cx231xx *dev, struct urb *urb) | 314 | static inline int cx231xx_isoc_copy(struct cx231xx *dev, struct urb *urb) |
326 | { | 315 | { |
327 | struct cx231xx_buffer *buf; | 316 | struct cx231xx_buffer *buf; |
328 | struct cx231xx_dmaqueue *dma_q = urb->context; | 317 | struct cx231xx_dmaqueue *dma_q = urb->context; |
329 | unsigned char *outp = NULL; | 318 | unsigned char *outp = NULL; |
330 | int i, rc = 1; | 319 | int i, rc = 1; |
331 | unsigned char *p_buffer; | 320 | unsigned char *p_buffer; |
332 | u32 bytes_parsed = 0, buffer_size = 0; | 321 | u32 bytes_parsed = 0, buffer_size = 0; |
333 | u8 sav_eav = 0; | 322 | u8 sav_eav = 0; |
334 | 323 | ||
335 | if (!dev) | 324 | if (!dev) |
336 | return 0; | 325 | return 0; |
@@ -357,342 +346,347 @@ static inline int cx231xx_isoc_copy(struct cx231xx *dev, struct urb *urb) | |||
357 | continue; | 346 | continue; |
358 | } | 347 | } |
359 | 348 | ||
360 | if (urb->iso_frame_desc[i].actual_length <= 0) { | 349 | if (urb->iso_frame_desc[i].actual_length <= 0) { |
361 | /* cx231xx_isocdbg("packet %d is empty",i); - spammy */ | 350 | /* cx231xx_isocdbg("packet %d is empty",i); - spammy */ |
362 | continue; | 351 | continue; |
363 | } | 352 | } |
364 | if (urb->iso_frame_desc[i].actual_length > | 353 | if (urb->iso_frame_desc[i].actual_length > |
365 | dev->video_mode.max_pkt_size) { | 354 | dev->video_mode.max_pkt_size) { |
366 | cx231xx_isocdbg("packet bigger than packet size"); | 355 | cx231xx_isocdbg("packet bigger than packet size"); |
367 | continue; | 356 | continue; |
368 | } | 357 | } |
369 | 358 | ||
370 | /* get buffer pointer and length */ | 359 | /* get buffer pointer and length */ |
371 | p_buffer = urb->transfer_buffer + urb->iso_frame_desc[i].offset; | 360 | p_buffer = urb->transfer_buffer + urb->iso_frame_desc[i].offset; |
372 | buffer_size = urb->iso_frame_desc[i].actual_length; | 361 | buffer_size = urb->iso_frame_desc[i].actual_length; |
373 | bytes_parsed = 0; | 362 | bytes_parsed = 0; |
374 | 363 | ||
375 | if(dma_q->is_partial_line) | 364 | if (dma_q->is_partial_line) { |
376 | { | 365 | /* Handle the case where we were working on a partial line */ |
377 | /* Handle the case where we were working on a partial line */ | 366 | sav_eav = dma_q->last_sav; |
378 | sav_eav = dma_q->last_sav; | 367 | } else { |
379 | } else { | 368 | /* Check for a SAV/EAV overlapping the buffer boundary */ |
380 | /* Check for a SAV/EAV overlapping the buffer boundary */ | 369 | sav_eav = |
381 | sav_eav = cx231xx_find_boundary_SAV_EAV(p_buffer, dma_q->partial_buf, &bytes_parsed); | 370 | cx231xx_find_boundary_SAV_EAV(p_buffer, |
382 | } | 371 | dma_q->partial_buf, |
383 | 372 | &bytes_parsed); | |
384 | sav_eav &= 0xF0; | 373 | } |
385 | /* Get the first line if we have some portion of an SAV/EAV from the last buffer | ||
386 | or a partial line */ | ||
387 | if(sav_eav) { | ||
388 | bytes_parsed += cx231xx_get_video_line(dev, dma_q, | ||
389 | sav_eav, /* SAV/EAV */ | ||
390 | p_buffer + bytes_parsed, /* p_buffer */ | ||
391 | buffer_size - bytes_parsed); /* buffer size */ | ||
392 | } | ||
393 | |||
394 | /* Now parse data that is completely in this buffer */ | ||
395 | /* dma_q->is_partial_line = 0; */ | ||
396 | |||
397 | while(bytes_parsed < buffer_size) | ||
398 | { | ||
399 | u32 bytes_used = 0; | ||
400 | |||
401 | sav_eav = cx231xx_find_next_SAV_EAV( | ||
402 | p_buffer + bytes_parsed, /* p_buffer */ | ||
403 | buffer_size - bytes_parsed, /* buffer size */ | ||
404 | &bytes_used); /* Receives bytes used to get SAV/EAV */ | ||
405 | |||
406 | bytes_parsed += bytes_used; | ||
407 | |||
408 | sav_eav &= 0xF0; | ||
409 | if(sav_eav && (bytes_parsed < buffer_size)) | ||
410 | { | ||
411 | bytes_parsed += cx231xx_get_video_line(dev, dma_q, | ||
412 | sav_eav, /* SAV/EAV */ | ||
413 | p_buffer + bytes_parsed, /* p_buffer */ | ||
414 | buffer_size - bytes_parsed); /* buffer size */ | ||
415 | } | ||
416 | } | ||
417 | |||
418 | /* Save the last four bytes of the buffer so we can check the buffer boundary | ||
419 | condition next time */ | ||
420 | memcpy(dma_q->partial_buf, p_buffer + buffer_size - 4, 4); | ||
421 | bytes_parsed = 0; | ||
422 | 374 | ||
423 | } | 375 | sav_eav &= 0xF0; |
424 | return rc; | 376 | /* Get the first line if we have some portion of an SAV/EAV from the last buffer |
425 | } | 377 | or a partial line */ |
378 | if (sav_eav) { | ||
379 | bytes_parsed += cx231xx_get_video_line(dev, dma_q, sav_eav, /* SAV/EAV */ | ||
380 | p_buffer + bytes_parsed, /* p_buffer */ | ||
381 | buffer_size - bytes_parsed); /* buffer size */ | ||
382 | } | ||
426 | 383 | ||
427 | u8 cx231xx_find_boundary_SAV_EAV(u8 *p_buffer, u8 *partial_buf, u32 *p_bytes_used) | 384 | /* Now parse data that is completely in this buffer */ |
428 | { | 385 | /* dma_q->is_partial_line = 0; */ |
429 | u32 bytes_used; | ||
430 | u8 boundary_bytes[8]; | ||
431 | u8 sav_eav = 0; | ||
432 | 386 | ||
433 | *p_bytes_used = 0; | 387 | while (bytes_parsed < buffer_size) { |
388 | u32 bytes_used = 0; | ||
434 | 389 | ||
435 | /* Create an array of the last 4 bytes of the last buffer and the first | 390 | sav_eav = cx231xx_find_next_SAV_EAV(p_buffer + bytes_parsed, /* p_buffer */ |
436 | 4 bytes of the current buffer. */ | 391 | buffer_size - bytes_parsed, /* buffer size */ |
392 | &bytes_used); /* Receives bytes used to get SAV/EAV */ | ||
437 | 393 | ||
438 | memcpy(boundary_bytes, partial_buf, 4); | 394 | bytes_parsed += bytes_used; |
439 | memcpy(boundary_bytes + 4, p_buffer, 4); | ||
440 | 395 | ||
441 | /* Check for the SAV/EAV in the boundary buffer */ | 396 | sav_eav &= 0xF0; |
442 | sav_eav = cx231xx_find_next_SAV_EAV((u8*)&boundary_bytes, 8, &bytes_used); | 397 | if (sav_eav && (bytes_parsed < buffer_size)) { |
398 | bytes_parsed += cx231xx_get_video_line(dev, dma_q, sav_eav, /* SAV/EAV */ | ||
399 | p_buffer + bytes_parsed, /* p_buffer */ | ||
400 | buffer_size - bytes_parsed); /* buffer size */ | ||
401 | } | ||
402 | } | ||
443 | 403 | ||
444 | if(sav_eav) { | 404 | /* Save the last four bytes of the buffer so we can check the buffer boundary |
445 | /* found a boundary SAV/EAV. Updates the bytes used to reflect | 405 | condition next time */ |
446 | only those used in the new buffer */ | 406 | memcpy(dma_q->partial_buf, p_buffer + buffer_size - 4, 4); |
447 | *p_bytes_used = bytes_used - 4; | 407 | bytes_parsed = 0; |
448 | } | ||
449 | 408 | ||
450 | return sav_eav; | 409 | } |
410 | return rc; | ||
451 | } | 411 | } |
452 | 412 | ||
453 | u8 cx231xx_find_next_SAV_EAV(u8 *p_buffer, u32 buffer_size, u32 *p_bytes_used) | 413 | u8 cx231xx_find_boundary_SAV_EAV(u8 * p_buffer, u8 * partial_buf, |
414 | u32 * p_bytes_used) | ||
454 | { | 415 | { |
455 | u32 i; | 416 | u32 bytes_used; |
456 | u8 sav_eav = 0; | 417 | u8 boundary_bytes[8]; |
418 | u8 sav_eav = 0; | ||
419 | |||
420 | *p_bytes_used = 0; | ||
457 | 421 | ||
458 | /* Don't search if the buffer size is less than 4. It causes a page fault since | 422 | /* Create an array of the last 4 bytes of the last buffer and the first |
459 | buffer_size - 4 evaluates to a large number in that case. */ | 423 | 4 bytes of the current buffer. */ |
460 | if(buffer_size < 4) { | ||
461 | *p_bytes_used = buffer_size; | ||
462 | return 0; | ||
463 | } | ||
464 | 424 | ||
465 | for(i = 0;i < (buffer_size - 3); i++) { | 425 | memcpy(boundary_bytes, partial_buf, 4); |
426 | memcpy(boundary_bytes + 4, p_buffer, 4); | ||
466 | 427 | ||
467 | if((p_buffer[i] == 0xFF) && | 428 | /* Check for the SAV/EAV in the boundary buffer */ |
468 | (p_buffer[i+1] == 0x00) && | 429 | sav_eav = |
469 | (p_buffer[i+2] == 0x00)) { | 430 | cx231xx_find_next_SAV_EAV((u8 *) & boundary_bytes, 8, &bytes_used); |
470 | 431 | ||
471 | *p_bytes_used = i+4; | 432 | if (sav_eav) { |
472 | sav_eav = p_buffer[i+3]; | 433 | /* found a boundary SAV/EAV. Updates the bytes used to reflect |
473 | return sav_eav; | 434 | only those used in the new buffer */ |
474 | } | 435 | *p_bytes_used = bytes_used - 4; |
475 | } | 436 | } |
476 | 437 | ||
477 | *p_bytes_used = buffer_size; | 438 | return sav_eav; |
478 | return 0; | ||
479 | } | 439 | } |
480 | 440 | ||
441 | u8 cx231xx_find_next_SAV_EAV(u8 * p_buffer, u32 buffer_size, u32 * p_bytes_used) | ||
442 | { | ||
443 | u32 i; | ||
444 | u8 sav_eav = 0; | ||
481 | 445 | ||
446 | /* Don't search if the buffer size is less than 4. It causes a page fault since | ||
447 | buffer_size - 4 evaluates to a large number in that case. */ | ||
448 | if (buffer_size < 4) { | ||
449 | *p_bytes_used = buffer_size; | ||
450 | return 0; | ||
451 | } | ||
482 | 452 | ||
453 | for (i = 0; i < (buffer_size - 3); i++) { | ||
483 | 454 | ||
484 | u32 cx231xx_get_video_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 455 | if ((p_buffer[i] == 0xFF) && |
485 | u8 sav_eav, u8 *p_buffer, u32 buffer_size) | 456 | (p_buffer[i + 1] == 0x00) && (p_buffer[i + 2] == 0x00)) { |
486 | { | ||
487 | u32 bytes_copied = 0; | ||
488 | int current_field = -1; | ||
489 | 457 | ||
458 | *p_bytes_used = i + 4; | ||
459 | sav_eav = p_buffer[i + 3]; | ||
460 | return sav_eav; | ||
461 | } | ||
462 | } | ||
490 | 463 | ||
491 | switch(sav_eav) { | 464 | *p_bytes_used = buffer_size; |
492 | case SAV_ACTIVE_VIDEO_FIELD1: | 465 | return 0; |
493 | /* looking for skipped line which occurred in PAL 720x480 mode. In this case, | 466 | } |
494 | there will be no active data contained between the SAV and EAV */ | ||
495 | if ( (buffer_size > 3) && | ||
496 | (p_buffer[0] == 0xFF) && (p_buffer[1] == 0x00) && (p_buffer[2] == 0x00) && | ||
497 | ( (p_buffer[3] == EAV_ACTIVE_VIDEO_FIELD1) || (p_buffer[3] == EAV_ACTIVE_VIDEO_FIELD2) || | ||
498 | (p_buffer[3] == EAV_VBLANK_FIELD1) || (p_buffer[3] == EAV_VBLANK_FIELD2) | ||
499 | ) | ||
500 | ) | ||
501 | { | ||
502 | return bytes_copied; | ||
503 | } | ||
504 | current_field = 1; | ||
505 | break; | ||
506 | 467 | ||
507 | case SAV_ACTIVE_VIDEO_FIELD2: | 468 | u32 cx231xx_get_video_line(struct cx231xx * dev, |
508 | /* looking for skipped line which occurred in PAL 720x480 mode. In this case, | 469 | struct cx231xx_dmaqueue * dma_q, u8 sav_eav, |
509 | there will be no active data contained between the SAV and EAV */ | 470 | u8 * p_buffer, u32 buffer_size) |
510 | if ( (buffer_size > 3) && | 471 | { |
511 | (p_buffer[0] == 0xFF) && (p_buffer[1] == 0x00) && (p_buffer[2] == 0x00) && | 472 | u32 bytes_copied = 0; |
512 | ( (p_buffer[3] == EAV_ACTIVE_VIDEO_FIELD1) || (p_buffer[3] == EAV_ACTIVE_VIDEO_FIELD2) || | 473 | int current_field = -1; |
513 | (p_buffer[3] == EAV_VBLANK_FIELD1) || (p_buffer[3] == EAV_VBLANK_FIELD2) | 474 | |
514 | ) | 475 | switch (sav_eav) { |
515 | ) | 476 | case SAV_ACTIVE_VIDEO_FIELD1: |
516 | { | 477 | /* looking for skipped line which occurred in PAL 720x480 mode. In this case, |
517 | return bytes_copied; | 478 | there will be no active data contained between the SAV and EAV */ |
518 | } | 479 | if ((buffer_size > 3) && |
519 | current_field = 2; | 480 | (p_buffer[0] == 0xFF) && (p_buffer[1] == 0x00) |
520 | break; | 481 | && (p_buffer[2] == 0x00) |
521 | } | 482 | && ((p_buffer[3] == EAV_ACTIVE_VIDEO_FIELD1) |
483 | || (p_buffer[3] == EAV_ACTIVE_VIDEO_FIELD2) | ||
484 | || (p_buffer[3] == EAV_VBLANK_FIELD1) | ||
485 | || (p_buffer[3] == EAV_VBLANK_FIELD2) | ||
486 | ) | ||
487 | ) { | ||
488 | return bytes_copied; | ||
489 | } | ||
490 | current_field = 1; | ||
491 | break; | ||
522 | 492 | ||
523 | dma_q->last_sav = sav_eav; | 493 | case SAV_ACTIVE_VIDEO_FIELD2: |
494 | /* looking for skipped line which occurred in PAL 720x480 mode. In this case, | ||
495 | there will be no active data contained between the SAV and EAV */ | ||
496 | if ((buffer_size > 3) && | ||
497 | (p_buffer[0] == 0xFF) && (p_buffer[1] == 0x00) | ||
498 | && (p_buffer[2] == 0x00) | ||
499 | && ((p_buffer[3] == EAV_ACTIVE_VIDEO_FIELD1) | ||
500 | || (p_buffer[3] == EAV_ACTIVE_VIDEO_FIELD2) | ||
501 | || (p_buffer[3] == EAV_VBLANK_FIELD1) | ||
502 | || (p_buffer[3] == EAV_VBLANK_FIELD2) | ||
503 | ) | ||
504 | ) { | ||
505 | return bytes_copied; | ||
506 | } | ||
507 | current_field = 2; | ||
508 | break; | ||
509 | } | ||
524 | 510 | ||
525 | bytes_copied = cx231xx_copy_video_line(dev, dma_q, p_buffer, buffer_size, current_field); | 511 | dma_q->last_sav = sav_eav; |
526 | 512 | ||
527 | return bytes_copied; | 513 | bytes_copied = |
514 | cx231xx_copy_video_line(dev, dma_q, p_buffer, buffer_size, | ||
515 | current_field); | ||
516 | |||
517 | return bytes_copied; | ||
528 | } | 518 | } |
529 | 519 | ||
530 | u32 cx231xx_copy_video_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 520 | u32 cx231xx_copy_video_line(struct cx231xx * dev, |
531 | u8 *p_line, u32 length, int field_number) | 521 | struct cx231xx_dmaqueue * dma_q, u8 * p_line, |
522 | u32 length, int field_number) | ||
532 | { | 523 | { |
533 | u32 bytes_to_copy; | 524 | u32 bytes_to_copy; |
534 | struct cx231xx_buffer *buf; | 525 | struct cx231xx_buffer *buf; |
535 | u32 _line_size = dev->width * 2; | 526 | u32 _line_size = dev->width * 2; |
536 | |||
537 | if( dma_q->current_field != field_number ) { | ||
538 | cx231xx_reset_video_buffer(dev, dma_q); | ||
539 | } | ||
540 | 527 | ||
541 | /* get the buffer pointer */ | 528 | if (dma_q->current_field != field_number) { |
542 | buf = dev->video_mode.isoc_ctl.buf; | 529 | cx231xx_reset_video_buffer(dev, dma_q); |
530 | } | ||
543 | 531 | ||
544 | /* Remember the field number for next time */ | 532 | /* get the buffer pointer */ |
545 | dma_q->current_field = field_number; | 533 | buf = dev->video_mode.isoc_ctl.buf; |
546 | 534 | ||
547 | bytes_to_copy = dma_q->bytes_left_in_line; | 535 | /* Remember the field number for next time */ |
548 | if(bytes_to_copy > length) | 536 | dma_q->current_field = field_number; |
549 | bytes_to_copy = length; | ||
550 | 537 | ||
538 | bytes_to_copy = dma_q->bytes_left_in_line; | ||
539 | if (bytes_to_copy > length) | ||
540 | bytes_to_copy = length; | ||
551 | 541 | ||
552 | if(dma_q->lines_completed >= dma_q->lines_per_field) { | 542 | if (dma_q->lines_completed >= dma_q->lines_per_field) { |
553 | dma_q->bytes_left_in_line -= bytes_to_copy; | 543 | dma_q->bytes_left_in_line -= bytes_to_copy; |
554 | dma_q->is_partial_line = (dma_q->bytes_left_in_line == 0) ? 0 : 1; | 544 | dma_q->is_partial_line = |
555 | return 0; | 545 | (dma_q->bytes_left_in_line == 0) ? 0 : 1; |
556 | } | 546 | return 0; |
547 | } | ||
557 | 548 | ||
558 | dma_q->is_partial_line = 1; | 549 | dma_q->is_partial_line = 1; |
559 | 550 | ||
560 | /* If we don't have a buffer, just return the number of bytes we would | 551 | /* If we don't have a buffer, just return the number of bytes we would |
561 | have copied if we had a buffer. */ | 552 | have copied if we had a buffer. */ |
562 | if(!buf) | 553 | if (!buf) { |
563 | { | 554 | dma_q->bytes_left_in_line -= bytes_to_copy; |
564 | dma_q->bytes_left_in_line -= bytes_to_copy; | 555 | dma_q->is_partial_line = |
565 | dma_q->is_partial_line = (dma_q->bytes_left_in_line == 0) ? 0 : 1; | 556 | (dma_q->bytes_left_in_line == 0) ? 0 : 1; |
566 | return bytes_to_copy; | 557 | return bytes_to_copy; |
567 | } | 558 | } |
568 | 559 | ||
569 | /* copy the data to video buffer */ | 560 | /* copy the data to video buffer */ |
570 | cx231xx_do_copy(dev, dma_q, p_line, bytes_to_copy); | 561 | cx231xx_do_copy(dev, dma_q, p_line, bytes_to_copy); |
571 | 562 | ||
572 | dma_q->pos += bytes_to_copy; | 563 | dma_q->pos += bytes_to_copy; |
573 | dma_q->bytes_left_in_line -= bytes_to_copy; | 564 | dma_q->bytes_left_in_line -= bytes_to_copy; |
574 | 565 | ||
575 | if(dma_q->bytes_left_in_line == 0) { | 566 | if (dma_q->bytes_left_in_line == 0) { |
576 | 567 | ||
577 | dma_q->bytes_left_in_line = _line_size; | 568 | dma_q->bytes_left_in_line = _line_size; |
578 | dma_q->lines_completed++; | 569 | dma_q->lines_completed++; |
579 | dma_q->is_partial_line = 0; | 570 | dma_q->is_partial_line = 0; |
580 | 571 | ||
581 | if(cx231xx_is_buffer_done(dev, dma_q) && buf) { | 572 | if (cx231xx_is_buffer_done(dev, dma_q) && buf) { |
582 | 573 | ||
583 | buffer_filled(dev, dma_q, buf); | 574 | buffer_filled(dev, dma_q, buf); |
584 | 575 | ||
585 | dma_q->pos = 0; | 576 | dma_q->pos = 0; |
586 | buf = NULL; | 577 | buf = NULL; |
587 | dma_q->lines_completed = 0; | 578 | dma_q->lines_completed = 0; |
588 | } | 579 | } |
589 | } | 580 | } |
590 | 581 | ||
591 | return bytes_to_copy; | 582 | return bytes_to_copy; |
592 | } | 583 | } |
593 | 584 | ||
594 | void cx231xx_reset_video_buffer(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q) | 585 | void cx231xx_reset_video_buffer(struct cx231xx *dev, |
586 | struct cx231xx_dmaqueue *dma_q) | ||
595 | { | 587 | { |
596 | struct cx231xx_buffer *buf; | 588 | struct cx231xx_buffer *buf; |
597 | 589 | ||
598 | /* handle the switch from field 1 to field 2 */ | 590 | /* handle the switch from field 1 to field 2 */ |
599 | if(dma_q->current_field == 1) { | 591 | if (dma_q->current_field == 1) { |
600 | if(dma_q->lines_completed >= dma_q->lines_per_field ) { | 592 | if (dma_q->lines_completed >= dma_q->lines_per_field) { |
601 | dma_q->field1_done = 1; | 593 | dma_q->field1_done = 1; |
602 | } else { | 594 | } else { |
603 | dma_q->field1_done = 0; | 595 | dma_q->field1_done = 0; |
604 | } | 596 | } |
605 | } | 597 | } |
606 | 598 | ||
607 | buf = dev->video_mode.isoc_ctl.buf; | 599 | buf = dev->video_mode.isoc_ctl.buf; |
608 | 600 | ||
609 | if(buf == NULL) { | 601 | if (buf == NULL) { |
610 | u8* outp = NULL; | 602 | u8 *outp = NULL; |
611 | /* first try to get the buffer */ | 603 | /* first try to get the buffer */ |
612 | get_next_buf(dma_q, &buf); | 604 | get_next_buf(dma_q, &buf); |
613 | 605 | ||
614 | if(buf) | 606 | if (buf) |
615 | outp = videobuf_to_vmalloc(&buf->vb); | 607 | outp = videobuf_to_vmalloc(&buf->vb); |
616 | 608 | ||
617 | dma_q->pos = 0; | 609 | dma_q->pos = 0; |
618 | dma_q->field1_done = 0; | 610 | dma_q->field1_done = 0; |
619 | dma_q->current_field = -1; | 611 | dma_q->current_field = -1; |
620 | } | 612 | } |
621 | 613 | ||
622 | /* reset the counters */ | 614 | /* reset the counters */ |
623 | dma_q->bytes_left_in_line = dev->width << 1; | 615 | dma_q->bytes_left_in_line = dev->width << 1; |
624 | dma_q->lines_completed = 0; | 616 | dma_q->lines_completed = 0; |
625 | } | 617 | } |
626 | 618 | ||
627 | int cx231xx_do_copy(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 619 | int cx231xx_do_copy(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
628 | u8 *p_buffer, u32 bytes_to_copy) | 620 | u8 * p_buffer, u32 bytes_to_copy) |
629 | { | 621 | { |
630 | u8 *p_out_buffer = NULL; | 622 | u8 *p_out_buffer = NULL; |
631 | u32 current_line_bytes_copied = 0; | 623 | u32 current_line_bytes_copied = 0; |
632 | struct cx231xx_buffer *buf; | 624 | struct cx231xx_buffer *buf; |
633 | u32 _line_size = dev->width << 1; | 625 | u32 _line_size = dev->width << 1; |
634 | void *startwrite; | 626 | void *startwrite; |
635 | int offset, lencopy; | 627 | int offset, lencopy; |
636 | 628 | ||
637 | buf = dev->video_mode.isoc_ctl.buf; | 629 | buf = dev->video_mode.isoc_ctl.buf; |
638 | 630 | ||
639 | if (buf == NULL) | 631 | if (buf == NULL) |
640 | return -1; | 632 | return -1; |
641 | 633 | ||
642 | p_out_buffer = videobuf_to_vmalloc(&buf->vb); | 634 | p_out_buffer = videobuf_to_vmalloc(&buf->vb); |
643 | 635 | ||
644 | current_line_bytes_copied = _line_size - dma_q->bytes_left_in_line; | 636 | current_line_bytes_copied = _line_size - dma_q->bytes_left_in_line; |
645 | 637 | ||
646 | /* Offset field 2 one line from the top of the buffer */ | 638 | /* Offset field 2 one line from the top of the buffer */ |
647 | offset = (dma_q->current_field == 1)? 0: _line_size; | 639 | offset = (dma_q->current_field == 1) ? 0 : _line_size; |
648 | 640 | ||
649 | /* Offset for field 2 */ | 641 | /* Offset for field 2 */ |
650 | startwrite = p_out_buffer + offset; | 642 | startwrite = p_out_buffer + offset; |
651 | 643 | ||
652 | /* lines already completed in the current field */ | 644 | /* lines already completed in the current field */ |
653 | startwrite += (dma_q->lines_completed * _line_size * 2); | 645 | startwrite += (dma_q->lines_completed * _line_size * 2); |
654 | 646 | ||
655 | /* bytes already completed in the current line */ | 647 | /* bytes already completed in the current line */ |
656 | startwrite += current_line_bytes_copied; | 648 | startwrite += current_line_bytes_copied; |
657 | 649 | ||
658 | lencopy = dma_q->bytes_left_in_line > bytes_to_copy ? bytes_to_copy : dma_q->bytes_left_in_line; | 650 | lencopy = |
651 | dma_q->bytes_left_in_line > | ||
652 | bytes_to_copy ? bytes_to_copy : dma_q->bytes_left_in_line; | ||
659 | 653 | ||
660 | if( (u8*)(startwrite +lencopy) > (u8*)(p_out_buffer+ buf->vb.size) ) { | 654 | if ((u8 *) (startwrite + lencopy) > |
661 | return 0; | 655 | (u8 *) (p_out_buffer + buf->vb.size)) { |
662 | } | 656 | return 0; |
657 | } | ||
663 | 658 | ||
664 | /* The below copies the UYVY data straight into video buffer */ | 659 | /* The below copies the UYVY data straight into video buffer */ |
665 | cx231xx_swab( (u16*)p_buffer, (u16*)startwrite, (u16)lencopy); | 660 | cx231xx_swab((u16 *) p_buffer, (u16 *) startwrite, (u16) lencopy); |
666 | 661 | ||
667 | return 0; | 662 | return 0; |
668 | } | 663 | } |
669 | 664 | ||
670 | void cx231xx_swab(u16 *from, u16 *to, u16 len) | 665 | void cx231xx_swab(u16 * from, u16 * to, u16 len) |
671 | { | 666 | { |
672 | u16 i; | 667 | u16 i; |
673 | 668 | ||
674 | if( len <= 0) | 669 | if (len <= 0) |
675 | return; | 670 | return; |
676 | 671 | ||
677 | for(i = 0; i < len/2; i++) { | 672 | for (i = 0; i < len / 2; i++) { |
678 | to[i] = (from[i] << 8) | (from[i] >> 8); | 673 | to[i] = (from[i] << 8) | (from[i] >> 8); |
679 | } | 674 | } |
680 | } | 675 | } |
681 | 676 | ||
682 | u8 cx231xx_is_buffer_done(struct cx231xx *dev,struct cx231xx_dmaqueue *dma_q) | 677 | u8 cx231xx_is_buffer_done(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q) |
683 | { | 678 | { |
684 | u8 buffer_complete = 0; | 679 | u8 buffer_complete = 0; |
685 | 680 | ||
686 | /* Dual field stream */ | 681 | /* Dual field stream */ |
687 | buffer_complete = | 682 | buffer_complete = |
688 | ((dma_q->current_field == 2) && | 683 | ((dma_q->current_field == 2) && |
689 | (dma_q->lines_completed >= dma_q->lines_per_field) && | 684 | (dma_q->lines_completed >= dma_q->lines_per_field) && |
690 | dma_q->field1_done); | 685 | dma_q->field1_done); |
691 | 686 | ||
692 | return buffer_complete; | 687 | return buffer_complete; |
693 | } | 688 | } |
694 | 689 | ||
695 | |||
696 | /* ------------------------------------------------------------------ | 690 | /* ------------------------------------------------------------------ |
697 | Videobuf operations | 691 | Videobuf operations |
698 | ------------------------------------------------------------------*/ | 692 | ------------------------------------------------------------------*/ |
@@ -701,10 +695,11 @@ static int | |||
701 | buffer_setup(struct videobuf_queue *vq, unsigned int *count, unsigned int *size) | 695 | buffer_setup(struct videobuf_queue *vq, unsigned int *count, unsigned int *size) |
702 | { | 696 | { |
703 | struct cx231xx_fh *fh = vq->priv_data; | 697 | struct cx231xx_fh *fh = vq->priv_data; |
704 | struct cx231xx *dev = fh->dev; | 698 | struct cx231xx *dev = fh->dev; |
705 | struct v4l2_frequency f; | 699 | struct v4l2_frequency f; |
706 | 700 | ||
707 | *size = ( fh->dev->width * fh->dev->height * dev->format->depth + 7) >> 3; | 701 | *size = |
702 | (fh->dev->width * fh->dev->height * dev->format->depth + 7) >> 3; | ||
708 | if (0 == *count) | 703 | if (0 == *count) |
709 | *count = CX231XX_DEF_BUF; | 704 | *count = CX231XX_DEF_BUF; |
710 | 705 | ||
@@ -714,7 +709,7 @@ buffer_setup(struct videobuf_queue *vq, unsigned int *count, unsigned int *size) | |||
714 | /* Ask tuner to go to analog mode */ | 709 | /* Ask tuner to go to analog mode */ |
715 | memset(&f, 0, sizeof(f)); | 710 | memset(&f, 0, sizeof(f)); |
716 | f.frequency = dev->ctl_freq; | 711 | f.frequency = dev->ctl_freq; |
717 | f.type = fh->radio ? V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV; | 712 | f.type = fh->radio ? V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV; |
718 | 713 | ||
719 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_FREQUENCY, &f); | 714 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_FREQUENCY, &f); |
720 | 715 | ||
@@ -724,8 +719,8 @@ buffer_setup(struct videobuf_queue *vq, unsigned int *count, unsigned int *size) | |||
724 | /* This is called *without* dev->slock held; please keep it that way */ | 719 | /* This is called *without* dev->slock held; please keep it that way */ |
725 | static void free_buffer(struct videobuf_queue *vq, struct cx231xx_buffer *buf) | 720 | static void free_buffer(struct videobuf_queue *vq, struct cx231xx_buffer *buf) |
726 | { | 721 | { |
727 | struct cx231xx_fh *fh = vq->priv_data; | 722 | struct cx231xx_fh *fh = vq->priv_data; |
728 | struct cx231xx *dev = fh->dev; | 723 | struct cx231xx *dev = fh->dev; |
729 | unsigned long flags = 0; | 724 | unsigned long flags = 0; |
730 | if (in_interrupt()) | 725 | if (in_interrupt()) |
731 | BUG(); | 726 | BUG(); |
@@ -738,7 +733,7 @@ static void free_buffer(struct videobuf_queue *vq, struct cx231xx_buffer *buf) | |||
738 | This should be safe; by the time we get here, the buffer isn't | 733 | This should be safe; by the time we get here, the buffer isn't |
739 | queued anymore. If we ever start marking the buffers as | 734 | queued anymore. If we ever start marking the buffers as |
740 | VIDEOBUF_ACTIVE, it won't be, though. | 735 | VIDEOBUF_ACTIVE, it won't be, though. |
741 | */ | 736 | */ |
742 | spin_lock_irqsave(&dev->video_mode.slock, flags); | 737 | spin_lock_irqsave(&dev->video_mode.slock, flags); |
743 | if (dev->video_mode.isoc_ctl.buf == buf) | 738 | if (dev->video_mode.isoc_ctl.buf == buf) |
744 | dev->video_mode.isoc_ctl.buf = NULL; | 739 | dev->video_mode.isoc_ctl.buf = NULL; |
@@ -750,22 +745,24 @@ static void free_buffer(struct videobuf_queue *vq, struct cx231xx_buffer *buf) | |||
750 | 745 | ||
751 | static int | 746 | static int |
752 | buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, | 747 | buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, |
753 | enum v4l2_field field) | 748 | enum v4l2_field field) |
754 | { | 749 | { |
755 | struct cx231xx_fh *fh = vq->priv_data; | 750 | struct cx231xx_fh *fh = vq->priv_data; |
756 | struct cx231xx_buffer *buf = container_of(vb, struct cx231xx_buffer, vb); | 751 | struct cx231xx_buffer *buf = |
757 | struct cx231xx *dev = fh->dev; | 752 | container_of(vb, struct cx231xx_buffer, vb); |
758 | int rc = 0, urb_init = 0; | 753 | struct cx231xx *dev = fh->dev; |
754 | int rc = 0, urb_init = 0; | ||
759 | 755 | ||
760 | /* The only currently supported format is 16 bits/pixel */ | 756 | /* The only currently supported format is 16 bits/pixel */ |
761 | buf->vb.size = (fh->dev->width * fh->dev->height * dev->format->depth + 7) >> 3; | 757 | buf->vb.size = |
758 | (fh->dev->width * fh->dev->height * dev->format->depth + 7) >> 3; | ||
762 | 759 | ||
763 | if (0 != buf->vb.baddr && buf->vb.bsize < buf->vb.size) | 760 | if (0 != buf->vb.baddr && buf->vb.bsize < buf->vb.size) |
764 | return -EINVAL; | 761 | return -EINVAL; |
765 | 762 | ||
766 | buf->vb.width = dev->width; | 763 | buf->vb.width = dev->width; |
767 | buf->vb.height = dev->height; | 764 | buf->vb.height = dev->height; |
768 | buf->vb.field = field; | 765 | buf->vb.field = field; |
769 | 766 | ||
770 | if (VIDEOBUF_NEEDS_INIT == buf->vb.state) { | 767 | if (VIDEOBUF_NEEDS_INIT == buf->vb.state) { |
771 | rc = videobuf_iolock(vq, &buf->vb, NULL); | 768 | rc = videobuf_iolock(vq, &buf->vb, NULL); |
@@ -778,8 +775,9 @@ buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, | |||
778 | 775 | ||
779 | if (urb_init) { | 776 | if (urb_init) { |
780 | rc = cx231xx_init_isoc(dev, CX231XX_NUM_PACKETS, | 777 | rc = cx231xx_init_isoc(dev, CX231XX_NUM_PACKETS, |
781 | CX231XX_NUM_BUFS, dev->video_mode.max_pkt_size, | 778 | CX231XX_NUM_BUFS, |
782 | cx231xx_isoc_copy); | 779 | dev->video_mode.max_pkt_size, |
780 | cx231xx_isoc_copy); | ||
783 | if (rc < 0) | 781 | if (rc < 0) |
784 | goto fail; | 782 | goto fail; |
785 | } | 783 | } |
@@ -787,18 +785,18 @@ buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, | |||
787 | buf->vb.state = VIDEOBUF_PREPARED; | 785 | buf->vb.state = VIDEOBUF_PREPARED; |
788 | return 0; | 786 | return 0; |
789 | 787 | ||
790 | fail: | 788 | fail: |
791 | free_buffer(vq, buf); | 789 | free_buffer(vq, buf); |
792 | return rc; | 790 | return rc; |
793 | } | 791 | } |
794 | 792 | ||
795 | static void | 793 | static void buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) |
796 | buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) | ||
797 | { | 794 | { |
798 | struct cx231xx_buffer *buf = container_of(vb, struct cx231xx_buffer, vb); | 795 | struct cx231xx_buffer *buf = |
799 | struct cx231xx_fh *fh = vq->priv_data; | 796 | container_of(vb, struct cx231xx_buffer, vb); |
800 | struct cx231xx *dev = fh->dev; | 797 | struct cx231xx_fh *fh = vq->priv_data; |
801 | struct cx231xx_dmaqueue *vidq = &dev->video_mode.vidq; | 798 | struct cx231xx *dev = fh->dev; |
799 | struct cx231xx_dmaqueue *vidq = &dev->video_mode.vidq; | ||
802 | 800 | ||
803 | buf->vb.state = VIDEOBUF_QUEUED; | 801 | buf->vb.state = VIDEOBUF_QUEUED; |
804 | list_add_tail(&buf->vb.queue, &vidq->active); | 802 | list_add_tail(&buf->vb.queue, &vidq->active); |
@@ -806,11 +804,12 @@ buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb) | |||
806 | } | 804 | } |
807 | 805 | ||
808 | static void buffer_release(struct videobuf_queue *vq, | 806 | static void buffer_release(struct videobuf_queue *vq, |
809 | struct videobuf_buffer *vb) | 807 | struct videobuf_buffer *vb) |
810 | { | 808 | { |
811 | struct cx231xx_buffer *buf = container_of(vb, struct cx231xx_buffer, vb); | 809 | struct cx231xx_buffer *buf = |
812 | struct cx231xx_fh *fh = vq->priv_data; | 810 | container_of(vb, struct cx231xx_buffer, vb); |
813 | struct cx231xx *dev = (struct cx231xx *)fh->dev; | 811 | struct cx231xx_fh *fh = vq->priv_data; |
812 | struct cx231xx *dev = (struct cx231xx *)fh->dev; | ||
814 | 813 | ||
815 | cx231xx_isocdbg("cx231xx: called buffer_release\n"); | 814 | cx231xx_isocdbg("cx231xx: called buffer_release\n"); |
816 | 815 | ||
@@ -818,15 +817,14 @@ static void buffer_release(struct videobuf_queue *vq, | |||
818 | } | 817 | } |
819 | 818 | ||
820 | static struct videobuf_queue_ops cx231xx_video_qops = { | 819 | static struct videobuf_queue_ops cx231xx_video_qops = { |
821 | .buf_setup = buffer_setup, | 820 | .buf_setup = buffer_setup, |
822 | .buf_prepare = buffer_prepare, | 821 | .buf_prepare = buffer_prepare, |
823 | .buf_queue = buffer_queue, | 822 | .buf_queue = buffer_queue, |
824 | .buf_release = buffer_release, | 823 | .buf_release = buffer_release, |
825 | }; | 824 | }; |
826 | 825 | ||
827 | /********************* v4l2 interface **************************************/ | 826 | /********************* v4l2 interface **************************************/ |
828 | 827 | ||
829 | |||
830 | void video_mux(struct cx231xx *dev, int index) | 828 | void video_mux(struct cx231xx *dev, int index) |
831 | { | 829 | { |
832 | 830 | ||
@@ -837,40 +835,41 @@ void video_mux(struct cx231xx *dev, int index) | |||
837 | dev->video_input = index; | 835 | dev->video_input = index; |
838 | dev->ctl_ainput = INPUT(index)->amux; | 836 | dev->ctl_ainput = INPUT(index)->amux; |
839 | 837 | ||
840 | cx231xx_set_video_input_mux(dev,index); | 838 | cx231xx_set_video_input_mux(dev, index); |
841 | 839 | ||
842 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_INT_S_VIDEO_ROUTING, &route); | 840 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_INT_S_VIDEO_ROUTING, |
841 | &route); | ||
843 | 842 | ||
844 | cx231xx_set_audio_input(dev, dev->ctl_ainput ); | 843 | cx231xx_set_audio_input(dev, dev->ctl_ainput); |
845 | 844 | ||
846 | cx231xx_info("video_mux : %d\n", index); | 845 | cx231xx_info("video_mux : %d\n", index); |
847 | 846 | ||
848 | /* do mode control overrides if required */ | 847 | /* do mode control overrides if required */ |
849 | cx231xx_do_mode_ctrl_overrides(dev); | 848 | cx231xx_do_mode_ctrl_overrides(dev); |
850 | } | 849 | } |
851 | 850 | ||
852 | /* Usage lock check functions */ | 851 | /* Usage lock check functions */ |
853 | static int res_get(struct cx231xx_fh *fh) | 852 | static int res_get(struct cx231xx_fh *fh) |
854 | { | 853 | { |
855 | struct cx231xx *dev = fh->dev; | 854 | struct cx231xx *dev = fh->dev; |
856 | int rc = 0; | 855 | int rc = 0; |
857 | 856 | ||
858 | /* This instance already has stream_on */ | 857 | /* This instance already has stream_on */ |
859 | if (fh->stream_on) | 858 | if (fh->stream_on) |
860 | return rc; | 859 | return rc; |
861 | 860 | ||
862 | if(fh->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) { | 861 | if (fh->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) { |
863 | if (dev->stream_on) | 862 | if (dev->stream_on) |
864 | return -EBUSY; | 863 | return -EBUSY; |
865 | dev->stream_on = 1; | 864 | dev->stream_on = 1; |
866 | } else if(fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) { | 865 | } else if (fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) { |
867 | if (dev->vbi_stream_on) | 866 | if (dev->vbi_stream_on) |
868 | return -EBUSY; | 867 | return -EBUSY; |
869 | dev->vbi_stream_on = 1; | 868 | dev->vbi_stream_on = 1; |
870 | } else | 869 | } else |
871 | return -EINVAL; | 870 | return -EINVAL; |
872 | 871 | ||
873 | fh->stream_on = 1; | 872 | fh->stream_on = 1; |
874 | 873 | ||
875 | return rc; | 874 | return rc; |
876 | } | 875 | } |
@@ -882,14 +881,14 @@ static int res_check(struct cx231xx_fh *fh) | |||
882 | 881 | ||
883 | static void res_free(struct cx231xx_fh *fh) | 882 | static void res_free(struct cx231xx_fh *fh) |
884 | { | 883 | { |
885 | struct cx231xx *dev = fh->dev; | 884 | struct cx231xx *dev = fh->dev; |
886 | 885 | ||
887 | fh->stream_on = 0; | 886 | fh->stream_on = 0; |
888 | 887 | ||
889 | if(fh->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) | 888 | if (fh->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) |
890 | dev->stream_on = 0; | 889 | dev->stream_on = 0; |
891 | if(fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) | 890 | if (fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) |
892 | dev->vbi_stream_on = 0; | 891 | dev->vbi_stream_on = 0; |
893 | } | 892 | } |
894 | 893 | ||
895 | static int check_dev(struct cx231xx *dev) | 894 | static int check_dev(struct cx231xx *dev) |
@@ -901,18 +900,18 @@ static int check_dev(struct cx231xx *dev) | |||
901 | 900 | ||
902 | if (dev->state & DEV_MISCONFIGURED) { | 901 | if (dev->state & DEV_MISCONFIGURED) { |
903 | cx231xx_errdev("v4l2 ioctl: device is misconfigured; " | 902 | cx231xx_errdev("v4l2 ioctl: device is misconfigured; " |
904 | "close and open it again\n"); | 903 | "close and open it again\n"); |
905 | return -EIO; | 904 | return -EIO; |
906 | } | 905 | } |
907 | return 0; | 906 | return 0; |
908 | } | 907 | } |
909 | 908 | ||
910 | void get_scale(struct cx231xx *dev, | 909 | void get_scale(struct cx231xx *dev, |
911 | unsigned int width, unsigned int height, | 910 | unsigned int width, unsigned int height, |
912 | unsigned int *hscale, unsigned int *vscale) | 911 | unsigned int *hscale, unsigned int *vscale) |
913 | { | 912 | { |
914 | unsigned int maxw = norm_maxw(dev); | 913 | unsigned int maxw = norm_maxw(dev); |
915 | unsigned int maxh = norm_maxh(dev); | 914 | unsigned int maxh = norm_maxh(dev); |
916 | 915 | ||
917 | *hscale = (((unsigned long)maxw) << 12) / width - 4096L; | 916 | *hscale = (((unsigned long)maxw) << 12) / width - 4096L; |
918 | if (*hscale >= 0x4000) | 917 | if (*hscale >= 0x4000) |
@@ -922,8 +921,8 @@ void get_scale(struct cx231xx *dev, | |||
922 | if (*vscale >= 0x4000) | 921 | if (*vscale >= 0x4000) |
923 | *vscale = 0x3fff; | 922 | *vscale = 0x3fff; |
924 | 923 | ||
925 | dev->hscale = *hscale; | 924 | dev->hscale = *hscale; |
926 | dev->vscale = *vscale; | 925 | dev->vscale = *vscale; |
927 | 926 | ||
928 | } | 927 | } |
929 | 928 | ||
@@ -932,10 +931,10 @@ void get_scale(struct cx231xx *dev, | |||
932 | ------------------------------------------------------------------*/ | 931 | ------------------------------------------------------------------*/ |
933 | 932 | ||
934 | static int vidioc_g_fmt_vid_cap(struct file *file, void *priv, | 933 | static int vidioc_g_fmt_vid_cap(struct file *file, void *priv, |
935 | struct v4l2_format *f) | 934 | struct v4l2_format *f) |
936 | { | 935 | { |
937 | struct cx231xx_fh *fh = priv; | 936 | struct cx231xx_fh *fh = priv; |
938 | struct cx231xx *dev = fh->dev; | 937 | struct cx231xx *dev = fh->dev; |
939 | 938 | ||
940 | mutex_lock(&dev->lock); | 939 | mutex_lock(&dev->lock); |
941 | 940 | ||
@@ -943,7 +942,7 @@ static int vidioc_g_fmt_vid_cap(struct file *file, void *priv, | |||
943 | f->fmt.pix.height = dev->height; | 942 | f->fmt.pix.height = dev->height; |
944 | f->fmt.pix.pixelformat = dev->format->fourcc;; | 943 | f->fmt.pix.pixelformat = dev->format->fourcc;; |
945 | f->fmt.pix.bytesperline = (dev->width * dev->format->depth + 7) >> 3;; | 944 | f->fmt.pix.bytesperline = (dev->width * dev->format->depth + 7) >> 3;; |
946 | f->fmt.pix.sizeimage = f->fmt.pix.bytesperline * dev->height; | 945 | f->fmt.pix.sizeimage = f->fmt.pix.bytesperline * dev->height; |
947 | f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M; | 946 | f->fmt.pix.colorspace = V4L2_COLORSPACE_SMPTE170M; |
948 | 947 | ||
949 | f->fmt.pix.field = V4L2_FIELD_INTERLACED; | 948 | f->fmt.pix.field = V4L2_FIELD_INTERLACED; |
@@ -964,21 +963,21 @@ static struct cx231xx_fmt *format_by_fourcc(unsigned int fourcc) | |||
964 | } | 963 | } |
965 | 964 | ||
966 | static int vidioc_try_fmt_vid_cap(struct file *file, void *priv, | 965 | static int vidioc_try_fmt_vid_cap(struct file *file, void *priv, |
967 | struct v4l2_format *f) | 966 | struct v4l2_format *f) |
968 | { | 967 | { |
969 | struct cx231xx_fh *fh = priv; | 968 | struct cx231xx_fh *fh = priv; |
970 | struct cx231xx *dev = fh->dev; | 969 | struct cx231xx *dev = fh->dev; |
971 | int width = f->fmt.pix.width; | 970 | int width = f->fmt.pix.width; |
972 | int height = f->fmt.pix.height; | 971 | int height = f->fmt.pix.height; |
973 | unsigned int maxw = norm_maxw(dev); | 972 | unsigned int maxw = norm_maxw(dev); |
974 | unsigned int maxh = norm_maxh(dev); | 973 | unsigned int maxh = norm_maxh(dev); |
975 | unsigned int hscale, vscale; | 974 | unsigned int hscale, vscale; |
976 | struct cx231xx_fmt *fmt; | 975 | struct cx231xx_fmt *fmt; |
977 | 976 | ||
978 | fmt = format_by_fourcc(f->fmt.pix.pixelformat); | 977 | fmt = format_by_fourcc(f->fmt.pix.pixelformat); |
979 | if (!fmt) { | 978 | if (!fmt) { |
980 | cx231xx_videodbg("Fourcc format (%08x) invalid.\n", | 979 | cx231xx_videodbg("Fourcc format (%08x) invalid.\n", |
981 | f->fmt.pix.pixelformat); | 980 | f->fmt.pix.pixelformat); |
982 | return -EINVAL; | 981 | return -EINVAL; |
983 | } | 982 | } |
984 | 983 | ||
@@ -1013,23 +1012,22 @@ static int vidioc_try_fmt_vid_cap(struct file *file, void *priv, | |||
1013 | } | 1012 | } |
1014 | 1013 | ||
1015 | static int vidioc_s_fmt_vid_cap(struct file *file, void *priv, | 1014 | static int vidioc_s_fmt_vid_cap(struct file *file, void *priv, |
1016 | struct v4l2_format *f) | 1015 | struct v4l2_format *f) |
1017 | { | 1016 | { |
1018 | struct cx231xx_fh *fh = priv; | 1017 | struct cx231xx_fh *fh = priv; |
1019 | struct cx231xx *dev = fh->dev; | 1018 | struct cx231xx *dev = fh->dev; |
1020 | int rc; | 1019 | int rc; |
1021 | struct cx231xx_fmt *fmt; | 1020 | struct cx231xx_fmt *fmt; |
1022 | 1021 | ||
1023 | rc = check_dev(dev); | 1022 | rc = check_dev(dev); |
1024 | if (rc < 0) | 1023 | if (rc < 0) |
1025 | return rc; | 1024 | return rc; |
1026 | 1025 | ||
1027 | |||
1028 | mutex_lock(&dev->lock); | 1026 | mutex_lock(&dev->lock); |
1029 | 1027 | ||
1030 | vidioc_try_fmt_vid_cap(file, priv, f); | 1028 | vidioc_try_fmt_vid_cap(file, priv, f); |
1031 | 1029 | ||
1032 | fmt = format_by_fourcc(f->fmt.pix.pixelformat); | 1030 | fmt = format_by_fourcc(f->fmt.pix.pixelformat); |
1033 | if (!fmt) { | 1031 | if (!fmt) { |
1034 | rc = -EINVAL; | 1032 | rc = -EINVAL; |
1035 | goto out; | 1033 | goto out; |
@@ -1050,23 +1048,23 @@ static int vidioc_s_fmt_vid_cap(struct file *file, void *priv, | |||
1050 | /* set new image size */ | 1048 | /* set new image size */ |
1051 | dev->width = f->fmt.pix.width; | 1049 | dev->width = f->fmt.pix.width; |
1052 | dev->height = f->fmt.pix.height; | 1050 | dev->height = f->fmt.pix.height; |
1053 | dev->format = fmt; | 1051 | dev->format = fmt; |
1054 | get_scale(dev, dev->width, dev->height, &dev->hscale, &dev->vscale); | 1052 | get_scale(dev, dev->width, dev->height, &dev->hscale, &dev->vscale); |
1055 | 1053 | ||
1056 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_S_FMT, f); | 1054 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_S_FMT, f); |
1057 | 1055 | ||
1058 | /* Set the correct alternate setting for this resolution */ | 1056 | /* Set the correct alternate setting for this resolution */ |
1059 | cx231xx_resolution_set(dev); | 1057 | cx231xx_resolution_set(dev); |
1060 | 1058 | ||
1061 | out: | 1059 | out: |
1062 | mutex_unlock(&dev->lock); | 1060 | mutex_unlock(&dev->lock); |
1063 | return rc; | 1061 | return rc; |
1064 | } | 1062 | } |
1065 | 1063 | ||
1066 | static int vidioc_g_std(struct file *file, void *priv, v4l2_std_id *id) | 1064 | static int vidioc_g_std(struct file *file, void *priv, v4l2_std_id * id) |
1067 | { | 1065 | { |
1068 | struct cx231xx_fh *fh = priv; | 1066 | struct cx231xx_fh *fh = priv; |
1069 | struct cx231xx *dev = fh->dev; | 1067 | struct cx231xx *dev = fh->dev; |
1070 | 1068 | ||
1071 | *id = dev->norm; | 1069 | *id = dev->norm; |
1072 | return 0; | 1070 | return 0; |
@@ -1074,21 +1072,20 @@ static int vidioc_g_std(struct file *file, void *priv, v4l2_std_id *id) | |||
1074 | 1072 | ||
1075 | static int vidioc_s_std(struct file *file, void *priv, v4l2_std_id * norm) | 1073 | static int vidioc_s_std(struct file *file, void *priv, v4l2_std_id * norm) |
1076 | { | 1074 | { |
1077 | struct cx231xx_fh *fh = priv; | 1075 | struct cx231xx_fh *fh = priv; |
1078 | struct cx231xx *dev = fh->dev; | 1076 | struct cx231xx *dev = fh->dev; |
1079 | struct v4l2_format f; | 1077 | struct v4l2_format f; |
1080 | int rc; | 1078 | int rc; |
1081 | 1079 | ||
1082 | rc = check_dev(dev); | 1080 | rc = check_dev(dev); |
1083 | if (rc < 0) | 1081 | if (rc < 0) |
1084 | return rc; | 1082 | return rc; |
1085 | 1083 | ||
1086 | cx231xx_info("vidioc_s_std : 0x%x\n", (unsigned int)*norm); | 1084 | cx231xx_info("vidioc_s_std : 0x%x\n", (unsigned int)*norm); |
1087 | 1085 | ||
1088 | mutex_lock(&dev->lock); | 1086 | mutex_lock(&dev->lock); |
1089 | dev->norm = *norm; | 1087 | dev->norm = *norm; |
1090 | 1088 | ||
1091 | |||
1092 | /* Adjusts width/height, if needed */ | 1089 | /* Adjusts width/height, if needed */ |
1093 | f.fmt.pix.width = dev->width; | 1090 | f.fmt.pix.width = dev->width; |
1094 | f.fmt.pix.height = dev->height; | 1091 | f.fmt.pix.height = dev->height; |
@@ -1103,29 +1100,29 @@ static int vidioc_s_std(struct file *file, void *priv, v4l2_std_id * norm) | |||
1103 | 1100 | ||
1104 | mutex_unlock(&dev->lock); | 1101 | mutex_unlock(&dev->lock); |
1105 | 1102 | ||
1106 | cx231xx_resolution_set(dev); | 1103 | cx231xx_resolution_set(dev); |
1107 | 1104 | ||
1108 | /* do mode control overrides */ | 1105 | /* do mode control overrides */ |
1109 | cx231xx_do_mode_ctrl_overrides(dev); | 1106 | cx231xx_do_mode_ctrl_overrides(dev); |
1110 | 1107 | ||
1111 | return 0; | 1108 | return 0; |
1112 | } | 1109 | } |
1113 | 1110 | ||
1114 | static const char *iname[] = { | 1111 | static const char *iname[] = { |
1115 | [CX231XX_VMUX_COMPOSITE1] = "Composite1", | 1112 | [CX231XX_VMUX_COMPOSITE1] = "Composite1", |
1116 | [CX231XX_VMUX_SVIDEO] = "S-Video", | 1113 | [CX231XX_VMUX_SVIDEO] = "S-Video", |
1117 | [CX231XX_VMUX_TELEVISION] = "Television", | 1114 | [CX231XX_VMUX_TELEVISION] = "Television", |
1118 | [CX231XX_VMUX_CABLE] = "Cable TV", | 1115 | [CX231XX_VMUX_CABLE] = "Cable TV", |
1119 | [CX231XX_VMUX_DVB] = "DVB", | 1116 | [CX231XX_VMUX_DVB] = "DVB", |
1120 | [CX231XX_VMUX_DEBUG] = "for debug only", | 1117 | [CX231XX_VMUX_DEBUG] = "for debug only", |
1121 | }; | 1118 | }; |
1122 | 1119 | ||
1123 | static int vidioc_enum_input(struct file *file, void *priv, | 1120 | static int vidioc_enum_input(struct file *file, void *priv, |
1124 | struct v4l2_input *i) | 1121 | struct v4l2_input *i) |
1125 | { | 1122 | { |
1126 | struct cx231xx_fh *fh = priv; | 1123 | struct cx231xx_fh *fh = priv; |
1127 | struct cx231xx *dev = fh->dev; | 1124 | struct cx231xx *dev = fh->dev; |
1128 | unsigned int n; | 1125 | unsigned int n; |
1129 | 1126 | ||
1130 | n = i->index; | 1127 | n = i->index; |
1131 | if (n >= MAX_CX231XX_INPUT) | 1128 | if (n >= MAX_CX231XX_INPUT) |
@@ -1139,7 +1136,7 @@ static int vidioc_enum_input(struct file *file, void *priv, | |||
1139 | strcpy(i->name, iname[INPUT(n)->type]); | 1136 | strcpy(i->name, iname[INPUT(n)->type]); |
1140 | 1137 | ||
1141 | if ((CX231XX_VMUX_TELEVISION == INPUT(n)->type) || | 1138 | if ((CX231XX_VMUX_TELEVISION == INPUT(n)->type) || |
1142 | (CX231XX_VMUX_CABLE == INPUT(n)->type)) | 1139 | (CX231XX_VMUX_CABLE == INPUT(n)->type)) |
1143 | i->type = V4L2_INPUT_TYPE_TUNER; | 1140 | i->type = V4L2_INPUT_TYPE_TUNER; |
1144 | 1141 | ||
1145 | i->std = dev->vdev->tvnorms; | 1142 | i->std = dev->vdev->tvnorms; |
@@ -1149,8 +1146,8 @@ static int vidioc_enum_input(struct file *file, void *priv, | |||
1149 | 1146 | ||
1150 | static int vidioc_g_input(struct file *file, void *priv, unsigned int *i) | 1147 | static int vidioc_g_input(struct file *file, void *priv, unsigned int *i) |
1151 | { | 1148 | { |
1152 | struct cx231xx_fh *fh = priv; | 1149 | struct cx231xx_fh *fh = priv; |
1153 | struct cx231xx *dev = fh->dev; | 1150 | struct cx231xx *dev = fh->dev; |
1154 | 1151 | ||
1155 | *i = dev->video_input; | 1152 | *i = dev->video_input; |
1156 | 1153 | ||
@@ -1159,9 +1156,9 @@ static int vidioc_g_input(struct file *file, void *priv, unsigned int *i) | |||
1159 | 1156 | ||
1160 | static int vidioc_s_input(struct file *file, void *priv, unsigned int i) | 1157 | static int vidioc_s_input(struct file *file, void *priv, unsigned int i) |
1161 | { | 1158 | { |
1162 | struct cx231xx_fh *fh = priv; | 1159 | struct cx231xx_fh *fh = priv; |
1163 | struct cx231xx *dev = fh->dev; | 1160 | struct cx231xx *dev = fh->dev; |
1164 | int rc; | 1161 | int rc; |
1165 | 1162 | ||
1166 | rc = check_dev(dev); | 1163 | rc = check_dev(dev); |
1167 | if (rc < 0) | 1164 | if (rc < 0) |
@@ -1182,8 +1179,8 @@ static int vidioc_s_input(struct file *file, void *priv, unsigned int i) | |||
1182 | 1179 | ||
1183 | static int vidioc_g_audio(struct file *file, void *priv, struct v4l2_audio *a) | 1180 | static int vidioc_g_audio(struct file *file, void *priv, struct v4l2_audio *a) |
1184 | { | 1181 | { |
1185 | struct cx231xx_fh *fh = priv; | 1182 | struct cx231xx_fh *fh = priv; |
1186 | struct cx231xx *dev = fh->dev; | 1183 | struct cx231xx *dev = fh->dev; |
1187 | 1184 | ||
1188 | switch (a->index) { | 1185 | switch (a->index) { |
1189 | case CX231XX_AMUX_VIDEO: | 1186 | case CX231XX_AMUX_VIDEO: |
@@ -1204,35 +1201,34 @@ static int vidioc_g_audio(struct file *file, void *priv, struct v4l2_audio *a) | |||
1204 | 1201 | ||
1205 | static int vidioc_s_audio(struct file *file, void *priv, struct v4l2_audio *a) | 1202 | static int vidioc_s_audio(struct file *file, void *priv, struct v4l2_audio *a) |
1206 | { | 1203 | { |
1207 | struct cx231xx_fh *fh = priv; | 1204 | struct cx231xx_fh *fh = priv; |
1208 | struct cx231xx *dev = fh->dev; | 1205 | struct cx231xx *dev = fh->dev; |
1209 | int status = 0; | 1206 | int status = 0; |
1210 | |||
1211 | 1207 | ||
1212 | /* Doesn't allow manual routing */ | 1208 | /* Doesn't allow manual routing */ |
1213 | if (a->index != dev->ctl_ainput) | 1209 | if (a->index != dev->ctl_ainput) |
1214 | return -EINVAL; | 1210 | return -EINVAL; |
1215 | 1211 | ||
1216 | dev->ctl_ainput = INPUT(a->index)->amux; | 1212 | dev->ctl_ainput = INPUT(a->index)->amux; |
1217 | status = cx231xx_set_audio_input(dev, dev->ctl_ainput); | 1213 | status = cx231xx_set_audio_input(dev, dev->ctl_ainput); |
1218 | 1214 | ||
1219 | return status; | 1215 | return status; |
1220 | } | 1216 | } |
1221 | 1217 | ||
1222 | static int vidioc_queryctrl(struct file *file, void *priv, | 1218 | static int vidioc_queryctrl(struct file *file, void *priv, |
1223 | struct v4l2_queryctrl *qc) | 1219 | struct v4l2_queryctrl *qc) |
1224 | { | 1220 | { |
1225 | struct cx231xx_fh *fh = priv; | 1221 | struct cx231xx_fh *fh = priv; |
1226 | struct cx231xx *dev = fh->dev; | 1222 | struct cx231xx *dev = fh->dev; |
1227 | int id = qc->id; | 1223 | int id = qc->id; |
1228 | int i; | 1224 | int i; |
1229 | int rc; | 1225 | int rc; |
1230 | 1226 | ||
1231 | rc = check_dev(dev); | 1227 | rc = check_dev(dev); |
1232 | if (rc < 0) | 1228 | if (rc < 0) |
1233 | return rc; | 1229 | return rc; |
1234 | 1230 | ||
1235 | qc->id = v4l2_ctrl_next(ctrl_classes, qc->id); | 1231 | qc->id = v4l2_ctrl_next(ctrl_classes, qc->id); |
1236 | if (unlikely(qc->id == 0)) | 1232 | if (unlikely(qc->id == 0)) |
1237 | return -EINVAL; | 1233 | return -EINVAL; |
1238 | 1234 | ||
@@ -1240,8 +1236,7 @@ static int vidioc_queryctrl(struct file *file, void *priv, | |||
1240 | 1236 | ||
1241 | qc->id = id; | 1237 | qc->id = id; |
1242 | 1238 | ||
1243 | if (qc->id < V4L2_CID_BASE || | 1239 | if (qc->id < V4L2_CID_BASE || qc->id >= V4L2_CID_LASTP1) |
1244 | qc->id >= V4L2_CID_LASTP1) | ||
1245 | return -EINVAL; | 1240 | return -EINVAL; |
1246 | 1241 | ||
1247 | for (i = 0; i < CX231XX_CTLS; i++) | 1242 | for (i = 0; i < CX231XX_CTLS; i++) |
@@ -1255,7 +1250,7 @@ static int vidioc_queryctrl(struct file *file, void *priv, | |||
1255 | *qc = cx231xx_ctls[i].v; | 1250 | *qc = cx231xx_ctls[i].v; |
1256 | 1251 | ||
1257 | mutex_lock(&dev->lock); | 1252 | mutex_lock(&dev->lock); |
1258 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_QUERYCTRL, qc); | 1253 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_QUERYCTRL, qc); |
1259 | mutex_unlock(&dev->lock); | 1254 | mutex_unlock(&dev->lock); |
1260 | 1255 | ||
1261 | if (qc->type) | 1256 | if (qc->type) |
@@ -1265,11 +1260,11 @@ static int vidioc_queryctrl(struct file *file, void *priv, | |||
1265 | } | 1260 | } |
1266 | 1261 | ||
1267 | static int vidioc_g_ctrl(struct file *file, void *priv, | 1262 | static int vidioc_g_ctrl(struct file *file, void *priv, |
1268 | struct v4l2_control *ctrl) | 1263 | struct v4l2_control *ctrl) |
1269 | { | 1264 | { |
1270 | struct cx231xx_fh *fh = priv; | 1265 | struct cx231xx_fh *fh = priv; |
1271 | struct cx231xx *dev = fh->dev; | 1266 | struct cx231xx *dev = fh->dev; |
1272 | int rc; | 1267 | int rc; |
1273 | 1268 | ||
1274 | rc = check_dev(dev); | 1269 | rc = check_dev(dev); |
1275 | if (rc < 0) | 1270 | if (rc < 0) |
@@ -1284,11 +1279,11 @@ static int vidioc_g_ctrl(struct file *file, void *priv, | |||
1284 | } | 1279 | } |
1285 | 1280 | ||
1286 | static int vidioc_s_ctrl(struct file *file, void *priv, | 1281 | static int vidioc_s_ctrl(struct file *file, void *priv, |
1287 | struct v4l2_control *ctrl) | 1282 | struct v4l2_control *ctrl) |
1288 | { | 1283 | { |
1289 | struct cx231xx_fh *fh = priv; | 1284 | struct cx231xx_fh *fh = priv; |
1290 | struct cx231xx *dev = fh->dev; | 1285 | struct cx231xx *dev = fh->dev; |
1291 | int rc; | 1286 | int rc; |
1292 | 1287 | ||
1293 | rc = check_dev(dev); | 1288 | rc = check_dev(dev); |
1294 | if (rc < 0) | 1289 | if (rc < 0) |
@@ -1302,12 +1297,11 @@ static int vidioc_s_ctrl(struct file *file, void *priv, | |||
1302 | return rc; | 1297 | return rc; |
1303 | } | 1298 | } |
1304 | 1299 | ||
1305 | static int vidioc_g_tuner(struct file *file, void *priv, | 1300 | static int vidioc_g_tuner(struct file *file, void *priv, struct v4l2_tuner *t) |
1306 | struct v4l2_tuner *t) | ||
1307 | { | 1301 | { |
1308 | struct cx231xx_fh *fh = priv; | 1302 | struct cx231xx_fh *fh = priv; |
1309 | struct cx231xx *dev = fh->dev; | 1303 | struct cx231xx *dev = fh->dev; |
1310 | int rc; | 1304 | int rc; |
1311 | 1305 | ||
1312 | rc = check_dev(dev); | 1306 | rc = check_dev(dev); |
1313 | if (rc < 0) | 1307 | if (rc < 0) |
@@ -1318,20 +1312,19 @@ static int vidioc_g_tuner(struct file *file, void *priv, | |||
1318 | 1312 | ||
1319 | strcpy(t->name, "Tuner"); | 1313 | strcpy(t->name, "Tuner"); |
1320 | 1314 | ||
1321 | t->type = V4L2_TUNER_ANALOG_TV; | 1315 | t->type = V4L2_TUNER_ANALOG_TV; |
1322 | t->capability = V4L2_TUNER_CAP_NORM; | 1316 | t->capability = V4L2_TUNER_CAP_NORM; |
1323 | t->rangehigh = 0xffffffffUL; | 1317 | t->rangehigh = 0xffffffffUL; |
1324 | t->signal = 0xffff ; /* LOCKED */ | 1318 | t->signal = 0xffff; /* LOCKED */ |
1325 | 1319 | ||
1326 | return 0; | 1320 | return 0; |
1327 | } | 1321 | } |
1328 | 1322 | ||
1329 | static int vidioc_s_tuner(struct file *file, void *priv, | 1323 | static int vidioc_s_tuner(struct file *file, void *priv, struct v4l2_tuner *t) |
1330 | struct v4l2_tuner *t) | ||
1331 | { | 1324 | { |
1332 | struct cx231xx_fh *fh = priv; | 1325 | struct cx231xx_fh *fh = priv; |
1333 | struct cx231xx *dev = fh->dev; | 1326 | struct cx231xx *dev = fh->dev; |
1334 | int rc; | 1327 | int rc; |
1335 | 1328 | ||
1336 | rc = check_dev(dev); | 1329 | rc = check_dev(dev); |
1337 | if (rc < 0) | 1330 | if (rc < 0) |
@@ -1350,28 +1343,28 @@ static int vidioc_s_tuner(struct file *file, void *priv, | |||
1350 | } | 1343 | } |
1351 | 1344 | ||
1352 | static int vidioc_g_frequency(struct file *file, void *priv, | 1345 | static int vidioc_g_frequency(struct file *file, void *priv, |
1353 | struct v4l2_frequency *f) | 1346 | struct v4l2_frequency *f) |
1354 | { | 1347 | { |
1355 | struct cx231xx_fh *fh = priv; | 1348 | struct cx231xx_fh *fh = priv; |
1356 | struct cx231xx *dev = fh->dev; | 1349 | struct cx231xx *dev = fh->dev; |
1357 | 1350 | ||
1358 | mutex_lock(&dev->lock); | 1351 | mutex_lock(&dev->lock); |
1359 | f->type = fh->radio ? V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV; | 1352 | f->type = fh->radio ? V4L2_TUNER_RADIO : V4L2_TUNER_ANALOG_TV; |
1360 | f->frequency = dev->ctl_freq; | 1353 | f->frequency = dev->ctl_freq; |
1361 | 1354 | ||
1362 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_G_FREQUENCY, f); | 1355 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_G_FREQUENCY, f); |
1363 | 1356 | ||
1364 | mutex_unlock(&dev->lock); | 1357 | mutex_unlock(&dev->lock); |
1365 | 1358 | ||
1366 | return 0; | 1359 | return 0; |
1367 | } | 1360 | } |
1368 | 1361 | ||
1369 | static int vidioc_s_frequency(struct file *file, void *priv, | 1362 | static int vidioc_s_frequency(struct file *file, void *priv, |
1370 | struct v4l2_frequency *f) | 1363 | struct v4l2_frequency *f) |
1371 | { | 1364 | { |
1372 | struct cx231xx_fh *fh = priv; | 1365 | struct cx231xx_fh *fh = priv; |
1373 | struct cx231xx *dev = fh->dev; | 1366 | struct cx231xx *dev = fh->dev; |
1374 | int rc; | 1367 | int rc; |
1375 | 1368 | ||
1376 | rc = check_dev(dev); | 1369 | rc = check_dev(dev); |
1377 | if (rc < 0) | 1370 | if (rc < 0) |
@@ -1385,106 +1378,121 @@ static int vidioc_s_frequency(struct file *file, void *priv, | |||
1385 | if (unlikely(1 == fh->radio && f->type != V4L2_TUNER_RADIO)) | 1378 | if (unlikely(1 == fh->radio && f->type != V4L2_TUNER_RADIO)) |
1386 | return -EINVAL; | 1379 | return -EINVAL; |
1387 | 1380 | ||
1388 | /* set pre channel change settings in DIF first */ | 1381 | /* set pre channel change settings in DIF first */ |
1389 | rc = cx231xx_tuner_pre_channel_change(dev); | 1382 | rc = cx231xx_tuner_pre_channel_change(dev); |
1390 | 1383 | ||
1391 | mutex_lock(&dev->lock); | 1384 | mutex_lock(&dev->lock); |
1392 | 1385 | ||
1393 | dev->ctl_freq = f->frequency; | 1386 | dev->ctl_freq = f->frequency; |
1394 | 1387 | ||
1395 | if(dev->tuner_type == TUNER_XC5000) { | 1388 | if (dev->tuner_type == TUNER_XC5000) { |
1396 | if( dev->cx231xx_set_analog_freq != NULL ) { | 1389 | if (dev->cx231xx_set_analog_freq != NULL) { |
1397 | dev->cx231xx_set_analog_freq(dev, f->frequency ); | 1390 | dev->cx231xx_set_analog_freq(dev, f->frequency); |
1398 | } | 1391 | } |
1399 | } else { | 1392 | } else { |
1400 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_FREQUENCY, f); | 1393 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_FREQUENCY, |
1394 | f); | ||
1401 | } | 1395 | } |
1402 | 1396 | ||
1403 | mutex_unlock(&dev->lock); | 1397 | mutex_unlock(&dev->lock); |
1404 | 1398 | ||
1405 | /* set post channel change settings in DIF first */ | 1399 | /* set post channel change settings in DIF first */ |
1406 | rc = cx231xx_tuner_post_channel_change(dev); | 1400 | rc = cx231xx_tuner_post_channel_change(dev); |
1407 | 1401 | ||
1408 | cx231xx_info("Set New FREQUENCY to %d\n",f->frequency); | 1402 | cx231xx_info("Set New FREQUENCY to %d\n", f->frequency); |
1409 | 1403 | ||
1410 | return rc; | 1404 | return rc; |
1411 | } | 1405 | } |
1412 | 1406 | ||
1413 | #ifdef CONFIG_VIDEO_ADV_DEBUG | 1407 | #ifdef CONFIG_VIDEO_ADV_DEBUG |
1414 | 1408 | ||
1415 | |||
1416 | /* | 1409 | /* |
1417 | -R, --list-registers=type=<host/i2cdrv/i2caddr>,chip=<chip>[,min=<addr>,max=<addr>] | 1410 | -R, --list-registers=type=<host/i2cdrv/i2caddr>,chip=<chip>[,min=<addr>,max=<addr>] |
1418 | dump registers from <min> to <max> [VIDIOC_DBG_G_REGISTER] | 1411 | dump registers from <min> to <max> [VIDIOC_DBG_G_REGISTER] |
1419 | -r, --set-register=type=<host/i2cdrv/i2caddr>,chip=<chip>,reg=<addr>,val=<val> | 1412 | -r, --set-register=type=<host/i2cdrv/i2caddr>,chip=<chip>,reg=<addr>,val=<val> |
1420 | set the register [VIDIOC_DBG_S_REGISTER] | 1413 | set the register [VIDIOC_DBG_S_REGISTER] |
1421 | 1414 | ||
1422 | if type == host, then <chip> is the hosts chip ID (default 0) | 1415 | if type == host, then <chip> is the hosts chip ID (default 0) |
1423 | if type == i2cdrv (default), then <chip> is the I2C driver name or ID | 1416 | if type == i2cdrv (default), then <chip> is the I2C driver name or ID |
1424 | if type == i2caddr, then <chip> is the 7-bit I2C address | 1417 | if type == i2caddr, then <chip> is the 7-bit I2C address |
1425 | */ | 1418 | */ |
1426 | 1419 | ||
1427 | |||
1428 | static int vidioc_g_register(struct file *file, void *priv, | 1420 | static int vidioc_g_register(struct file *file, void *priv, |
1429 | struct v4l2_dbg_register *reg) | 1421 | struct v4l2_dbg_register *reg) |
1430 | { | 1422 | { |
1431 | struct cx231xx_fh *fh = priv; | 1423 | struct cx231xx_fh *fh = priv; |
1432 | struct cx231xx *dev = fh->dev; | 1424 | struct cx231xx *dev = fh->dev; |
1433 | int ret = 0; | 1425 | int ret = 0; |
1434 | u8 value[4] ={0,0,0,0}; | 1426 | u8 value[4] = { 0, 0, 0, 0 }; |
1435 | u32 data = 0; | 1427 | u32 data = 0; |
1436 | 1428 | ||
1437 | switch (reg->match.type) { | 1429 | switch (reg->match.type) { |
1438 | case V4L2_CHIP_MATCH_HOST: | 1430 | case V4L2_CHIP_MATCH_HOST: |
1439 | switch(reg->match.addr) { | 1431 | switch (reg->match.addr) { |
1440 | case 0: /* Cx231xx - internal registers */ | 1432 | case 0: /* Cx231xx - internal registers */ |
1441 | ret = cx231xx_read_ctrl_reg(dev,VRT_GET_REGISTER, (u16) reg->reg, value, 4); | 1433 | ret = |
1442 | reg->val = value[0] | value[1] << 8 | value[2] << 16 | value[3] << 24; | 1434 | cx231xx_read_ctrl_reg(dev, VRT_GET_REGISTER, |
1443 | break; | 1435 | (u16) reg->reg, value, 4); |
1444 | case 1: /* Colibri - read byte */ | 1436 | reg->val = |
1445 | ret = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, (u16) reg->reg, 2, &data, 1); | 1437 | value[0] | value[1] << 8 | value[2] << 16 | value[3] |
1446 | reg->val = le32_to_cpu(data & 0xff); | 1438 | << 24; |
1447 | break; | 1439 | break; |
1448 | case 14: /* Colibri - read dword */ | 1440 | case 1: /* Colibri - read byte */ |
1449 | ret = cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, (u16) reg->reg, 2, &data, 4); | 1441 | ret = |
1450 | reg->val = le32_to_cpu(data); | 1442 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
1451 | break; | 1443 | (u16) reg->reg, 2, &data, 1); |
1452 | case 2: /* Hammerhead - read byte */ | 1444 | reg->val = le32_to_cpu(data & 0xff); |
1453 | ret = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, (u16) reg->reg, 2, &data, 1); | 1445 | break; |
1454 | reg->val = le32_to_cpu(data & 0xff); | 1446 | case 14: /* Colibri - read dword */ |
1455 | break; | 1447 | ret = |
1456 | case 24: /* Hammerhead - read dword */ | 1448 | cx231xx_read_i2c_data(dev, Colibri_DEVICE_ADDRESS, |
1457 | ret = cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, (u16) reg->reg, 2, &data, 4); | 1449 | (u16) reg->reg, 2, &data, 4); |
1458 | reg->val = le32_to_cpu(data); | 1450 | reg->val = le32_to_cpu(data); |
1459 | break; | 1451 | break; |
1460 | case 3: /* flatiron - read byte */ | 1452 | case 2: /* Hammerhead - read byte */ |
1461 | ret = cx231xx_read_i2c_data(dev, Flatrion_DEVICE_ADDRESS, (u16) reg->reg, 1, &data, 1); | 1453 | ret = |
1462 | reg->val = le32_to_cpu(data & 0xff); | 1454 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1463 | break; | 1455 | (u16) reg->reg, 2, &data, 1); |
1464 | case 34: /* flatiron - read dword */ | 1456 | reg->val = le32_to_cpu(data & 0xff); |
1465 | ret = cx231xx_read_i2c_data(dev, Flatrion_DEVICE_ADDRESS, (u16) reg->reg, 1, &data, 4); | 1457 | break; |
1466 | reg->val = le32_to_cpu(data); | 1458 | case 24: /* Hammerhead - read dword */ |
1467 | break; | 1459 | ret = |
1468 | } | 1460 | cx231xx_read_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, |
1469 | return ret < 0?ret:0; | 1461 | (u16) reg->reg, 2, &data, 4); |
1470 | 1462 | reg->val = le32_to_cpu(data); | |
1471 | case V4L2_CHIP_MATCH_I2C_DRIVER: | 1463 | break; |
1472 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_DBG_G_REGISTER, reg); | 1464 | case 3: /* flatiron - read byte */ |
1473 | return 0; | 1465 | ret = |
1474 | case V4L2_CHIP_MATCH_I2C_ADDR: | 1466 | cx231xx_read_i2c_data(dev, Flatrion_DEVICE_ADDRESS, |
1475 | /* Not supported yet */ | 1467 | (u16) reg->reg, 1, &data, 1); |
1476 | return -EINVAL; | 1468 | reg->val = le32_to_cpu(data & 0xff); |
1477 | default: | 1469 | break; |
1478 | if (!v4l2_chip_match_host(®->match)) | 1470 | case 34: /* flatiron - read dword */ |
1479 | return -EINVAL; | 1471 | ret = |
1480 | } | 1472 | cx231xx_read_i2c_data(dev, Flatrion_DEVICE_ADDRESS, |
1473 | (u16) reg->reg, 1, &data, 4); | ||
1474 | reg->val = le32_to_cpu(data); | ||
1475 | break; | ||
1476 | } | ||
1477 | return ret < 0 ? ret : 0; | ||
1481 | 1478 | ||
1479 | case V4L2_CHIP_MATCH_I2C_DRIVER: | ||
1480 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], | ||
1481 | VIDIOC_DBG_G_REGISTER, reg); | ||
1482 | return 0; | ||
1483 | case V4L2_CHIP_MATCH_I2C_ADDR: | ||
1484 | /* Not supported yet */ | ||
1485 | return -EINVAL; | ||
1486 | default: | ||
1487 | if (!v4l2_chip_match_host(®->match)) | ||
1488 | return -EINVAL; | ||
1489 | } | ||
1482 | 1490 | ||
1483 | mutex_lock(&dev->lock); | 1491 | mutex_lock(&dev->lock); |
1484 | 1492 | ||
1485 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_DBG_G_REGISTER, reg); | 1493 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_DBG_G_REGISTER, reg); |
1486 | 1494 | ||
1487 | mutex_unlock(&dev->lock); | 1495 | mutex_unlock(&dev->lock); |
1488 | 1496 | ||
1489 | return ret; | 1497 | return ret; |
1490 | } | 1498 | } |
@@ -1492,70 +1500,97 @@ static int vidioc_g_register(struct file *file, void *priv, | |||
1492 | static int vidioc_s_register(struct file *file, void *priv, | 1500 | static int vidioc_s_register(struct file *file, void *priv, |
1493 | struct v4l2_dbg_register *reg) | 1501 | struct v4l2_dbg_register *reg) |
1494 | { | 1502 | { |
1495 | struct cx231xx_fh *fh = priv; | 1503 | struct cx231xx_fh *fh = priv; |
1496 | struct cx231xx *dev = fh->dev; | 1504 | struct cx231xx *dev = fh->dev; |
1497 | int ret = 0; | 1505 | int ret = 0; |
1498 | __le64 buf; | 1506 | __le64 buf; |
1499 | u32 value; | 1507 | u32 value; |
1500 | u8 data[4] ={0,0,0,0}; | 1508 | u8 data[4] = { 0, 0, 0, 0 }; |
1501 | 1509 | ||
1502 | buf = cpu_to_le64(reg->val); | 1510 | buf = cpu_to_le64(reg->val); |
1503 | 1511 | ||
1504 | switch (reg->match.type) { | 1512 | switch (reg->match.type) { |
1505 | case V4L2_CHIP_MATCH_HOST: | 1513 | case V4L2_CHIP_MATCH_HOST: |
1506 | { | 1514 | { |
1507 | value = (u32) buf & 0xffffffff; | 1515 | value = (u32) buf & 0xffffffff; |
1508 | 1516 | ||
1509 | switch(reg->match.addr) { | 1517 | switch (reg->match.addr) { |
1510 | case 0: /* cx231xx internal registers */ | 1518 | case 0: /* cx231xx internal registers */ |
1511 | data[0]=(u8)value; | 1519 | data[0] = (u8) value; |
1512 | data[1]=(u8)(value>>8); | 1520 | data[1] = (u8) (value >> 8); |
1513 | data[2]=(u8)(value>>16); | 1521 | data[2] = (u8) (value >> 16); |
1514 | data[3]=(u8)(value>>24); | 1522 | data[3] = (u8) (value >> 24); |
1515 | ret = cx231xx_write_ctrl_reg(dev,VRT_SET_REGISTER, (u16) reg->reg, data, 4); | 1523 | ret = |
1516 | break; | 1524 | cx231xx_write_ctrl_reg(dev, |
1517 | case 1: /* Colibri - read byte */ | 1525 | VRT_SET_REGISTER, |
1518 | ret = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, (u16) reg->reg, 2, value, 1); | 1526 | (u16) reg->reg, data, |
1519 | break; | 1527 | 4); |
1520 | case 14: /* Colibri - read dword */ | 1528 | break; |
1521 | ret = cx231xx_write_i2c_data(dev, Colibri_DEVICE_ADDRESS, (u16) reg->reg, 2, value, 4); | 1529 | case 1: /* Colibri - read byte */ |
1522 | break; | 1530 | ret = |
1523 | case 2: /* Hammerhead - read byte */ | 1531 | cx231xx_write_i2c_data(dev, |
1524 | ret = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, (u16) reg->reg, 2, value, 1); | 1532 | Colibri_DEVICE_ADDRESS, |
1525 | break; | 1533 | (u16) reg->reg, 2, |
1526 | case 24: /* Hammerhead - read dword */ | 1534 | value, 1); |
1527 | ret = cx231xx_write_i2c_data(dev, HAMMERHEAD_I2C_ADDRESS, (u16) reg->reg, 2, value, 4); | 1535 | break; |
1528 | break; | 1536 | case 14: /* Colibri - read dword */ |
1529 | case 3: /* flatiron - read byte */ | 1537 | ret = |
1530 | ret = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, (u16) reg->reg, 1, value, 1); | 1538 | cx231xx_write_i2c_data(dev, |
1531 | break; | 1539 | Colibri_DEVICE_ADDRESS, |
1532 | case 34: /* flatiron - read dword */ | 1540 | (u16) reg->reg, 2, |
1533 | ret = cx231xx_write_i2c_data(dev, Flatrion_DEVICE_ADDRESS, (u16) reg->reg, 1, value, 4); | 1541 | value, 4); |
1534 | break; | 1542 | break; |
1535 | } | 1543 | case 2: /* Hammerhead - read byte */ |
1536 | } | 1544 | ret = |
1537 | return ret < 0?ret:0; | 1545 | cx231xx_write_i2c_data(dev, |
1538 | 1546 | HAMMERHEAD_I2C_ADDRESS, | |
1539 | default: | 1547 | (u16) reg->reg, 2, |
1540 | break; | 1548 | value, 1); |
1541 | } | 1549 | break; |
1550 | case 24: /* Hammerhead - read dword */ | ||
1551 | ret = | ||
1552 | cx231xx_write_i2c_data(dev, | ||
1553 | HAMMERHEAD_I2C_ADDRESS, | ||
1554 | (u16) reg->reg, 2, | ||
1555 | value, 4); | ||
1556 | break; | ||
1557 | case 3: /* flatiron - read byte */ | ||
1558 | ret = | ||
1559 | cx231xx_write_i2c_data(dev, | ||
1560 | Flatrion_DEVICE_ADDRESS, | ||
1561 | (u16) reg->reg, 1, | ||
1562 | value, 1); | ||
1563 | break; | ||
1564 | case 34: /* flatiron - read dword */ | ||
1565 | ret = | ||
1566 | cx231xx_write_i2c_data(dev, | ||
1567 | Flatrion_DEVICE_ADDRESS, | ||
1568 | (u16) reg->reg, 1, | ||
1569 | value, 4); | ||
1570 | break; | ||
1571 | } | ||
1572 | } | ||
1573 | return ret < 0 ? ret : 0; | ||
1574 | |||
1575 | default: | ||
1576 | break; | ||
1577 | } | ||
1542 | 1578 | ||
1543 | mutex_lock(&dev->lock); | 1579 | mutex_lock(&dev->lock); |
1544 | 1580 | ||
1545 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_DBG_S_REGISTER, reg); | 1581 | cx231xx_i2c_call_clients(&dev->i2c_bus[0], VIDIOC_DBG_S_REGISTER, reg); |
1546 | 1582 | ||
1547 | mutex_unlock(&dev->lock); | 1583 | mutex_unlock(&dev->lock); |
1548 | 1584 | ||
1549 | return ret; | 1585 | return ret; |
1550 | } | 1586 | } |
1551 | #endif | 1587 | #endif |
1552 | 1588 | ||
1553 | |||
1554 | static int vidioc_cropcap(struct file *file, void *priv, | 1589 | static int vidioc_cropcap(struct file *file, void *priv, |
1555 | struct v4l2_cropcap *cc) | 1590 | struct v4l2_cropcap *cc) |
1556 | { | 1591 | { |
1557 | struct cx231xx_fh *fh = priv; | 1592 | struct cx231xx_fh *fh = priv; |
1558 | struct cx231xx *dev = fh->dev; | 1593 | struct cx231xx *dev = fh->dev; |
1559 | 1594 | ||
1560 | if (cc->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) | 1595 | if (cc->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) |
1561 | return -EINVAL; | 1596 | return -EINVAL; |
@@ -1572,17 +1607,17 @@ static int vidioc_cropcap(struct file *file, void *priv, | |||
1572 | } | 1607 | } |
1573 | 1608 | ||
1574 | static int vidioc_streamon(struct file *file, void *priv, | 1609 | static int vidioc_streamon(struct file *file, void *priv, |
1575 | enum v4l2_buf_type type) | 1610 | enum v4l2_buf_type type) |
1576 | { | 1611 | { |
1577 | struct cx231xx_fh *fh = priv; | 1612 | struct cx231xx_fh *fh = priv; |
1578 | struct cx231xx *dev = fh->dev; | 1613 | struct cx231xx *dev = fh->dev; |
1579 | int rc; | 1614 | int rc; |
1580 | 1615 | ||
1581 | rc = check_dev(dev); | 1616 | rc = check_dev(dev); |
1582 | if (rc < 0) | 1617 | if (rc < 0) |
1583 | return rc; | 1618 | return rc; |
1584 | 1619 | ||
1585 | mutex_lock(&dev->lock); | 1620 | mutex_lock(&dev->lock); |
1586 | rc = res_get(fh); | 1621 | rc = res_get(fh); |
1587 | 1622 | ||
1588 | if (likely(rc >= 0)) | 1623 | if (likely(rc >= 0)) |
@@ -1594,52 +1629,51 @@ static int vidioc_streamon(struct file *file, void *priv, | |||
1594 | } | 1629 | } |
1595 | 1630 | ||
1596 | static int vidioc_streamoff(struct file *file, void *priv, | 1631 | static int vidioc_streamoff(struct file *file, void *priv, |
1597 | enum v4l2_buf_type type) | 1632 | enum v4l2_buf_type type) |
1598 | { | 1633 | { |
1599 | struct cx231xx_fh *fh = priv; | 1634 | struct cx231xx_fh *fh = priv; |
1600 | struct cx231xx *dev = fh->dev; | 1635 | struct cx231xx *dev = fh->dev; |
1601 | int rc; | 1636 | int rc; |
1602 | 1637 | ||
1603 | rc = check_dev(dev); | 1638 | rc = check_dev(dev); |
1604 | if (rc < 0) | 1639 | if (rc < 0) |
1605 | return rc; | 1640 | return rc; |
1606 | 1641 | ||
1607 | if ( (fh->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) || | 1642 | if ((fh->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) || |
1608 | (fh->type != V4L2_BUF_TYPE_VBI_CAPTURE) ) | 1643 | (fh->type != V4L2_BUF_TYPE_VBI_CAPTURE)) |
1609 | return -EINVAL; | 1644 | return -EINVAL; |
1610 | if (type != fh->type) | 1645 | if (type != fh->type) |
1611 | return -EINVAL; | 1646 | return -EINVAL; |
1612 | 1647 | ||
1613 | mutex_lock(&dev->lock); | 1648 | mutex_lock(&dev->lock); |
1614 | 1649 | ||
1615 | videobuf_streamoff(&fh->vb_vidq); | 1650 | videobuf_streamoff(&fh->vb_vidq); |
1616 | res_free(fh); | 1651 | res_free(fh); |
1617 | 1652 | ||
1618 | mutex_unlock(&dev->lock); | 1653 | mutex_unlock(&dev->lock); |
1619 | 1654 | ||
1620 | return 0; | 1655 | return 0; |
1621 | } | 1656 | } |
1622 | 1657 | ||
1623 | static int vidioc_querycap(struct file *file, void *priv, | 1658 | static int vidioc_querycap(struct file *file, void *priv, |
1624 | struct v4l2_capability *cap) | 1659 | struct v4l2_capability *cap) |
1625 | { | 1660 | { |
1626 | struct cx231xx_fh *fh = priv; | 1661 | struct cx231xx_fh *fh = priv; |
1627 | struct cx231xx *dev = fh->dev; | 1662 | struct cx231xx *dev = fh->dev; |
1628 | 1663 | ||
1629 | strlcpy(cap->driver, "cx231xx", sizeof(cap->driver)); | 1664 | strlcpy(cap->driver, "cx231xx", sizeof(cap->driver)); |
1630 | strlcpy(cap->card, cx231xx_boards[dev->model].name, sizeof(cap->card)); | 1665 | strlcpy(cap->card, cx231xx_boards[dev->model].name, sizeof(cap->card)); |
1631 | strlcpy(cap->bus_info, dev_name(&dev->udev->dev), sizeof(cap->bus_info)); | 1666 | strlcpy(cap->bus_info, dev_name(&dev->udev->dev), |
1667 | sizeof(cap->bus_info)); | ||
1632 | 1668 | ||
1633 | cap->version = CX231XX_VERSION_CODE; | 1669 | cap->version = CX231XX_VERSION_CODE; |
1634 | 1670 | ||
1635 | cap->capabilities = | 1671 | cap->capabilities = V4L2_CAP_VBI_CAPTURE | |
1636 | V4L2_CAP_VBI_CAPTURE | | ||
1637 | #if 0 | 1672 | #if 0 |
1638 | V4L2_CAP_SLICED_VBI_CAPTURE | | 1673 | V4L2_CAP_SLICED_VBI_CAPTURE | |
1639 | #endif | 1674 | #endif |
1640 | V4L2_CAP_VIDEO_CAPTURE | | 1675 | V4L2_CAP_VIDEO_CAPTURE | |
1641 | V4L2_CAP_AUDIO | | 1676 | V4L2_CAP_AUDIO | V4L2_CAP_READWRITE | V4L2_CAP_STREAMING; |
1642 | V4L2_CAP_READWRITE | V4L2_CAP_STREAMING; | ||
1643 | 1677 | ||
1644 | if (dev->tuner_type != TUNER_ABSENT) | 1678 | if (dev->tuner_type != TUNER_ABSENT) |
1645 | cap->capabilities |= V4L2_CAP_TUNER; | 1679 | cap->capabilities |= V4L2_CAP_TUNER; |
@@ -1647,10 +1681,10 @@ static int vidioc_querycap(struct file *file, void *priv, | |||
1647 | return 0; | 1681 | return 0; |
1648 | } | 1682 | } |
1649 | 1683 | ||
1650 | static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv, | 1684 | static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv, |
1651 | struct v4l2_fmtdesc *f) | 1685 | struct v4l2_fmtdesc *f) |
1652 | { | 1686 | { |
1653 | if (unlikely(f->index >= ARRAY_SIZE(format))) | 1687 | if (unlikely(f->index >= ARRAY_SIZE(format))) |
1654 | return -EINVAL; | 1688 | return -EINVAL; |
1655 | 1689 | ||
1656 | strlcpy(f->description, format[f->index].name, sizeof(f->description)); | 1690 | strlcpy(f->description, format[f->index].name, sizeof(f->description)); |
@@ -1661,11 +1695,11 @@ static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv, | |||
1661 | 1695 | ||
1662 | /* Sliced VBI ioctls */ | 1696 | /* Sliced VBI ioctls */ |
1663 | static int vidioc_g_fmt_sliced_vbi_cap(struct file *file, void *priv, | 1697 | static int vidioc_g_fmt_sliced_vbi_cap(struct file *file, void *priv, |
1664 | struct v4l2_format *f) | 1698 | struct v4l2_format *f) |
1665 | { | 1699 | { |
1666 | struct cx231xx_fh *fh = priv; | 1700 | struct cx231xx_fh *fh = priv; |
1667 | struct cx231xx *dev = fh->dev; | 1701 | struct cx231xx *dev = fh->dev; |
1668 | int rc; | 1702 | int rc; |
1669 | 1703 | ||
1670 | rc = check_dev(dev); | 1704 | rc = check_dev(dev); |
1671 | if (rc < 0) | 1705 | if (rc < 0) |
@@ -1685,11 +1719,11 @@ static int vidioc_g_fmt_sliced_vbi_cap(struct file *file, void *priv, | |||
1685 | } | 1719 | } |
1686 | 1720 | ||
1687 | static int vidioc_try_set_sliced_vbi_cap(struct file *file, void *priv, | 1721 | static int vidioc_try_set_sliced_vbi_cap(struct file *file, void *priv, |
1688 | struct v4l2_format *f) | 1722 | struct v4l2_format *f) |
1689 | { | 1723 | { |
1690 | struct cx231xx_fh *fh = priv; | 1724 | struct cx231xx_fh *fh = priv; |
1691 | struct cx231xx *dev = fh->dev; | 1725 | struct cx231xx *dev = fh->dev; |
1692 | int rc; | 1726 | int rc; |
1693 | 1727 | ||
1694 | rc = check_dev(dev); | 1728 | rc = check_dev(dev); |
1695 | if (rc < 0) | 1729 | if (rc < 0) |
@@ -1705,26 +1739,25 @@ static int vidioc_try_set_sliced_vbi_cap(struct file *file, void *priv, | |||
1705 | return 0; | 1739 | return 0; |
1706 | } | 1740 | } |
1707 | 1741 | ||
1708 | |||
1709 | /* RAW VBI ioctls */ | 1742 | /* RAW VBI ioctls */ |
1710 | 1743 | ||
1711 | static int vidioc_g_fmt_vbi_cap(struct file *file, void *priv, | 1744 | static int vidioc_g_fmt_vbi_cap(struct file *file, void *priv, |
1712 | struct v4l2_format *f) | 1745 | struct v4l2_format *f) |
1713 | { | 1746 | { |
1714 | struct cx231xx_fh *fh = priv; | 1747 | struct cx231xx_fh *fh = priv; |
1715 | struct cx231xx *dev = fh->dev; | 1748 | struct cx231xx *dev = fh->dev; |
1716 | 1749 | ||
1717 | f->fmt.vbi.sampling_rate = (dev->norm & V4L2_STD_625_50) ? | 1750 | f->fmt.vbi.sampling_rate = (dev->norm & V4L2_STD_625_50) ? |
1718 | 35468950:28636363; | 1751 | 35468950 : 28636363; |
1719 | f->fmt.vbi.samples_per_line = VBI_LINE_LENGTH; | 1752 | f->fmt.vbi.samples_per_line = VBI_LINE_LENGTH; |
1720 | f->fmt.vbi.sample_format = V4L2_PIX_FMT_GREY; | 1753 | f->fmt.vbi.sample_format = V4L2_PIX_FMT_GREY; |
1721 | f->fmt.vbi.offset = 64 * 4; | 1754 | f->fmt.vbi.offset = 64 * 4; |
1722 | f->fmt.vbi.start[0] = (dev->norm & V4L2_STD_625_50) ? | 1755 | f->fmt.vbi.start[0] = (dev->norm & V4L2_STD_625_50) ? |
1723 | PAL_VBI_START_LINE : NTSC_VBI_START_LINE; | 1756 | PAL_VBI_START_LINE : NTSC_VBI_START_LINE; |
1724 | f->fmt.vbi.count[0] = (dev->norm & V4L2_STD_625_50) ? | 1757 | f->fmt.vbi.count[0] = (dev->norm & V4L2_STD_625_50) ? |
1725 | PAL_VBI_LINES : NTSC_VBI_LINES; | 1758 | PAL_VBI_LINES : NTSC_VBI_LINES; |
1726 | f->fmt.vbi.start[1] = (dev->norm & V4L2_STD_625_50) ? | 1759 | f->fmt.vbi.start[1] = (dev->norm & V4L2_STD_625_50) ? |
1727 | PAL_VBI_START_LINE+312 : NTSC_VBI_START_LINE + 263; | 1760 | PAL_VBI_START_LINE + 312 : NTSC_VBI_START_LINE + 263; |
1728 | f->fmt.vbi.count[1] = f->fmt.vbi.count[0]; | 1761 | f->fmt.vbi.count[1] = f->fmt.vbi.count[0]; |
1729 | 1762 | ||
1730 | return 0; | 1763 | return 0; |
@@ -1732,29 +1765,29 @@ static int vidioc_g_fmt_vbi_cap(struct file *file, void *priv, | |||
1732 | } | 1765 | } |
1733 | 1766 | ||
1734 | static int vidioc_try_fmt_vbi_cap(struct file *file, void *priv, | 1767 | static int vidioc_try_fmt_vbi_cap(struct file *file, void *priv, |
1735 | struct v4l2_format *f) | 1768 | struct v4l2_format *f) |
1736 | { | 1769 | { |
1737 | struct cx231xx_fh *fh = priv; | 1770 | struct cx231xx_fh *fh = priv; |
1738 | struct cx231xx *dev = fh->dev; | 1771 | struct cx231xx *dev = fh->dev; |
1739 | 1772 | ||
1740 | if (dev->vbi_stream_on && !fh->stream_on) { | 1773 | if (dev->vbi_stream_on && !fh->stream_on) { |
1741 | cx231xx_errdev("%s device in use by another fh\n", __func__); | 1774 | cx231xx_errdev("%s device in use by another fh\n", __func__); |
1742 | return -EBUSY; | 1775 | return -EBUSY; |
1743 | } | 1776 | } |
1744 | 1777 | ||
1745 | f->type = V4L2_BUF_TYPE_VBI_CAPTURE; | 1778 | f->type = V4L2_BUF_TYPE_VBI_CAPTURE; |
1746 | f->fmt.vbi.sampling_rate = (dev->norm & V4L2_STD_625_50) ? | 1779 | f->fmt.vbi.sampling_rate = (dev->norm & V4L2_STD_625_50) ? |
1747 | 35468950:28636363; | 1780 | 35468950 : 28636363; |
1748 | f->fmt.vbi.samples_per_line = VBI_LINE_LENGTH; | 1781 | f->fmt.vbi.samples_per_line = VBI_LINE_LENGTH; |
1749 | f->fmt.vbi.sample_format = V4L2_PIX_FMT_GREY; | 1782 | f->fmt.vbi.sample_format = V4L2_PIX_FMT_GREY; |
1750 | f->fmt.vbi.offset = 244; | 1783 | f->fmt.vbi.offset = 244; |
1751 | f->fmt.vbi.flags = 0; | 1784 | f->fmt.vbi.flags = 0; |
1752 | f->fmt.vbi.start[0] = (dev->norm & V4L2_STD_625_50) ? | 1785 | f->fmt.vbi.start[0] = (dev->norm & V4L2_STD_625_50) ? |
1753 | PAL_VBI_START_LINE : NTSC_VBI_START_LINE; | 1786 | PAL_VBI_START_LINE : NTSC_VBI_START_LINE; |
1754 | f->fmt.vbi.count[0] = (dev->norm & V4L2_STD_625_50) ? | 1787 | f->fmt.vbi.count[0] = (dev->norm & V4L2_STD_625_50) ? |
1755 | PAL_VBI_LINES : NTSC_VBI_LINES; | 1788 | PAL_VBI_LINES : NTSC_VBI_LINES; |
1756 | f->fmt.vbi.start[1] = (dev->norm & V4L2_STD_625_50) ? | 1789 | f->fmt.vbi.start[1] = (dev->norm & V4L2_STD_625_50) ? |
1757 | PAL_VBI_START_LINE+312 : NTSC_VBI_START_LINE + 263; | 1790 | PAL_VBI_START_LINE + 312 : NTSC_VBI_START_LINE + 263; |
1758 | f->fmt.vbi.count[1] = f->fmt.vbi.count[0]; | 1791 | f->fmt.vbi.count[1] = f->fmt.vbi.count[0]; |
1759 | 1792 | ||
1760 | return 0; | 1793 | return 0; |
@@ -1764,9 +1797,9 @@ static int vidioc_try_fmt_vbi_cap(struct file *file, void *priv, | |||
1764 | static int vidioc_reqbufs(struct file *file, void *priv, | 1797 | static int vidioc_reqbufs(struct file *file, void *priv, |
1765 | struct v4l2_requestbuffers *rb) | 1798 | struct v4l2_requestbuffers *rb) |
1766 | { | 1799 | { |
1767 | struct cx231xx_fh *fh = priv; | 1800 | struct cx231xx_fh *fh = priv; |
1768 | struct cx231xx *dev = fh->dev; | 1801 | struct cx231xx *dev = fh->dev; |
1769 | int rc; | 1802 | int rc; |
1770 | 1803 | ||
1771 | rc = check_dev(dev); | 1804 | rc = check_dev(dev); |
1772 | if (rc < 0) | 1805 | if (rc < 0) |
@@ -1775,12 +1808,11 @@ static int vidioc_reqbufs(struct file *file, void *priv, | |||
1775 | return (videobuf_reqbufs(&fh->vb_vidq, rb)); | 1808 | return (videobuf_reqbufs(&fh->vb_vidq, rb)); |
1776 | } | 1809 | } |
1777 | 1810 | ||
1778 | static int vidioc_querybuf(struct file *file, void *priv, | 1811 | static int vidioc_querybuf(struct file *file, void *priv, struct v4l2_buffer *b) |
1779 | struct v4l2_buffer *b) | ||
1780 | { | 1812 | { |
1781 | struct cx231xx_fh *fh = priv; | 1813 | struct cx231xx_fh *fh = priv; |
1782 | struct cx231xx *dev = fh->dev; | 1814 | struct cx231xx *dev = fh->dev; |
1783 | int rc; | 1815 | int rc; |
1784 | 1816 | ||
1785 | rc = check_dev(dev); | 1817 | rc = check_dev(dev); |
1786 | if (rc < 0) | 1818 | if (rc < 0) |
@@ -1791,9 +1823,9 @@ static int vidioc_querybuf(struct file *file, void *priv, | |||
1791 | 1823 | ||
1792 | static int vidioc_qbuf(struct file *file, void *priv, struct v4l2_buffer *b) | 1824 | static int vidioc_qbuf(struct file *file, void *priv, struct v4l2_buffer *b) |
1793 | { | 1825 | { |
1794 | struct cx231xx_fh *fh = priv; | 1826 | struct cx231xx_fh *fh = priv; |
1795 | struct cx231xx *dev = fh->dev; | 1827 | struct cx231xx *dev = fh->dev; |
1796 | int rc; | 1828 | int rc; |
1797 | 1829 | ||
1798 | rc = check_dev(dev); | 1830 | rc = check_dev(dev); |
1799 | if (rc < 0) | 1831 | if (rc < 0) |
@@ -1804,33 +1836,31 @@ static int vidioc_qbuf(struct file *file, void *priv, struct v4l2_buffer *b) | |||
1804 | 1836 | ||
1805 | static int vidioc_dqbuf(struct file *file, void *priv, struct v4l2_buffer *b) | 1837 | static int vidioc_dqbuf(struct file *file, void *priv, struct v4l2_buffer *b) |
1806 | { | 1838 | { |
1807 | struct cx231xx_fh *fh = priv; | 1839 | struct cx231xx_fh *fh = priv; |
1808 | struct cx231xx *dev = fh->dev; | 1840 | struct cx231xx *dev = fh->dev; |
1809 | int rc; | 1841 | int rc; |
1810 | 1842 | ||
1811 | rc = check_dev(dev); | 1843 | rc = check_dev(dev); |
1812 | if (rc < 0) | 1844 | if (rc < 0) |
1813 | return rc; | 1845 | return rc; |
1814 | 1846 | ||
1815 | return (videobuf_dqbuf(&fh->vb_vidq, b, | 1847 | return (videobuf_dqbuf(&fh->vb_vidq, b, file->f_flags & O_NONBLOCK)); |
1816 | file->f_flags & O_NONBLOCK)); | ||
1817 | } | 1848 | } |
1818 | 1849 | ||
1819 | #ifdef CONFIG_VIDEO_V4L1_COMPAT | 1850 | #ifdef CONFIG_VIDEO_V4L1_COMPAT |
1820 | static int vidiocgmbuf(struct file *file, void *priv, struct video_mbuf *mbuf) | 1851 | static int vidiocgmbuf(struct file *file, void *priv, struct video_mbuf *mbuf) |
1821 | { | 1852 | { |
1822 | struct cx231xx_fh *fh = priv; | 1853 | struct cx231xx_fh *fh = priv; |
1823 | 1854 | ||
1824 | return videobuf_cgmbuf(&fh->vb_vidq, mbuf, 8); | 1855 | return videobuf_cgmbuf(&fh->vb_vidq, mbuf, 8); |
1825 | } | 1856 | } |
1826 | #endif | 1857 | #endif |
1827 | 1858 | ||
1828 | |||
1829 | /* ----------------------------------------------------------- */ | 1859 | /* ----------------------------------------------------------- */ |
1830 | /* RADIO ESPECIFIC IOCTLS */ | 1860 | /* RADIO ESPECIFIC IOCTLS */ |
1831 | /* ----------------------------------------------------------- */ | 1861 | /* ----------------------------------------------------------- */ |
1832 | 1862 | ||
1833 | static int radio_querycap(struct file *file, void *priv, | 1863 | static int radio_querycap(struct file *file, void *priv, |
1834 | struct v4l2_capability *cap) | 1864 | struct v4l2_capability *cap) |
1835 | { | 1865 | { |
1836 | struct cx231xx *dev = ((struct cx231xx_fh *)priv)->dev; | 1866 | struct cx231xx *dev = ((struct cx231xx_fh *)priv)->dev; |
@@ -1844,8 +1874,7 @@ static int radio_querycap(struct file *file, void *priv, | |||
1844 | return 0; | 1874 | return 0; |
1845 | } | 1875 | } |
1846 | 1876 | ||
1847 | static int radio_g_tuner(struct file *file, void *priv, | 1877 | static int radio_g_tuner(struct file *file, void *priv, struct v4l2_tuner *t) |
1848 | struct v4l2_tuner *t) | ||
1849 | { | 1878 | { |
1850 | struct cx231xx *dev = ((struct cx231xx_fh *)priv)->dev; | 1879 | struct cx231xx *dev = ((struct cx231xx_fh *)priv)->dev; |
1851 | 1880 | ||
@@ -1855,15 +1884,14 @@ static int radio_g_tuner(struct file *file, void *priv, | |||
1855 | strcpy(t->name, "Radio"); | 1884 | strcpy(t->name, "Radio"); |
1856 | t->type = V4L2_TUNER_RADIO; | 1885 | t->type = V4L2_TUNER_RADIO; |
1857 | 1886 | ||
1858 | mutex_lock(&dev->lock); | 1887 | mutex_lock(&dev->lock); |
1859 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_G_TUNER, t); | 1888 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_G_TUNER, t); |
1860 | mutex_unlock(&dev->lock); | 1889 | mutex_unlock(&dev->lock); |
1861 | 1890 | ||
1862 | return 0; | 1891 | return 0; |
1863 | } | 1892 | } |
1864 | 1893 | ||
1865 | static int radio_enum_input(struct file *file, void *priv, | 1894 | static int radio_enum_input(struct file *file, void *priv, struct v4l2_input *i) |
1866 | struct v4l2_input *i) | ||
1867 | { | 1895 | { |
1868 | if (i->index != 0) | 1896 | if (i->index != 0) |
1869 | return -EINVAL; | 1897 | return -EINVAL; |
@@ -1882,23 +1910,21 @@ static int radio_g_audio(struct file *file, void *priv, struct v4l2_audio *a) | |||
1882 | return 0; | 1910 | return 0; |
1883 | } | 1911 | } |
1884 | 1912 | ||
1885 | static int radio_s_tuner(struct file *file, void *priv, | 1913 | static int radio_s_tuner(struct file *file, void *priv, struct v4l2_tuner *t) |
1886 | struct v4l2_tuner *t) | ||
1887 | { | 1914 | { |
1888 | struct cx231xx *dev = ((struct cx231xx_fh *)priv)->dev; | 1915 | struct cx231xx *dev = ((struct cx231xx_fh *)priv)->dev; |
1889 | 1916 | ||
1890 | if (0 != t->index) | 1917 | if (0 != t->index) |
1891 | return -EINVAL; | 1918 | return -EINVAL; |
1892 | 1919 | ||
1893 | mutex_lock(&dev->lock); | 1920 | mutex_lock(&dev->lock); |
1894 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_TUNER, t); | 1921 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], VIDIOC_S_TUNER, t); |
1895 | mutex_unlock(&dev->lock); | 1922 | mutex_unlock(&dev->lock); |
1896 | 1923 | ||
1897 | return 0; | 1924 | return 0; |
1898 | } | 1925 | } |
1899 | 1926 | ||
1900 | static int radio_s_audio(struct file *file, void *fh, | 1927 | static int radio_s_audio(struct file *file, void *fh, struct v4l2_audio *a) |
1901 | struct v4l2_audio *a) | ||
1902 | { | 1928 | { |
1903 | return 0; | 1929 | return 0; |
1904 | } | 1930 | } |
@@ -1913,8 +1939,7 @@ static int radio_queryctrl(struct file *file, void *priv, | |||
1913 | { | 1939 | { |
1914 | int i; | 1940 | int i; |
1915 | 1941 | ||
1916 | if (c->id < V4L2_CID_BASE || | 1942 | if (c->id < V4L2_CID_BASE || c->id >= V4L2_CID_LASTP1) |
1917 | c->id >= V4L2_CID_LASTP1) | ||
1918 | return -EINVAL; | 1943 | return -EINVAL; |
1919 | if (c->id == V4L2_CID_AUDIO_MUTE) { | 1944 | if (c->id == V4L2_CID_AUDIO_MUTE) { |
1920 | for (i = 0; i < CX231XX_CTLS; i++) | 1945 | for (i = 0; i < CX231XX_CTLS; i++) |
@@ -1932,25 +1957,26 @@ static int radio_queryctrl(struct file *file, void *priv, | |||
1932 | */ | 1957 | */ |
1933 | static int cx231xx_v4l2_open(struct file *filp) | 1958 | static int cx231xx_v4l2_open(struct file *filp) |
1934 | { | 1959 | { |
1935 | int minor = video_devdata(filp)->minor; | 1960 | int minor = video_devdata(filp)->minor; |
1936 | int errCode = 0, radio = 0; | 1961 | int errCode = 0, radio = 0; |
1937 | struct cx231xx *dev = NULL; | 1962 | struct cx231xx *dev = NULL; |
1938 | struct cx231xx_fh *fh; | 1963 | struct cx231xx_fh *fh; |
1939 | enum v4l2_buf_type fh_type = 0; | 1964 | enum v4l2_buf_type fh_type = 0; |
1940 | 1965 | ||
1941 | dev = cx231xx_get_device(minor, &fh_type, &radio); | 1966 | dev = cx231xx_get_device(minor, &fh_type, &radio); |
1942 | if (NULL == dev) | 1967 | if (NULL == dev) |
1943 | return -ENODEV; | 1968 | return -ENODEV; |
1944 | 1969 | ||
1945 | mutex_lock(&dev->lock); | 1970 | mutex_lock(&dev->lock); |
1946 | 1971 | ||
1947 | cx231xx_videodbg("open minor=%d type=%s users=%d\n", | 1972 | cx231xx_videodbg("open minor=%d type=%s users=%d\n", |
1948 | minor, v4l2_type_names[fh_type], dev->users); | 1973 | minor, v4l2_type_names[fh_type], dev->users); |
1949 | 1974 | ||
1950 | #if 0 | 1975 | #if 0 |
1951 | errCode = cx231xx_set_mode(dev, CX231XX_ANALOG_MODE); | 1976 | errCode = cx231xx_set_mode(dev, CX231XX_ANALOG_MODE); |
1952 | if (errCode < 0) { | 1977 | if (errCode < 0) { |
1953 | cx231xx_errdev("Device locked on digital mode. Can't open analog\n"); | 1978 | cx231xx_errdev |
1979 | ("Device locked on digital mode. Can't open analog\n"); | ||
1954 | mutex_unlock(&dev->lock); | 1980 | mutex_unlock(&dev->lock); |
1955 | return -EBUSY; | 1981 | return -EBUSY; |
1956 | } | 1982 | } |
@@ -1973,25 +1999,24 @@ static int cx231xx_v4l2_open(struct file *filp) | |||
1973 | dev->hscale = 0; | 1999 | dev->hscale = 0; |
1974 | dev->vscale = 0; | 2000 | dev->vscale = 0; |
1975 | 2001 | ||
1976 | 2002 | /* Power up in Analog TV mode */ | |
1977 | /* Power up in Analog TV mode */ | 2003 | cx231xx_set_power_mode(dev, POLARIS_AVMODE_ANALOGT_TV); |
1978 | cx231xx_set_power_mode(dev, POLARIS_AVMODE_ANALOGT_TV); | ||
1979 | 2004 | ||
1980 | #if 0 | 2005 | #if 0 |
1981 | cx231xx_set_mode(dev, CX231XX_ANALOG_MODE); | 2006 | cx231xx_set_mode(dev, CX231XX_ANALOG_MODE); |
1982 | #endif | 2007 | #endif |
1983 | cx231xx_resolution_set(dev); | 2008 | cx231xx_resolution_set(dev); |
1984 | 2009 | ||
1985 | /* set video alternate setting */ | 2010 | /* set video alternate setting */ |
1986 | cx231xx_set_video_alternate(dev); | 2011 | cx231xx_set_video_alternate(dev); |
1987 | 2012 | ||
1988 | /* Needed, since GPIO might have disabled power of | 2013 | /* Needed, since GPIO might have disabled power of |
1989 | some i2c device */ | 2014 | some i2c device */ |
1990 | cx231xx_config_i2c(dev); | 2015 | cx231xx_config_i2c(dev); |
1991 | 2016 | ||
1992 | /* device needs to be initialized before isoc transfer */ | 2017 | /* device needs to be initialized before isoc transfer */ |
1993 | dev->video_input = dev->video_input > 2 ? 2: dev->video_input; | 2018 | dev->video_input = dev->video_input > 2 ? 2 : dev->video_input; |
1994 | video_mux(dev, dev->video_input ); | 2019 | video_mux(dev, dev->video_input); |
1995 | 2020 | ||
1996 | } | 2021 | } |
1997 | if (fh->radio) { | 2022 | if (fh->radio) { |
@@ -1999,26 +2024,25 @@ static int cx231xx_v4l2_open(struct file *filp) | |||
1999 | 2024 | ||
2000 | /* cx231xx_start_radio(dev); */ | 2025 | /* cx231xx_start_radio(dev); */ |
2001 | 2026 | ||
2002 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], AUDC_SET_RADIO, NULL); | 2027 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], AUDC_SET_RADIO, |
2028 | NULL); | ||
2003 | } | 2029 | } |
2004 | 2030 | ||
2005 | dev->users++; | 2031 | dev->users++; |
2006 | 2032 | ||
2007 | if (fh->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) { | 2033 | if (fh->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) { |
2008 | videobuf_queue_vmalloc_init(&fh->vb_vidq, &cx231xx_video_qops, | 2034 | videobuf_queue_vmalloc_init(&fh->vb_vidq, &cx231xx_video_qops, NULL, &dev->video_mode.slock, fh->type, V4L2_FIELD_INTERLACED, /* V4L2_FIELD_SEQ_TB, */ |
2009 | NULL, &dev->video_mode.slock, fh->type, V4L2_FIELD_INTERLACED, /* V4L2_FIELD_SEQ_TB, */ | 2035 | sizeof(struct cx231xx_buffer), fh); |
2010 | sizeof(struct cx231xx_buffer), fh); | 2036 | } |
2011 | } | ||
2012 | 2037 | ||
2013 | if (fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) { | 2038 | if (fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) { |
2014 | 2039 | ||
2015 | /* Set the required alternate setting VBI interface works in Bulk mode only */ | 2040 | /* Set the required alternate setting VBI interface works in Bulk mode only */ |
2016 | cx231xx_set_alt_setting(dev, INDEX_VANC, 0); | 2041 | cx231xx_set_alt_setting(dev, INDEX_VANC, 0); |
2017 | 2042 | ||
2018 | videobuf_queue_vmalloc_init(&fh->vb_vidq, &cx231xx_vbi_qops, | 2043 | videobuf_queue_vmalloc_init(&fh->vb_vidq, &cx231xx_vbi_qops, NULL, &dev->vbi_mode.slock, fh->type, V4L2_FIELD_SEQ_TB, /* V4L2_FIELD_INTERLACED, */ |
2019 | NULL, &dev->vbi_mode.slock, fh->type, V4L2_FIELD_SEQ_TB, /* V4L2_FIELD_INTERLACED, */ | 2044 | sizeof(struct cx231xx_buffer), fh); |
2020 | sizeof(struct cx231xx_buffer), fh); | 2045 | } |
2021 | } | ||
2022 | 2046 | ||
2023 | mutex_unlock(&dev->lock); | 2047 | mutex_unlock(&dev->lock); |
2024 | 2048 | ||
@@ -2044,7 +2068,7 @@ void cx231xx_release_analog_resources(struct cx231xx *dev) | |||
2044 | } | 2068 | } |
2045 | if (dev->vbi_dev) { | 2069 | if (dev->vbi_dev) { |
2046 | cx231xx_info("V4L2 device /dev/vbi%d deregistered\n", | 2070 | cx231xx_info("V4L2 device /dev/vbi%d deregistered\n", |
2047 | dev->vbi_dev->num); | 2071 | dev->vbi_dev->num); |
2048 | if (-1 != dev->vbi_dev->minor) | 2072 | if (-1 != dev->vbi_dev->minor) |
2049 | video_unregister_device(dev->vbi_dev); | 2073 | video_unregister_device(dev->vbi_dev); |
2050 | else | 2074 | else |
@@ -2053,7 +2077,7 @@ void cx231xx_release_analog_resources(struct cx231xx *dev) | |||
2053 | } | 2077 | } |
2054 | if (dev->vdev) { | 2078 | if (dev->vdev) { |
2055 | cx231xx_info("V4L2 device /dev/video%d deregistered\n", | 2079 | cx231xx_info("V4L2 device /dev/video%d deregistered\n", |
2056 | dev->vdev->num); | 2080 | dev->vdev->num); |
2057 | if (-1 != dev->vdev->minor) | 2081 | if (-1 != dev->vdev->minor) |
2058 | video_unregister_device(dev->vdev); | 2082 | video_unregister_device(dev->vdev); |
2059 | else | 2083 | else |
@@ -2069,44 +2093,44 @@ void cx231xx_release_analog_resources(struct cx231xx *dev) | |||
2069 | */ | 2093 | */ |
2070 | static int cx231xx_v4l2_close(struct file *filp) | 2094 | static int cx231xx_v4l2_close(struct file *filp) |
2071 | { | 2095 | { |
2072 | struct cx231xx_fh *fh = filp->private_data; | 2096 | struct cx231xx_fh *fh = filp->private_data; |
2073 | struct cx231xx *dev = fh->dev; | 2097 | struct cx231xx *dev = fh->dev; |
2074 | 2098 | ||
2075 | cx231xx_videodbg("users=%d\n", dev->users); | 2099 | cx231xx_videodbg("users=%d\n", dev->users); |
2076 | 2100 | ||
2077 | mutex_lock(&dev->lock); | 2101 | mutex_lock(&dev->lock); |
2078 | 2102 | ||
2079 | if (res_check(fh)) | 2103 | if (res_check(fh)) |
2080 | res_free(fh); | 2104 | res_free(fh); |
2081 | 2105 | ||
2082 | if (fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) { | 2106 | if (fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) { |
2083 | videobuf_stop(&fh->vb_vidq); | 2107 | videobuf_stop(&fh->vb_vidq); |
2084 | videobuf_mmap_free(&fh->vb_vidq); | 2108 | videobuf_mmap_free(&fh->vb_vidq); |
2085 | 2109 | ||
2086 | /* the device is already disconnect, | 2110 | /* the device is already disconnect, |
2087 | free the remaining resources */ | 2111 | free the remaining resources */ |
2088 | if (dev->state & DEV_DISCONNECTED) { | 2112 | if (dev->state & DEV_DISCONNECTED) { |
2089 | cx231xx_release_resources(dev); | 2113 | cx231xx_release_resources(dev); |
2090 | mutex_unlock(&dev->lock); | 2114 | mutex_unlock(&dev->lock); |
2091 | kfree(dev); | 2115 | kfree(dev); |
2092 | return 0; | 2116 | return 0; |
2093 | } | 2117 | } |
2094 | 2118 | ||
2095 | /* do this before setting alternate! */ | 2119 | /* do this before setting alternate! */ |
2096 | cx231xx_uninit_vbi_isoc(dev); | 2120 | cx231xx_uninit_vbi_isoc(dev); |
2097 | 2121 | ||
2098 | /* set alternate 0 */ | 2122 | /* set alternate 0 */ |
2099 | if( !dev->vbi_or_sliced_cc_mode) { | 2123 | if (!dev->vbi_or_sliced_cc_mode) { |
2100 | cx231xx_set_alt_setting(dev, INDEX_VANC, 0); | 2124 | cx231xx_set_alt_setting(dev, INDEX_VANC, 0); |
2101 | } else { | 2125 | } else { |
2102 | cx231xx_set_alt_setting(dev, INDEX_HANC, 0); | 2126 | cx231xx_set_alt_setting(dev, INDEX_HANC, 0); |
2103 | } | 2127 | } |
2104 | 2128 | ||
2105 | kfree(fh); | 2129 | kfree(fh); |
2106 | dev->users--; | 2130 | dev->users--; |
2107 | wake_up_interruptible_nr(&dev->open, 1); | 2131 | wake_up_interruptible_nr(&dev->open, 1); |
2108 | mutex_unlock(&dev->lock); | 2132 | mutex_unlock(&dev->lock); |
2109 | return 0; | 2133 | return 0; |
2110 | } | 2134 | } |
2111 | 2135 | ||
2112 | if (dev->users == 1) { | 2136 | if (dev->users == 1) { |
@@ -2122,8 +2146,9 @@ static int cx231xx_v4l2_close(struct file *filp) | |||
2122 | return 0; | 2146 | return 0; |
2123 | } | 2147 | } |
2124 | 2148 | ||
2125 | /* Save some power by putting tuner to sleep */ | 2149 | /* Save some power by putting tuner to sleep */ |
2126 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], TUNER_SET_STANDBY, NULL); | 2150 | cx231xx_i2c_call_clients(&dev->i2c_bus[1], TUNER_SET_STANDBY, |
2151 | NULL); | ||
2127 | 2152 | ||
2128 | /* do this before setting alternate! */ | 2153 | /* do this before setting alternate! */ |
2129 | cx231xx_uninit_isoc(dev); | 2154 | cx231xx_uninit_isoc(dev); |
@@ -2144,8 +2169,8 @@ static int cx231xx_v4l2_close(struct file *filp) | |||
2144 | * will allocate buffers when called for the first time | 2169 | * will allocate buffers when called for the first time |
2145 | */ | 2170 | */ |
2146 | static ssize_t | 2171 | static ssize_t |
2147 | cx231xx_v4l2_read(struct file *filp, char __user *buf, size_t count, | 2172 | cx231xx_v4l2_read(struct file *filp, char __user * buf, size_t count, |
2148 | loff_t *pos) | 2173 | loff_t * pos) |
2149 | { | 2174 | { |
2150 | struct cx231xx_fh *fh = filp->private_data; | 2175 | struct cx231xx_fh *fh = filp->private_data; |
2151 | struct cx231xx *dev = fh->dev; | 2176 | struct cx231xx *dev = fh->dev; |
@@ -2155,8 +2180,8 @@ cx231xx_v4l2_read(struct file *filp, char __user *buf, size_t count, | |||
2155 | if (rc < 0) | 2180 | if (rc < 0) |
2156 | return rc; | 2181 | return rc; |
2157 | 2182 | ||
2158 | if ( (fh->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) || | 2183 | if ((fh->type == V4L2_BUF_TYPE_VIDEO_CAPTURE) || |
2159 | (fh->type == V4L2_BUF_TYPE_VBI_CAPTURE) ) { | 2184 | (fh->type == V4L2_BUF_TYPE_VBI_CAPTURE)) { |
2160 | mutex_lock(&dev->lock); | 2185 | mutex_lock(&dev->lock); |
2161 | rc = res_get(fh); | 2186 | rc = res_get(fh); |
2162 | mutex_unlock(&dev->lock); | 2187 | mutex_unlock(&dev->lock); |
@@ -2165,7 +2190,7 @@ cx231xx_v4l2_read(struct file *filp, char __user *buf, size_t count, | |||
2165 | return rc; | 2190 | return rc; |
2166 | 2191 | ||
2167 | return videobuf_read_stream(&fh->vb_vidq, buf, count, pos, 0, | 2192 | return videobuf_read_stream(&fh->vb_vidq, buf, count, pos, 0, |
2168 | filp->f_flags & O_NONBLOCK); | 2193 | filp->f_flags & O_NONBLOCK); |
2169 | } | 2194 | } |
2170 | return 0; | 2195 | return 0; |
2171 | } | 2196 | } |
@@ -2191,10 +2216,10 @@ static unsigned int cx231xx_v4l2_poll(struct file *filp, poll_table * wait) | |||
2191 | if (unlikely(rc < 0)) | 2216 | if (unlikely(rc < 0)) |
2192 | return POLLERR; | 2217 | return POLLERR; |
2193 | 2218 | ||
2194 | if ( (V4L2_BUF_TYPE_VIDEO_CAPTURE == fh->type) || | 2219 | if ((V4L2_BUF_TYPE_VIDEO_CAPTURE == fh->type) || |
2195 | (V4L2_BUF_TYPE_VBI_CAPTURE == fh->type) ) | 2220 | (V4L2_BUF_TYPE_VBI_CAPTURE == fh->type)) |
2196 | return videobuf_poll_stream(filp, &fh->vb_vidq, wait); | 2221 | return videobuf_poll_stream(filp, &fh->vb_vidq, wait); |
2197 | else | 2222 | else |
2198 | return POLLERR; | 2223 | return POLLERR; |
2199 | } | 2224 | } |
2200 | 2225 | ||
@@ -2203,15 +2228,15 @@ static unsigned int cx231xx_v4l2_poll(struct file *filp, poll_table * wait) | |||
2203 | */ | 2228 | */ |
2204 | static int cx231xx_v4l2_mmap(struct file *filp, struct vm_area_struct *vma) | 2229 | static int cx231xx_v4l2_mmap(struct file *filp, struct vm_area_struct *vma) |
2205 | { | 2230 | { |
2206 | struct cx231xx_fh *fh = filp->private_data; | 2231 | struct cx231xx_fh *fh = filp->private_data; |
2207 | struct cx231xx *dev = fh->dev; | 2232 | struct cx231xx *dev = fh->dev; |
2208 | int rc; | 2233 | int rc; |
2209 | 2234 | ||
2210 | rc = check_dev(dev); | 2235 | rc = check_dev(dev); |
2211 | if (rc < 0) | 2236 | if (rc < 0) |
2212 | return rc; | 2237 | return rc; |
2213 | 2238 | ||
2214 | mutex_lock(&dev->lock); | 2239 | mutex_lock(&dev->lock); |
2215 | rc = res_get(fh); | 2240 | rc = res_get(fh); |
2216 | mutex_unlock(&dev->lock); | 2241 | mutex_unlock(&dev->lock); |
2217 | 2242 | ||
@@ -2221,114 +2246,112 @@ static int cx231xx_v4l2_mmap(struct file *filp, struct vm_area_struct *vma) | |||
2221 | rc = videobuf_mmap_mapper(&fh->vb_vidq, vma); | 2246 | rc = videobuf_mmap_mapper(&fh->vb_vidq, vma); |
2222 | 2247 | ||
2223 | cx231xx_videodbg("vma start=0x%08lx, size=%ld, ret=%d\n", | 2248 | cx231xx_videodbg("vma start=0x%08lx, size=%ld, ret=%d\n", |
2224 | (unsigned long)vma->vm_start, | 2249 | (unsigned long)vma->vm_start, |
2225 | (unsigned long)vma->vm_end-(unsigned long)vma->vm_start, | 2250 | (unsigned long)vma->vm_end - |
2226 | rc); | 2251 | (unsigned long)vma->vm_start, rc); |
2227 | 2252 | ||
2228 | return rc; | 2253 | return rc; |
2229 | } | 2254 | } |
2230 | 2255 | ||
2231 | static const struct v4l2_file_operations cx231xx_v4l_fops = { | 2256 | static const struct v4l2_file_operations cx231xx_v4l_fops = { |
2232 | .owner = THIS_MODULE, | 2257 | .owner = THIS_MODULE, |
2233 | .open = cx231xx_v4l2_open, | 2258 | .open = cx231xx_v4l2_open, |
2234 | .release = cx231xx_v4l2_close, | 2259 | .release = cx231xx_v4l2_close, |
2235 | .read = cx231xx_v4l2_read, | 2260 | .read = cx231xx_v4l2_read, |
2236 | .poll = cx231xx_v4l2_poll, | 2261 | .poll = cx231xx_v4l2_poll, |
2237 | .mmap = cx231xx_v4l2_mmap, | 2262 | .mmap = cx231xx_v4l2_mmap, |
2238 | .ioctl = video_ioctl2, | 2263 | .ioctl = video_ioctl2, |
2239 | }; | 2264 | }; |
2240 | 2265 | ||
2241 | static const struct v4l2_ioctl_ops video_ioctl_ops = { | 2266 | static const struct v4l2_ioctl_ops video_ioctl_ops = { |
2242 | .vidioc_querycap = vidioc_querycap, | 2267 | .vidioc_querycap = vidioc_querycap, |
2243 | .vidioc_enum_fmt_vid_cap = vidioc_enum_fmt_vid_cap, | 2268 | .vidioc_enum_fmt_vid_cap = vidioc_enum_fmt_vid_cap, |
2244 | .vidioc_g_fmt_vid_cap = vidioc_g_fmt_vid_cap, | 2269 | .vidioc_g_fmt_vid_cap = vidioc_g_fmt_vid_cap, |
2245 | .vidioc_try_fmt_vid_cap = vidioc_try_fmt_vid_cap, | 2270 | .vidioc_try_fmt_vid_cap = vidioc_try_fmt_vid_cap, |
2246 | .vidioc_s_fmt_vid_cap = vidioc_s_fmt_vid_cap, | 2271 | .vidioc_s_fmt_vid_cap = vidioc_s_fmt_vid_cap, |
2247 | .vidioc_g_fmt_vbi_cap = vidioc_g_fmt_vbi_cap, | 2272 | .vidioc_g_fmt_vbi_cap = vidioc_g_fmt_vbi_cap, |
2248 | .vidioc_try_fmt_vbi_cap = vidioc_try_fmt_vbi_cap, | 2273 | .vidioc_try_fmt_vbi_cap = vidioc_try_fmt_vbi_cap, |
2249 | .vidioc_s_fmt_vbi_cap = vidioc_try_fmt_vbi_cap, | 2274 | .vidioc_s_fmt_vbi_cap = vidioc_try_fmt_vbi_cap, |
2250 | .vidioc_g_audio = vidioc_g_audio, | 2275 | .vidioc_g_audio = vidioc_g_audio, |
2251 | .vidioc_s_audio = vidioc_s_audio, | 2276 | .vidioc_s_audio = vidioc_s_audio, |
2252 | .vidioc_cropcap = vidioc_cropcap, | 2277 | .vidioc_cropcap = vidioc_cropcap, |
2253 | .vidioc_g_fmt_sliced_vbi_cap = vidioc_g_fmt_sliced_vbi_cap, | 2278 | .vidioc_g_fmt_sliced_vbi_cap = vidioc_g_fmt_sliced_vbi_cap, |
2254 | .vidioc_try_fmt_sliced_vbi_cap = vidioc_try_set_sliced_vbi_cap, | 2279 | .vidioc_try_fmt_sliced_vbi_cap = vidioc_try_set_sliced_vbi_cap, |
2255 | .vidioc_reqbufs = vidioc_reqbufs, | 2280 | .vidioc_reqbufs = vidioc_reqbufs, |
2256 | .vidioc_querybuf = vidioc_querybuf, | 2281 | .vidioc_querybuf = vidioc_querybuf, |
2257 | .vidioc_qbuf = vidioc_qbuf, | 2282 | .vidioc_qbuf = vidioc_qbuf, |
2258 | .vidioc_dqbuf = vidioc_dqbuf, | 2283 | .vidioc_dqbuf = vidioc_dqbuf, |
2259 | .vidioc_s_std = vidioc_s_std, | 2284 | .vidioc_s_std = vidioc_s_std, |
2260 | .vidioc_g_std = vidioc_g_std, | 2285 | .vidioc_g_std = vidioc_g_std, |
2261 | .vidioc_enum_input = vidioc_enum_input, | 2286 | .vidioc_enum_input = vidioc_enum_input, |
2262 | .vidioc_g_input = vidioc_g_input, | 2287 | .vidioc_g_input = vidioc_g_input, |
2263 | .vidioc_s_input = vidioc_s_input, | 2288 | .vidioc_s_input = vidioc_s_input, |
2264 | .vidioc_queryctrl = vidioc_queryctrl, | 2289 | .vidioc_queryctrl = vidioc_queryctrl, |
2265 | .vidioc_g_ctrl = vidioc_g_ctrl, | 2290 | .vidioc_g_ctrl = vidioc_g_ctrl, |
2266 | .vidioc_s_ctrl = vidioc_s_ctrl, | 2291 | .vidioc_s_ctrl = vidioc_s_ctrl, |
2267 | .vidioc_streamon = vidioc_streamon, | 2292 | .vidioc_streamon = vidioc_streamon, |
2268 | .vidioc_streamoff = vidioc_streamoff, | 2293 | .vidioc_streamoff = vidioc_streamoff, |
2269 | .vidioc_g_tuner = vidioc_g_tuner, | 2294 | .vidioc_g_tuner = vidioc_g_tuner, |
2270 | .vidioc_s_tuner = vidioc_s_tuner, | 2295 | .vidioc_s_tuner = vidioc_s_tuner, |
2271 | .vidioc_g_frequency = vidioc_g_frequency, | 2296 | .vidioc_g_frequency = vidioc_g_frequency, |
2272 | .vidioc_s_frequency = vidioc_s_frequency, | 2297 | .vidioc_s_frequency = vidioc_s_frequency, |
2273 | #ifdef CONFIG_VIDEO_ADV_DEBUG | 2298 | #ifdef CONFIG_VIDEO_ADV_DEBUG |
2274 | .vidioc_g_register = vidioc_g_register, | 2299 | .vidioc_g_register = vidioc_g_register, |
2275 | .vidioc_s_register = vidioc_s_register, | 2300 | .vidioc_s_register = vidioc_s_register, |
2276 | #endif | 2301 | #endif |
2277 | #ifdef CONFIG_VIDEO_V4L1_COMPAT | 2302 | #ifdef CONFIG_VIDEO_V4L1_COMPAT |
2278 | .vidiocgmbuf = vidiocgmbuf, | 2303 | .vidiocgmbuf = vidiocgmbuf, |
2279 | #endif | 2304 | #endif |
2280 | }; | 2305 | }; |
2281 | 2306 | ||
2282 | static struct video_device cx231xx_vbi_template; | 2307 | static struct video_device cx231xx_vbi_template; |
2283 | 2308 | ||
2284 | static const struct video_device cx231xx_video_template = { | 2309 | static const struct video_device cx231xx_video_template = { |
2285 | .fops = &cx231xx_v4l_fops, | 2310 | .fops = &cx231xx_v4l_fops, |
2286 | .release = video_device_release, | 2311 | .release = video_device_release, |
2287 | .ioctl_ops = &video_ioctl_ops, | 2312 | .ioctl_ops = &video_ioctl_ops, |
2288 | .minor = -1, | 2313 | .minor = -1, |
2289 | .tvnorms = V4L2_STD_ALL, | 2314 | .tvnorms = V4L2_STD_ALL, |
2290 | .current_norm = V4L2_STD_PAL, | 2315 | .current_norm = V4L2_STD_PAL, |
2291 | }; | 2316 | }; |
2292 | 2317 | ||
2293 | static const struct v4l2_file_operations radio_fops = { | 2318 | static const struct v4l2_file_operations radio_fops = { |
2294 | .owner = THIS_MODULE, | 2319 | .owner = THIS_MODULE, |
2295 | .open = cx231xx_v4l2_open, | 2320 | .open = cx231xx_v4l2_open, |
2296 | .release = cx231xx_v4l2_close, | 2321 | .release = cx231xx_v4l2_close, |
2297 | .ioctl = video_ioctl2, | 2322 | .ioctl = video_ioctl2, |
2298 | }; | 2323 | }; |
2299 | 2324 | ||
2300 | static const struct v4l2_ioctl_ops radio_ioctl_ops = { | 2325 | static const struct v4l2_ioctl_ops radio_ioctl_ops = { |
2301 | .vidioc_querycap = radio_querycap, | 2326 | .vidioc_querycap = radio_querycap, |
2302 | .vidioc_g_tuner = radio_g_tuner, | 2327 | .vidioc_g_tuner = radio_g_tuner, |
2303 | .vidioc_enum_input = radio_enum_input, | 2328 | .vidioc_enum_input = radio_enum_input, |
2304 | .vidioc_g_audio = radio_g_audio, | 2329 | .vidioc_g_audio = radio_g_audio, |
2305 | .vidioc_s_tuner = radio_s_tuner, | 2330 | .vidioc_s_tuner = radio_s_tuner, |
2306 | .vidioc_s_audio = radio_s_audio, | 2331 | .vidioc_s_audio = radio_s_audio, |
2307 | .vidioc_s_input = radio_s_input, | 2332 | .vidioc_s_input = radio_s_input, |
2308 | .vidioc_queryctrl = radio_queryctrl, | 2333 | .vidioc_queryctrl = radio_queryctrl, |
2309 | .vidioc_g_ctrl = vidioc_g_ctrl, | 2334 | .vidioc_g_ctrl = vidioc_g_ctrl, |
2310 | .vidioc_s_ctrl = vidioc_s_ctrl, | 2335 | .vidioc_s_ctrl = vidioc_s_ctrl, |
2311 | .vidioc_g_frequency = vidioc_g_frequency, | 2336 | .vidioc_g_frequency = vidioc_g_frequency, |
2312 | .vidioc_s_frequency = vidioc_s_frequency, | 2337 | .vidioc_s_frequency = vidioc_s_frequency, |
2313 | #ifdef CONFIG_VIDEO_ADV_DEBUG | 2338 | #ifdef CONFIG_VIDEO_ADV_DEBUG |
2314 | .vidioc_g_register = vidioc_g_register, | 2339 | .vidioc_g_register = vidioc_g_register, |
2315 | .vidioc_s_register = vidioc_s_register, | 2340 | .vidioc_s_register = vidioc_s_register, |
2316 | #endif | 2341 | #endif |
2317 | }; | 2342 | }; |
2318 | 2343 | ||
2319 | static struct video_device cx231xx_radio_template = { | 2344 | static struct video_device cx231xx_radio_template = { |
2320 | .name = "cx231xx-radio", | 2345 | .name = "cx231xx-radio", |
2321 | .fops = &radio_fops, | 2346 | .fops = &radio_fops, |
2322 | .ioctl_ops = &radio_ioctl_ops, | 2347 | .ioctl_ops = &radio_ioctl_ops, |
2323 | .minor = -1, | 2348 | .minor = -1, |
2324 | }; | 2349 | }; |
2325 | 2350 | ||
2326 | /******************************** usb interface ******************************/ | 2351 | /******************************** usb interface ******************************/ |
2327 | 2352 | ||
2328 | 2353 | static struct video_device *cx231xx_vdev_init(struct cx231xx *dev, const struct video_device | |
2329 | static struct video_device *cx231xx_vdev_init(struct cx231xx *dev, | 2354 | *template, const char *type_name) |
2330 | const struct video_device *template, | ||
2331 | const char *type_name) | ||
2332 | { | 2355 | { |
2333 | struct video_device *vfd; | 2356 | struct video_device *vfd; |
2334 | 2357 | ||
@@ -2336,13 +2359,12 @@ static struct video_device *cx231xx_vdev_init(struct cx231xx *dev, | |||
2336 | if (NULL == vfd) | 2359 | if (NULL == vfd) |
2337 | return NULL; | 2360 | return NULL; |
2338 | *vfd = *template; | 2361 | *vfd = *template; |
2339 | vfd->minor = -1; | 2362 | vfd->minor = -1; |
2340 | vfd->parent = &dev->udev->dev; | 2363 | vfd->parent = &dev->udev->dev; |
2341 | vfd->release = video_device_release; | 2364 | vfd->release = video_device_release; |
2342 | vfd->debug = video_debug; | 2365 | vfd->debug = video_debug; |
2343 | 2366 | ||
2344 | snprintf(vfd->name, sizeof(vfd->name), "%s %s", | 2367 | snprintf(vfd->name, sizeof(vfd->name), "%s %s", dev->name, type_name); |
2345 | dev->name, type_name); | ||
2346 | 2368 | ||
2347 | return vfd; | 2369 | return vfd; |
2348 | } | 2370 | } |
@@ -2351,15 +2373,16 @@ int cx231xx_register_analog_devices(struct cx231xx *dev) | |||
2351 | { | 2373 | { |
2352 | int ret; | 2374 | int ret; |
2353 | 2375 | ||
2354 | cx231xx_info("%s()\n", __func__); | 2376 | cx231xx_info("%s()\n", __func__); |
2355 | 2377 | ||
2356 | cx231xx_info("%s: v4l2 driver version %d.%d.%d\n", | 2378 | cx231xx_info("%s: v4l2 driver version %d.%d.%d\n", |
2357 | dev->name, | 2379 | dev->name, |
2358 | (CX231XX_VERSION_CODE >> 16) & 0xff, | 2380 | (CX231XX_VERSION_CODE >> 16) & 0xff, |
2359 | (CX231XX_VERSION_CODE >> 8) & 0xff, CX231XX_VERSION_CODE & 0xff); | 2381 | (CX231XX_VERSION_CODE >> 8) & 0xff, |
2382 | CX231XX_VERSION_CODE & 0xff); | ||
2360 | 2383 | ||
2361 | /* set default norm */ | 2384 | /* set default norm */ |
2362 | /*dev->norm = cx231xx_video_template.current_norm;*/ | 2385 | /*dev->norm = cx231xx_video_template.current_norm; */ |
2363 | dev->width = norm_maxw(dev); | 2386 | dev->width = norm_maxw(dev); |
2364 | dev->height = norm_maxh(dev); | 2387 | dev->height = norm_maxh(dev); |
2365 | dev->interlaced = 0; | 2388 | dev->interlaced = 0; |
@@ -2375,7 +2398,7 @@ int cx231xx_register_analog_devices(struct cx231xx *dev) | |||
2375 | dev->volume = 0x1f; | 2398 | dev->volume = 0x1f; |
2376 | 2399 | ||
2377 | /* enable vbi capturing */ | 2400 | /* enable vbi capturing */ |
2378 | /* write code here... */ | 2401 | /* write code here... */ |
2379 | 2402 | ||
2380 | /* allocate and fill video video_device struct */ | 2403 | /* allocate and fill video video_device struct */ |
2381 | dev->vdev = cx231xx_vdev_init(dev, &cx231xx_video_template, "video"); | 2404 | dev->vdev = cx231xx_vdev_init(dev, &cx231xx_video_template, "video"); |
@@ -2386,37 +2409,38 @@ int cx231xx_register_analog_devices(struct cx231xx *dev) | |||
2386 | 2409 | ||
2387 | /* register v4l2 video video_device */ | 2410 | /* register v4l2 video video_device */ |
2388 | ret = video_register_device(dev->vdev, VFL_TYPE_GRABBER, | 2411 | ret = video_register_device(dev->vdev, VFL_TYPE_GRABBER, |
2389 | video_nr[dev->devno]); | 2412 | video_nr[dev->devno]); |
2390 | if (ret) { | 2413 | if (ret) { |
2391 | cx231xx_errdev("unable to register video device (error=%i).\n", ret); | 2414 | cx231xx_errdev("unable to register video device (error=%i).\n", |
2415 | ret); | ||
2392 | return ret; | 2416 | return ret; |
2393 | } | 2417 | } |
2394 | 2418 | ||
2395 | cx231xx_info("%s/0: registered device video%d [v4l2]\n", | 2419 | cx231xx_info("%s/0: registered device video%d [v4l2]\n", |
2396 | dev->name, dev->vdev->num); | 2420 | dev->name, dev->vdev->num); |
2397 | |||
2398 | /* Initialize VBI template */ | ||
2399 | memcpy( &cx231xx_vbi_template, &cx231xx_video_template, | ||
2400 | sizeof(cx231xx_vbi_template) ); | ||
2401 | strcpy(cx231xx_vbi_template.name,"cx231xx-vbi"); | ||
2402 | 2421 | ||
2422 | /* Initialize VBI template */ | ||
2423 | memcpy(&cx231xx_vbi_template, &cx231xx_video_template, | ||
2424 | sizeof(cx231xx_vbi_template)); | ||
2425 | strcpy(cx231xx_vbi_template.name, "cx231xx-vbi"); | ||
2403 | 2426 | ||
2404 | /* Allocate and fill vbi video_device struct */ | 2427 | /* Allocate and fill vbi video_device struct */ |
2405 | dev->vbi_dev = cx231xx_vdev_init(dev, &cx231xx_vbi_template, "vbi"); | 2428 | dev->vbi_dev = cx231xx_vdev_init(dev, &cx231xx_vbi_template, "vbi"); |
2406 | 2429 | ||
2407 | /* register v4l2 vbi video_device */ | 2430 | /* register v4l2 vbi video_device */ |
2408 | ret = video_register_device(dev->vbi_dev, VFL_TYPE_VBI, | 2431 | ret = video_register_device(dev->vbi_dev, VFL_TYPE_VBI, |
2409 | vbi_nr[dev->devno]); | 2432 | vbi_nr[dev->devno]); |
2410 | if (ret < 0) { | 2433 | if (ret < 0) { |
2411 | cx231xx_errdev("unable to register vbi device\n"); | 2434 | cx231xx_errdev("unable to register vbi device\n"); |
2412 | return ret; | 2435 | return ret; |
2413 | } | 2436 | } |
2414 | 2437 | ||
2415 | cx231xx_info("%s/0: registered device vbi%d\n", | 2438 | cx231xx_info("%s/0: registered device vbi%d\n", |
2416 | dev->name, dev->vbi_dev->num); | 2439 | dev->name, dev->vbi_dev->num); |
2417 | 2440 | ||
2418 | if (cx231xx_boards[dev->model].radio.type == CX231XX_RADIO) { | 2441 | if (cx231xx_boards[dev->model].radio.type == CX231XX_RADIO) { |
2419 | dev->radio_dev = cx231xx_vdev_init(dev, &cx231xx_radio_template, "radio"); | 2442 | dev->radio_dev = |
2443 | cx231xx_vdev_init(dev, &cx231xx_radio_template, "radio"); | ||
2420 | if (!dev->radio_dev) { | 2444 | if (!dev->radio_dev) { |
2421 | cx231xx_errdev("cannot allocate video_device.\n"); | 2445 | cx231xx_errdev("cannot allocate video_device.\n"); |
2422 | return -ENODEV; | 2446 | return -ENODEV; |
@@ -2428,13 +2452,11 @@ int cx231xx_register_analog_devices(struct cx231xx *dev) | |||
2428 | return ret; | 2452 | return ret; |
2429 | } | 2453 | } |
2430 | cx231xx_info("Registered radio device as /dev/radio%d\n", | 2454 | cx231xx_info("Registered radio device as /dev/radio%d\n", |
2431 | dev->radio_dev->num); | 2455 | dev->radio_dev->num); |
2432 | } | 2456 | } |
2433 | 2457 | ||
2434 | cx231xx_info("V4L2 device registered as /dev/video%d and /dev/vbi%d\n", | 2458 | cx231xx_info("V4L2 device registered as /dev/video%d and /dev/vbi%d\n", |
2435 | dev->vdev->num, dev->vbi_dev->num); | 2459 | dev->vdev->num, dev->vbi_dev->num); |
2436 | 2460 | ||
2437 | return 0; | 2461 | return 0; |
2438 | } | 2462 | } |
2439 | |||
2440 | |||
diff --git a/drivers/media/video/cx231xx/cx231xx.h b/drivers/media/video/cx231xx/cx231xx.h index 5fef87fbbcec..1f6c5be65a55 100644 --- a/drivers/media/video/cx231xx/cx231xx.h +++ b/drivers/media/video/cx231xx/cx231xx.h | |||
@@ -2,7 +2,7 @@ | |||
2 | cx231xx.h - driver for Conexant Cx23100/101/102 USB video capture devices | 2 | cx231xx.h - driver for Conexant Cx23100/101/102 USB video capture devices |
3 | 3 | ||
4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> | 4 | Copyright (C) 2008 <srinivasa.deevi at conexant dot com> |
5 | Based on em28xx driver | 5 | Based on em28xx driver |
6 | 6 | ||
7 | This program is free software; you can redistribute it and/or modify | 7 | This program is free software; you can redistribute it and/or modify |
8 | it under the terms of the GNU General Public License as published by | 8 | it under the terms of the GNU General Public License as published by |
@@ -65,7 +65,7 @@ | |||
65 | 65 | ||
66 | /* Params for validated field */ | 66 | /* Params for validated field */ |
67 | #define CX231XX_BOARD_NOT_VALIDATED 1 | 67 | #define CX231XX_BOARD_NOT_VALIDATED 1 |
68 | #define CX231XX_BOARD_VALIDATED 0 | 68 | #define CX231XX_BOARD_VALIDATED 0 |
69 | 69 | ||
70 | /* maximum number of cx231xx boards */ | 70 | /* maximum number of cx231xx boards */ |
71 | #define CX231XX_MAXBOARDS 8 | 71 | #define CX231XX_MAXBOARDS 8 |
@@ -82,17 +82,14 @@ | |||
82 | */ | 82 | */ |
83 | #define CX231XX_NUM_PACKETS 40 | 83 | #define CX231XX_NUM_PACKETS 40 |
84 | 84 | ||
85 | |||
86 | /* default alternate; 0 means choose the best */ | 85 | /* default alternate; 0 means choose the best */ |
87 | #define CX231XX_PINOUT 0 | 86 | #define CX231XX_PINOUT 0 |
88 | 87 | ||
89 | #define CX231XX_INTERLACED_DEFAULT 1 | 88 | #define CX231XX_INTERLACED_DEFAULT 1 |
90 | 89 | ||
91 | |||
92 | /* time to wait when stopping the isoc transfer */ | 90 | /* time to wait when stopping the isoc transfer */ |
93 | #define CX231XX_URB_TIMEOUT msecs_to_jiffies(CX231XX_NUM_BUFS * CX231XX_NUM_PACKETS) | 91 | #define CX231XX_URB_TIMEOUT msecs_to_jiffies(CX231XX_NUM_BUFS * CX231XX_NUM_PACKETS) |
94 | 92 | ||
95 | |||
96 | enum cx231xx_mode { | 93 | enum cx231xx_mode { |
97 | CX231XX_SUSPEND, | 94 | CX231XX_SUSPEND, |
98 | CX231XX_ANALOG_MODE, | 95 | CX231XX_ANALOG_MODE, |
@@ -113,47 +110,45 @@ enum cx231xx_stream_state { | |||
113 | struct cx231xx; | 110 | struct cx231xx; |
114 | 111 | ||
115 | struct cx231xx_usb_isoc_ctl { | 112 | struct cx231xx_usb_isoc_ctl { |
116 | /* max packet size of isoc transaction */ | 113 | /* max packet size of isoc transaction */ |
117 | int max_pkt_size; | 114 | int max_pkt_size; |
118 | 115 | ||
119 | /* number of allocated urbs */ | 116 | /* number of allocated urbs */ |
120 | int num_bufs; | 117 | int num_bufs; |
121 | 118 | ||
122 | /* urb for isoc transfers */ | 119 | /* urb for isoc transfers */ |
123 | struct urb **urb; | 120 | struct urb **urb; |
124 | 121 | ||
125 | /* transfer buffers for isoc transfer */ | 122 | /* transfer buffers for isoc transfer */ |
126 | char **transfer_buffer; | 123 | char **transfer_buffer; |
127 | 124 | ||
128 | /* Last buffer command and region */ | 125 | /* Last buffer command and region */ |
129 | u8 cmd; | 126 | u8 cmd; |
130 | int pos, size, pktsize; | 127 | int pos, size, pktsize; |
131 | 128 | ||
132 | /* Last field: ODD or EVEN? */ | 129 | /* Last field: ODD or EVEN? */ |
133 | int field; | 130 | int field; |
134 | 131 | ||
135 | /* Stores incomplete commands */ | 132 | /* Stores incomplete commands */ |
136 | u32 tmp_buf; | 133 | u32 tmp_buf; |
137 | int tmp_buf_len; | 134 | int tmp_buf_len; |
138 | 135 | ||
139 | /* Stores already requested buffers */ | 136 | /* Stores already requested buffers */ |
140 | struct cx231xx_buffer *buf; | 137 | struct cx231xx_buffer *buf; |
141 | 138 | ||
142 | /* Stores the number of received fields */ | 139 | /* Stores the number of received fields */ |
143 | int nfields; | 140 | int nfields; |
144 | 141 | ||
145 | /* isoc urb callback */ | 142 | /* isoc urb callback */ |
146 | int (*isoc_copy) (struct cx231xx *dev, struct urb *urb); | 143 | int (*isoc_copy) (struct cx231xx * dev, struct urb * urb); |
147 | 144 | ||
148 | }; | 145 | }; |
149 | 146 | ||
150 | |||
151 | |||
152 | struct cx231xx_fmt { | 147 | struct cx231xx_fmt { |
153 | char *name; | 148 | char *name; |
154 | u32 fourcc; /* v4l2 format id */ | 149 | u32 fourcc; /* v4l2 format id */ |
155 | int depth; | 150 | int depth; |
156 | int reg; | 151 | int reg; |
157 | }; | 152 | }; |
158 | 153 | ||
159 | /* buffer for one video frame */ | 154 | /* buffer for one video frame */ |
@@ -167,24 +162,23 @@ struct cx231xx_buffer { | |||
167 | }; | 162 | }; |
168 | 163 | ||
169 | struct cx231xx_dmaqueue { | 164 | struct cx231xx_dmaqueue { |
170 | struct list_head active; | 165 | struct list_head active; |
171 | struct list_head queued; | 166 | struct list_head queued; |
172 | 167 | ||
173 | wait_queue_head_t wq; | 168 | wait_queue_head_t wq; |
174 | 169 | ||
175 | /* Counters to control buffer fill */ | 170 | /* Counters to control buffer fill */ |
176 | int pos; | 171 | int pos; |
177 | u8 is_partial_line; | 172 | u8 is_partial_line; |
178 | u8 partial_buf[8]; | 173 | u8 partial_buf[8]; |
179 | u8 last_sav; | 174 | u8 last_sav; |
180 | int current_field; | 175 | int current_field; |
181 | u32 bytes_left_in_line; | 176 | u32 bytes_left_in_line; |
182 | u32 lines_completed; | 177 | u32 lines_completed; |
183 | u8 field1_done; | 178 | u8 field1_done; |
184 | u32 lines_per_field; | 179 | u32 lines_per_field; |
185 | }; | 180 | }; |
186 | 181 | ||
187 | |||
188 | /* inputs */ | 182 | /* inputs */ |
189 | 183 | ||
190 | #define MAX_CX231XX_INPUT 4 | 184 | #define MAX_CX231XX_INPUT 4 |
@@ -193,35 +187,35 @@ enum cx231xx_itype { | |||
193 | CX231XX_VMUX_COMPOSITE1 = 1, | 187 | CX231XX_VMUX_COMPOSITE1 = 1, |
194 | CX231XX_VMUX_SVIDEO, | 188 | CX231XX_VMUX_SVIDEO, |
195 | CX231XX_VMUX_TELEVISION, | 189 | CX231XX_VMUX_TELEVISION, |
196 | CX231XX_VMUX_CABLE, | 190 | CX231XX_VMUX_CABLE, |
197 | CX231XX_RADIO, | 191 | CX231XX_RADIO, |
198 | CX231XX_VMUX_DVB, | 192 | CX231XX_VMUX_DVB, |
199 | CX231XX_VMUX_DEBUG | 193 | CX231XX_VMUX_DEBUG |
200 | }; | 194 | }; |
201 | 195 | ||
202 | enum cx231xx_v_input { | 196 | enum cx231xx_v_input { |
203 | CX231XX_VIN_1_1 = 0x1, | 197 | CX231XX_VIN_1_1 = 0x1, |
204 | CX231XX_VIN_2_1, | 198 | CX231XX_VIN_2_1, |
205 | CX231XX_VIN_3_1, | 199 | CX231XX_VIN_3_1, |
206 | CX231XX_VIN_4_1, | 200 | CX231XX_VIN_4_1, |
207 | CX231XX_VIN_1_2 = 0x01, | 201 | CX231XX_VIN_1_2 = 0x01, |
208 | CX231XX_VIN_2_2, | 202 | CX231XX_VIN_2_2, |
209 | CX231XX_VIN_3_2, | 203 | CX231XX_VIN_3_2, |
210 | CX231XX_VIN_1_3 = 0x1, | 204 | CX231XX_VIN_1_3 = 0x1, |
211 | CX231XX_VIN_2_3, | 205 | CX231XX_VIN_2_3, |
212 | CX231XX_VIN_3_3, | 206 | CX231XX_VIN_3_3, |
213 | }; | 207 | }; |
214 | 208 | ||
215 | /* cx231xx has two audio inputs: tuner and line in */ | 209 | /* cx231xx has two audio inputs: tuner and line in */ |
216 | enum cx231xx_amux { | 210 | enum cx231xx_amux { |
217 | /* This is the only entry for cx231xx tuner input */ | 211 | /* This is the only entry for cx231xx tuner input */ |
218 | CX231XX_AMUX_VIDEO, /* cx231xx tuner*/ | 212 | CX231XX_AMUX_VIDEO, /* cx231xx tuner */ |
219 | CX231XX_AMUX_LINE_IN, /* Line In */ | 213 | CX231XX_AMUX_LINE_IN, /* Line In */ |
220 | }; | 214 | }; |
221 | 215 | ||
222 | struct cx231xx_reg_seq { | 216 | struct cx231xx_reg_seq { |
223 | unsigned char bit; | 217 | unsigned char bit; |
224 | unsigned char val; | 218 | unsigned char val; |
225 | int sleep; | 219 | int sleep; |
226 | }; | 220 | }; |
227 | 221 | ||
@@ -239,41 +233,40 @@ enum cx231xx_decoder { | |||
239 | CX231XX_AVDECODER | 233 | CX231XX_AVDECODER |
240 | }; | 234 | }; |
241 | 235 | ||
242 | typedef enum _I2C_MASTER_PORT | 236 | typedef enum _I2C_MASTER_PORT { |
243 | { | 237 | I2C_0 = 0, |
244 | I2C_0 =0, | 238 | I2C_1 = 1, |
245 | I2C_1 =1, | 239 | I2C_2 = 2, |
246 | I2C_2 =2, | 240 | I2C_3 = 3 |
247 | I2C_3 =3 | 241 | } CX231XX_I2C_MASTER_PORT; |
248 | }CX231XX_I2C_MASTER_PORT; | ||
249 | 242 | ||
250 | struct cx231xx_board { | 243 | struct cx231xx_board { |
251 | char *name; | 244 | char *name; |
252 | int vchannels; | 245 | int vchannels; |
253 | int tuner_type; | 246 | int tuner_type; |
254 | int tuner_addr; | 247 | int tuner_addr; |
255 | v4l2_std_id norm; /* tv norm */ | 248 | v4l2_std_id norm; /* tv norm */ |
256 | 249 | ||
257 | /* demod related */ | 250 | /* demod related */ |
258 | int demod_addr; | 251 | int demod_addr; |
259 | u8 demod_xfer_mode; /* 0 - Serial; 1 - parallel */ | 252 | u8 demod_xfer_mode; /* 0 - Serial; 1 - parallel */ |
260 | 253 | ||
261 | /* GPIO Pins */ | 254 | /* GPIO Pins */ |
262 | struct cx231xx_reg_seq *dvb_gpio; | 255 | struct cx231xx_reg_seq *dvb_gpio; |
263 | struct cx231xx_reg_seq *suspend_gpio; | 256 | struct cx231xx_reg_seq *suspend_gpio; |
264 | struct cx231xx_reg_seq *tuner_gpio; | 257 | struct cx231xx_reg_seq *tuner_gpio; |
265 | u8 tuner_sif_gpio; | 258 | u8 tuner_sif_gpio; |
266 | u8 tuner_scl_gpio; | 259 | u8 tuner_scl_gpio; |
267 | u8 tuner_sda_gpio; | 260 | u8 tuner_sda_gpio; |
268 | 261 | ||
269 | /* PIN ctrl */ | 262 | /* PIN ctrl */ |
270 | u32 ctl_pin_status_mask; | 263 | u32 ctl_pin_status_mask; |
271 | u8 agc_analog_digital_select_gpio; | 264 | u8 agc_analog_digital_select_gpio; |
272 | u32 gpio_pin_status_mask; | 265 | u32 gpio_pin_status_mask; |
273 | 266 | ||
274 | /* i2c masters */ | 267 | /* i2c masters */ |
275 | u8 tuner_i2c_master; | 268 | u8 tuner_i2c_master; |
276 | u8 demod_i2c_master; | 269 | u8 demod_i2c_master; |
277 | 270 | ||
278 | unsigned int max_range_640_480:1; | 271 | unsigned int max_range_640_480:1; |
279 | unsigned int has_dvb:1; | 272 | unsigned int has_dvb:1; |
@@ -283,9 +276,9 @@ struct cx231xx_board { | |||
283 | 276 | ||
284 | enum cx231xx_decoder decoder; | 277 | enum cx231xx_decoder decoder; |
285 | 278 | ||
286 | struct cx231xx_input input[MAX_CX231XX_INPUT]; | 279 | struct cx231xx_input input[MAX_CX231XX_INPUT]; |
287 | struct cx231xx_input radio; | 280 | struct cx231xx_input radio; |
288 | IR_KEYTAB_TYPE *ir_codes; | 281 | IR_KEYTAB_TYPE *ir_codes; |
289 | }; | 282 | }; |
290 | 283 | ||
291 | /* device states */ | 284 | /* device states */ |
@@ -295,22 +288,20 @@ enum cx231xx_dev_state { | |||
295 | DEV_MISCONFIGURED = 0x04, | 288 | DEV_MISCONFIGURED = 0x04, |
296 | }; | 289 | }; |
297 | 290 | ||
298 | enum AFE_MODE | 291 | enum AFE_MODE { |
299 | { | 292 | AFE_MODE_LOW_IF, |
300 | AFE_MODE_LOW_IF, | 293 | AFE_MODE_BASEBAND, |
301 | AFE_MODE_BASEBAND, | 294 | AFE_MODE_EU_HI_IF, |
302 | AFE_MODE_EU_HI_IF, | 295 | AFE_MODE_US_HI_IF, |
303 | AFE_MODE_US_HI_IF, | 296 | AFE_MODE_JAPAN_HI_IF |
304 | AFE_MODE_JAPAN_HI_IF | ||
305 | }; | 297 | }; |
306 | 298 | ||
307 | enum AUDIO_INPUT | 299 | enum AUDIO_INPUT { |
308 | { | 300 | AUDIO_INPUT_MUTE, |
309 | AUDIO_INPUT_MUTE, | 301 | AUDIO_INPUT_LINE, |
310 | AUDIO_INPUT_LINE, | 302 | AUDIO_INPUT_TUNER_TV, |
311 | AUDIO_INPUT_TUNER_TV, | 303 | AUDIO_INPUT_SPDIF, |
312 | AUDIO_INPUT_SPDIF, | 304 | AUDIO_INPUT_TUNER_FM |
313 | AUDIO_INPUT_TUNER_FM | ||
314 | }; | 305 | }; |
315 | 306 | ||
316 | #define CX231XX_AUDIO_BUFS 5 | 307 | #define CX231XX_AUDIO_BUFS 5 |
@@ -319,7 +310,6 @@ enum AUDIO_INPUT | |||
319 | #define CX231XX_STOP_AUDIO 0 | 310 | #define CX231XX_STOP_AUDIO 0 |
320 | #define CX231XX_START_AUDIO 1 | 311 | #define CX231XX_START_AUDIO 1 |
321 | 312 | ||
322 | |||
323 | /* cx231xx extensions */ | 313 | /* cx231xx extensions */ |
324 | #define CX231XX_AUDIO 0x10 | 314 | #define CX231XX_AUDIO 0x10 |
325 | #define CX231XX_DVB 0x20 | 315 | #define CX231XX_DVB 0x20 |
@@ -330,169 +320,167 @@ struct cx231xx_audio { | |||
330 | struct urb *urb[CX231XX_AUDIO_BUFS]; | 320 | struct urb *urb[CX231XX_AUDIO_BUFS]; |
331 | struct usb_device *udev; | 321 | struct usb_device *udev; |
332 | unsigned int capture_transfer_done; | 322 | unsigned int capture_transfer_done; |
333 | struct snd_pcm_substream *capture_pcm_substream; | 323 | struct snd_pcm_substream *capture_pcm_substream; |
334 | 324 | ||
335 | unsigned int hwptr_done_capture; | 325 | unsigned int hwptr_done_capture; |
336 | struct snd_card *sndcard; | 326 | struct snd_card *sndcard; |
337 | 327 | ||
338 | int users, shutdown; | 328 | int users, shutdown; |
339 | enum cx231xx_stream_state capture_stream; | 329 | enum cx231xx_stream_state capture_stream; |
340 | spinlock_t slock; | 330 | spinlock_t slock; |
341 | 331 | ||
342 | int alt; /* alternate */ | 332 | int alt; /* alternate */ |
343 | int max_pkt_size; /* max packet size of isoc transaction */ | 333 | int max_pkt_size; /* max packet size of isoc transaction */ |
344 | int num_alt; /* Number of alternative settings */ | 334 | int num_alt; /* Number of alternative settings */ |
345 | unsigned int *alt_max_pkt_size; /* array of wMaxPacketSize */ | 335 | unsigned int *alt_max_pkt_size; /* array of wMaxPacketSize */ |
346 | u16 end_point_addr; | 336 | u16 end_point_addr; |
347 | }; | 337 | }; |
348 | 338 | ||
349 | struct cx231xx; | 339 | struct cx231xx; |
350 | 340 | ||
351 | struct cx231xx_fh { | 341 | struct cx231xx_fh { |
352 | struct cx231xx *dev; | 342 | struct cx231xx *dev; |
353 | unsigned int stream_on:1; /* Locks streams */ | 343 | unsigned int stream_on:1; /* Locks streams */ |
354 | int radio; | 344 | int radio; |
355 | 345 | ||
356 | struct videobuf_queue vb_vidq; | 346 | struct videobuf_queue vb_vidq; |
357 | 347 | ||
358 | enum v4l2_buf_type type; | 348 | enum v4l2_buf_type type; |
359 | }; | 349 | }; |
360 | 350 | ||
361 | /**********************************************************************************/ | 351 | /**********************************************************************************/ |
362 | /* set/get i2c */ | 352 | /* set/get i2c */ |
363 | #define I2C_SPEED_1M 0x0 /* 00--1Mb/s, 01-400kb/s, 10--100kb/s, 11--5Mb/s */ | 353 | #define I2C_SPEED_1M 0x0 /* 00--1Mb/s, 01-400kb/s, 10--100kb/s, 11--5Mb/s */ |
364 | #define I2C_SPEED_400K 0x1 /* 00--1Mb/s, 01-400kb/s, 10--100kb/s, 11--5Mb/s */ | 354 | #define I2C_SPEED_400K 0x1 /* 00--1Mb/s, 01-400kb/s, 10--100kb/s, 11--5Mb/s */ |
365 | #define I2C_SPEED_100K 0x2 /* 00--1Mb/s, 01-400kb/s, 10--100kb/s, 11--5Mb/s */ | 355 | #define I2C_SPEED_100K 0x2 /* 00--1Mb/s, 01-400kb/s, 10--100kb/s, 11--5Mb/s */ |
366 | #define I2C_SPEED_5M 0x3 /* 00--1Mb/s, 01-400kb/s, 10--100kb/s, 11--5Mb/s */ | 356 | #define I2C_SPEED_5M 0x3 /* 00--1Mb/s, 01-400kb/s, 10--100kb/s, 11--5Mb/s */ |
367 | 357 | ||
368 | #define I2C_STOP 0x0 /* 0-- STOP transaction */ | 358 | #define I2C_STOP 0x0 /* 0-- STOP transaction */ |
369 | #define I2C_NOSTOP 0x1 /* 1-- do not transmit STOP at end of transaction */ | 359 | #define I2C_NOSTOP 0x1 /* 1-- do not transmit STOP at end of transaction */ |
370 | #define I2C_SYNC 0x1 /* 1--alllow slave to insert clock wait states */ | 360 | #define I2C_SYNC 0x1 /* 1--alllow slave to insert clock wait states */ |
371 | 361 | ||
372 | struct cx231xx_i2c { | 362 | struct cx231xx_i2c { |
373 | struct cx231xx *dev; | 363 | struct cx231xx *dev; |
374 | 364 | ||
375 | int nr; | 365 | int nr; |
376 | 366 | ||
377 | /* i2c i/o */ | 367 | /* i2c i/o */ |
378 | struct i2c_adapter i2c_adap; | 368 | struct i2c_adapter i2c_adap; |
379 | struct i2c_algo_bit_data i2c_algo; | 369 | struct i2c_algo_bit_data i2c_algo; |
380 | struct i2c_client i2c_client; | 370 | struct i2c_client i2c_client; |
381 | u32 i2c_rc; | 371 | u32 i2c_rc; |
382 | 372 | ||
383 | /* different settings for each bus */ | 373 | /* different settings for each bus */ |
384 | u8 i2c_period; | 374 | u8 i2c_period; |
385 | u8 i2c_nostop; | 375 | u8 i2c_nostop; |
386 | u8 i2c_reserve; | 376 | u8 i2c_reserve; |
387 | }; | 377 | }; |
388 | 378 | ||
389 | struct cx231xx_i2c_xfer_data{ | 379 | struct cx231xx_i2c_xfer_data { |
390 | u8 dev_addr; | 380 | u8 dev_addr; |
391 | u8 direction; /* 1 - IN, 0 - OUT */ | 381 | u8 direction; /* 1 - IN, 0 - OUT */ |
392 | u8 saddr_len; /* sub address len */ | 382 | u8 saddr_len; /* sub address len */ |
393 | u16 saddr_dat; /* sub addr data */ | 383 | u16 saddr_dat; /* sub addr data */ |
394 | u8 buf_size; /* buffer size */ | 384 | u8 buf_size; /* buffer size */ |
395 | u8* p_buffer; /* pointer to the buffer */ | 385 | u8 *p_buffer; /* pointer to the buffer */ |
396 | }; | 386 | }; |
397 | 387 | ||
398 | typedef struct _VENDOR_REQUEST_IN | 388 | typedef struct _VENDOR_REQUEST_IN { |
399 | { | 389 | u8 bRequest; |
400 | u8 bRequest; | 390 | u16 wValue; |
401 | u16 wValue; | 391 | u16 wIndex; |
402 | u16 wIndex; | 392 | u16 wLength; |
403 | u16 wLength; | 393 | u8 direction; |
404 | u8 direction; | 394 | u8 bData; |
405 | u8 bData; | 395 | u8 *pBuff; |
406 | u8 *pBuff; | ||
407 | } VENDOR_REQUEST_IN, *PVENDOR_REQUEST_IN; | 396 | } VENDOR_REQUEST_IN, *PVENDOR_REQUEST_IN; |
408 | 397 | ||
409 | struct cx231xx_ctrl { | 398 | struct cx231xx_ctrl { |
410 | struct v4l2_queryctrl v; | 399 | struct v4l2_queryctrl v; |
411 | u32 off; | 400 | u32 off; |
412 | u32 reg; | 401 | u32 reg; |
413 | u32 mask; | 402 | u32 mask; |
414 | u32 shift; | 403 | u32 shift; |
415 | }; | 404 | }; |
416 | 405 | ||
417 | typedef enum{ | 406 | typedef enum { |
418 | Raw_Video = 0, | 407 | Raw_Video = 0, |
419 | Audio, | 408 | Audio, |
420 | Vbi, /* VANC */ | 409 | Vbi, /* VANC */ |
421 | Sliced_cc, /* HANC */ | 410 | Sliced_cc, /* HANC */ |
422 | TS1_serial_mode, | 411 | TS1_serial_mode, |
423 | TS2, | 412 | TS2, |
424 | TS1_parallel_mode | 413 | TS1_parallel_mode |
425 | }TRANSFER_TYPE; | 414 | } TRANSFER_TYPE; |
426 | 415 | ||
427 | struct cx231xx_video_mode { | 416 | struct cx231xx_video_mode { |
428 | /* Isoc control struct */ | 417 | /* Isoc control struct */ |
429 | struct cx231xx_dmaqueue vidq; | 418 | struct cx231xx_dmaqueue vidq; |
430 | struct cx231xx_usb_isoc_ctl isoc_ctl; | 419 | struct cx231xx_usb_isoc_ctl isoc_ctl; |
431 | spinlock_t slock; | 420 | spinlock_t slock; |
432 | 421 | ||
433 | /* usb transfer */ | 422 | /* usb transfer */ |
434 | int alt; /* alternate */ | 423 | int alt; /* alternate */ |
435 | int max_pkt_size; /* max packet size of isoc transaction */ | 424 | int max_pkt_size; /* max packet size of isoc transaction */ |
436 | int num_alt; /* Number of alternative settings */ | 425 | int num_alt; /* Number of alternative settings */ |
437 | unsigned int *alt_max_pkt_size; /* array of wMaxPacketSize */ | 426 | unsigned int *alt_max_pkt_size; /* array of wMaxPacketSize */ |
438 | u16 end_point_addr; | 427 | u16 end_point_addr; |
439 | }; | 428 | }; |
440 | 429 | ||
441 | |||
442 | /* main device struct */ | 430 | /* main device struct */ |
443 | struct cx231xx { | 431 | struct cx231xx { |
444 | /* generic device properties */ | 432 | /* generic device properties */ |
445 | char name[30]; /* name (including minor) of the device */ | 433 | char name[30]; /* name (including minor) of the device */ |
446 | int model; /* index in the device_data struct */ | 434 | int model; /* index in the device_data struct */ |
447 | int devno; /* marks the number of this device */ | 435 | int devno; /* marks the number of this device */ |
448 | 436 | ||
449 | struct cx231xx_board board; | 437 | struct cx231xx_board board; |
450 | 438 | ||
451 | unsigned int stream_on:1; /* Locks streams */ | 439 | unsigned int stream_on:1; /* Locks streams */ |
452 | unsigned int vbi_stream_on:1; /* Locks streams for VBI */ | 440 | unsigned int vbi_stream_on:1; /* Locks streams for VBI */ |
453 | unsigned int has_audio_class:1; | 441 | unsigned int has_audio_class:1; |
454 | unsigned int has_alsa_audio:1; | 442 | unsigned int has_alsa_audio:1; |
455 | 443 | ||
456 | struct cx231xx_fmt *format; | 444 | struct cx231xx_fmt *format; |
457 | 445 | ||
458 | struct cx231xx_IR *ir; | 446 | struct cx231xx_IR *ir; |
459 | 447 | ||
460 | struct list_head devlist; | 448 | struct list_head devlist; |
461 | 449 | ||
462 | int tuner_type; /* type of the tuner */ | 450 | int tuner_type; /* type of the tuner */ |
463 | int tuner_addr; /* tuner address */ | 451 | int tuner_addr; /* tuner address */ |
464 | 452 | ||
465 | /* I2C adapters: Master 1 & 2 (External) & Master 3 (Internal only) */ | 453 | /* I2C adapters: Master 1 & 2 (External) & Master 3 (Internal only) */ |
466 | struct cx231xx_i2c i2c_bus[3]; | 454 | struct cx231xx_i2c i2c_bus[3]; |
467 | unsigned int xc_fw_load_done:1; | 455 | unsigned int xc_fw_load_done:1; |
468 | struct mutex gpio_i2c_lock; | 456 | struct mutex gpio_i2c_lock; |
469 | 457 | ||
470 | /* video for linux */ | 458 | /* video for linux */ |
471 | int users; /* user count for exclusive use */ | 459 | int users; /* user count for exclusive use */ |
472 | struct video_device *vdev; /* video for linux device struct */ | 460 | struct video_device *vdev; /* video for linux device struct */ |
473 | v4l2_std_id norm; /* selected tv norm */ | 461 | v4l2_std_id norm; /* selected tv norm */ |
474 | int ctl_freq; /* selected frequency */ | 462 | int ctl_freq; /* selected frequency */ |
475 | unsigned int ctl_ainput; /* selected audio input */ | 463 | unsigned int ctl_ainput; /* selected audio input */ |
476 | int mute; | 464 | int mute; |
477 | int volume; | 465 | int volume; |
478 | 466 | ||
479 | /* frame properties */ | 467 | /* frame properties */ |
480 | int width; /* current frame width */ | 468 | int width; /* current frame width */ |
481 | int height; /* current frame height */ | 469 | int height; /* current frame height */ |
482 | unsigned hscale; /* horizontal scale factor (see datasheet) */ | 470 | unsigned hscale; /* horizontal scale factor (see datasheet) */ |
483 | unsigned vscale; /* vertical scale factor (see datasheet) */ | 471 | unsigned vscale; /* vertical scale factor (see datasheet) */ |
484 | int interlaced; /* 1=interlace fileds, 0=just top fileds */ | 472 | int interlaced; /* 1=interlace fileds, 0=just top fileds */ |
485 | 473 | ||
486 | struct cx231xx_audio adev; | 474 | struct cx231xx_audio adev; |
487 | 475 | ||
488 | /* states */ | 476 | /* states */ |
489 | enum cx231xx_dev_state state; | 477 | enum cx231xx_dev_state state; |
490 | 478 | ||
491 | struct work_struct request_module_wk; | 479 | struct work_struct request_module_wk; |
492 | 480 | ||
493 | /* locks */ | 481 | /* locks */ |
494 | struct mutex lock; | 482 | struct mutex lock; |
495 | struct mutex ctrl_urb_lock; /* protects urb_buf */ | 483 | struct mutex ctrl_urb_lock; /* protects urb_buf */ |
496 | struct list_head inqueue, outqueue; | 484 | struct list_head inqueue, outqueue; |
497 | wait_queue_head_t open, wait_frame, wait_stream; | 485 | wait_queue_head_t open, wait_frame, wait_stream; |
498 | struct video_device *vbi_dev; | 486 | struct video_device *vbi_dev; |
@@ -500,54 +488,56 @@ struct cx231xx { | |||
500 | 488 | ||
501 | unsigned char eedata[256]; | 489 | unsigned char eedata[256]; |
502 | 490 | ||
503 | struct cx231xx_video_mode video_mode; | 491 | struct cx231xx_video_mode video_mode; |
504 | struct cx231xx_video_mode vbi_mode; | 492 | struct cx231xx_video_mode vbi_mode; |
505 | struct cx231xx_video_mode sliced_cc_mode; | 493 | struct cx231xx_video_mode sliced_cc_mode; |
506 | struct cx231xx_video_mode ts1_mode; | 494 | struct cx231xx_video_mode ts1_mode; |
507 | |||
508 | struct usb_device *udev; /* the usb device */ | ||
509 | char urb_buf[URB_MAX_CTRL_SIZE];/* urb control msg buffer */ | ||
510 | 495 | ||
496 | struct usb_device *udev; /* the usb device */ | ||
497 | char urb_buf[URB_MAX_CTRL_SIZE]; /* urb control msg buffer */ | ||
511 | 498 | ||
512 | /* helper funcs that call usb_control_msg */ | 499 | /* helper funcs that call usb_control_msg */ |
513 | int (*cx231xx_read_ctrl_reg) (struct cx231xx *dev, u8 req, u16 reg, | 500 | int (*cx231xx_read_ctrl_reg) (struct cx231xx * dev, u8 req, u16 reg, |
514 | char *buf, int len); | ||
515 | int (*cx231xx_write_ctrl_reg)(struct cx231xx *dev, u8 req, u16 reg, | ||
516 | char *buf, int len); | 501 | char *buf, int len); |
517 | int (*cx231xx_send_usb_command)(struct cx231xx_i2c *i2c_bus, | 502 | int (*cx231xx_write_ctrl_reg) (struct cx231xx * dev, u8 req, u16 reg, |
518 | struct cx231xx_i2c_xfer_data *req_data); | 503 | char *buf, int len); |
519 | int (*cx231xx_gpio_i2c_read)(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len); | 504 | int (*cx231xx_send_usb_command) (struct cx231xx_i2c * i2c_bus, |
520 | int (*cx231xx_gpio_i2c_write)(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len); | 505 | struct cx231xx_i2c_xfer_data * |
521 | 506 | req_data); | |
522 | int (*cx231xx_set_analog_freq)(struct cx231xx *dev, u32 freq ) ; | 507 | int (*cx231xx_gpio_i2c_read) (struct cx231xx * dev, u8 dev_addr, |
523 | int (*cx231xx_reset_analog_tuner)(struct cx231xx *dev) ; | 508 | u8 * buf, u8 len); |
509 | int (*cx231xx_gpio_i2c_write) (struct cx231xx * dev, u8 dev_addr, | ||
510 | u8 * buf, u8 len); | ||
511 | |||
512 | int (*cx231xx_set_analog_freq) (struct cx231xx * dev, u32 freq); | ||
513 | int (*cx231xx_reset_analog_tuner) (struct cx231xx * dev); | ||
524 | 514 | ||
525 | enum cx231xx_mode mode; | 515 | enum cx231xx_mode mode; |
526 | 516 | ||
527 | struct cx231xx_dvb *dvb; | 517 | struct cx231xx_dvb *dvb; |
528 | 518 | ||
529 | /* Cx231xx supported PCB config's */ | 519 | /* Cx231xx supported PCB config's */ |
530 | struct pcb_config current_pcb_config; | 520 | struct pcb_config current_pcb_config; |
531 | u8 current_scenario_idx; | 521 | u8 current_scenario_idx; |
532 | u8 interface_count; | 522 | u8 interface_count; |
533 | u8 max_iad_interface_count; | 523 | u8 max_iad_interface_count; |
534 | 524 | ||
535 | /* GPIO related register direction and values */ | 525 | /* GPIO related register direction and values */ |
536 | u32 gpio_dir; | 526 | u32 gpio_dir; |
537 | u32 gpio_val; | 527 | u32 gpio_val; |
538 | 528 | ||
539 | /* Power Modes */ | 529 | /* Power Modes */ |
540 | int power_mode; | 530 | int power_mode; |
541 | 531 | ||
542 | /* colibri parameters */ | 532 | /* colibri parameters */ |
543 | enum AFE_MODE colibri_mode; | 533 | enum AFE_MODE colibri_mode; |
544 | u32 colibri_ref_count; | 534 | u32 colibri_ref_count; |
545 | 535 | ||
546 | /* video related parameters */ | 536 | /* video related parameters */ |
547 | u32 video_input; | 537 | u32 video_input; |
548 | u32 active_mode; | 538 | u32 active_mode; |
549 | u8 vbi_or_sliced_cc_mode; /* 0 - vbi ; 1 - sliced cc mode */ | 539 | u8 vbi_or_sliced_cc_mode; /* 0 - vbi ; 1 - sliced cc mode */ |
550 | enum cx231xx_std_mode std_mode; /* 0 - Air; 1 - cable */ | 540 | enum cx231xx_std_mode std_mode; /* 0 - Air; 1 - cable */ |
551 | 541 | ||
552 | }; | 542 | }; |
553 | 543 | ||
@@ -555,29 +545,31 @@ struct cx231xx_ops { | |||
555 | struct list_head next; | 545 | struct list_head next; |
556 | char *name; | 546 | char *name; |
557 | int id; | 547 | int id; |
558 | int (*init)(struct cx231xx *); | 548 | int (*init) (struct cx231xx *); |
559 | int (*fini)(struct cx231xx *); | 549 | int (*fini) (struct cx231xx *); |
560 | }; | 550 | }; |
561 | 551 | ||
562 | /* call back functions in dvb module */ | 552 | /* call back functions in dvb module */ |
563 | int cx231xx_set_analog_freq(struct cx231xx *dev, u32 freq ) ; | 553 | int cx231xx_set_analog_freq(struct cx231xx *dev, u32 freq); |
564 | int cx231xx_reset_analog_tuner(struct cx231xx *dev) ; | 554 | int cx231xx_reset_analog_tuner(struct cx231xx *dev); |
565 | 555 | ||
566 | /* Provided by cx231xx-i2c.c */ | 556 | /* Provided by cx231xx-i2c.c */ |
567 | void cx231xx_i2c_call_clients(struct cx231xx_i2c *bus, unsigned int cmd, void *arg); | 557 | void cx231xx_i2c_call_clients(struct cx231xx_i2c *bus, unsigned int cmd, |
558 | void *arg); | ||
568 | void cx231xx_do_i2c_scan(struct cx231xx *dev, struct i2c_client *c); | 559 | void cx231xx_do_i2c_scan(struct cx231xx *dev, struct i2c_client *c); |
569 | int cx231xx_i2c_register(struct cx231xx_i2c *bus); | 560 | int cx231xx_i2c_register(struct cx231xx_i2c *bus); |
570 | int cx231xx_i2c_unregister(struct cx231xx_i2c *bus); | 561 | int cx231xx_i2c_unregister(struct cx231xx_i2c *bus); |
571 | 562 | ||
572 | /* Internal block control functions */ | 563 | /* Internal block control functions */ |
573 | int cx231xx_read_i2c_data(struct cx231xx *dev, u8 dev_addr, | 564 | int cx231xx_read_i2c_data(struct cx231xx *dev, u8 dev_addr, |
574 | u16 saddr, u8 saddr_len, u32 *data, u8 data_len); | 565 | u16 saddr, u8 saddr_len, u32 * data, u8 data_len); |
575 | int cx231xx_write_i2c_data(struct cx231xx *dev, u8 dev_addr, | 566 | int cx231xx_write_i2c_data(struct cx231xx *dev, u8 dev_addr, |
576 | u16 saddr, u8 saddr_len, u32 data, u8 data_len); | 567 | u16 saddr, u8 saddr_len, u32 data, u8 data_len); |
577 | int cx231xx_reg_mask_write(struct cx231xx *dev, u8 dev_addr, u8 size, u16 register_address, | 568 | int cx231xx_reg_mask_write(struct cx231xx *dev, u8 dev_addr, u8 size, |
578 | u8 bit_start,u8 bit_end, u32 value); | 569 | u16 register_address, u8 bit_start, u8 bit_end, |
570 | u32 value); | ||
579 | int cx231xx_read_modify_write_i2c_dword(struct cx231xx *dev, u8 dev_addr, | 571 | int cx231xx_read_modify_write_i2c_dword(struct cx231xx *dev, u8 dev_addr, |
580 | u16 saddr, u32 mask, u32 value); | 572 | u16 saddr, u32 mask, u32 value); |
581 | u32 cx231xx_set_field(u32 field_mask, u32 data); | 573 | u32 cx231xx_set_field(u32 field_mask, u32 data); |
582 | 574 | ||
583 | /* Colibri related functions */ | 575 | /* Colibri related functions */ |
@@ -596,23 +588,26 @@ int cx231xx_flatiron_set_audio_input(struct cx231xx *dev, u8 audio_input); | |||
596 | 588 | ||
597 | /* DIF related functions */ | 589 | /* DIF related functions */ |
598 | int cx231xx_dif_configure_C2HH_for_low_IF(struct cx231xx *dev, u32 mode, | 590 | int cx231xx_dif_configure_C2HH_for_low_IF(struct cx231xx *dev, u32 mode, |
599 | u32 function_mode, u32 standard); | 591 | u32 function_mode, u32 standard); |
600 | int cx231xx_dif_set_standard(struct cx231xx *dev, u32 standard); | 592 | int cx231xx_dif_set_standard(struct cx231xx *dev, u32 standard); |
601 | int cx231xx_tuner_pre_channel_change(struct cx231xx *dev); | 593 | int cx231xx_tuner_pre_channel_change(struct cx231xx *dev); |
602 | int cx231xx_tuner_post_channel_change(struct cx231xx *dev); | 594 | int cx231xx_tuner_post_channel_change(struct cx231xx *dev); |
603 | 595 | ||
604 | /* video parser functions */ | 596 | /* video parser functions */ |
605 | u8 cx231xx_find_next_SAV_EAV(u8 *p_buffer, u32 buffer_size, u32 *p_bytes_used); | 597 | u8 cx231xx_find_next_SAV_EAV(u8 * p_buffer, u32 buffer_size, |
606 | u8 cx231xx_find_boundary_SAV_EAV(u8 *p_buffer, u8 *partial_buf, u32 *p_bytes_used); | 598 | u32 * p_bytes_used); |
599 | u8 cx231xx_find_boundary_SAV_EAV(u8 * p_buffer, u8 * partial_buf, | ||
600 | u32 * p_bytes_used); | ||
607 | int cx231xx_do_copy(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 601 | int cx231xx_do_copy(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
608 | u8 *p_buffer, u32 bytes_to_copy); | 602 | u8 * p_buffer, u32 bytes_to_copy); |
609 | void cx231xx_reset_video_buffer(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q); | 603 | void cx231xx_reset_video_buffer(struct cx231xx *dev, |
610 | u8 cx231xx_is_buffer_done(struct cx231xx *dev,struct cx231xx_dmaqueue *dma_q); | 604 | struct cx231xx_dmaqueue *dma_q); |
611 | u32 cx231xx_copy_video_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 605 | u8 cx231xx_is_buffer_done(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q); |
612 | u8 *p_line, u32 length, int field_number); | 606 | u32 cx231xx_copy_video_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
613 | u32 cx231xx_get_video_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, | 607 | u8 * p_line, u32 length, int field_number); |
614 | u8 sav_eav, u8 *p_buffer, u32 buffer_size); | 608 | u32 cx231xx_get_video_line(struct cx231xx *dev, struct cx231xx_dmaqueue *dma_q, |
615 | void cx231xx_swab(u16 *from, u16 *to, u16 len); | 609 | u8 sav_eav, u8 * p_buffer, u32 buffer_size); |
610 | void cx231xx_swab(u16 * from, u16 * to, u16 len); | ||
616 | 611 | ||
617 | /* Provided by cx231xx-core.c */ | 612 | /* Provided by cx231xx-core.c */ |
618 | 613 | ||
@@ -622,46 +617,49 @@ void cx231xx_release_buffers(struct cx231xx *dev); | |||
622 | 617 | ||
623 | /* read from control pipe */ | 618 | /* read from control pipe */ |
624 | int cx231xx_read_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, | 619 | int cx231xx_read_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, |
625 | char *buf, int len); | 620 | char *buf, int len); |
626 | 621 | ||
627 | /* write to control pipe */ | 622 | /* write to control pipe */ |
628 | int cx231xx_write_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, | 623 | int cx231xx_write_ctrl_reg(struct cx231xx *dev, u8 req, u16 reg, |
629 | char *buf, int len); | 624 | char *buf, int len); |
630 | int cx231xx_mode_register(struct cx231xx *dev, u16 address, u32 mode); | 625 | int cx231xx_mode_register(struct cx231xx *dev, u16 address, u32 mode); |
631 | 626 | ||
632 | int cx231xx_send_vendor_cmd(struct cx231xx *dev, VENDOR_REQUEST_IN *ven_req); | 627 | int cx231xx_send_vendor_cmd(struct cx231xx *dev, VENDOR_REQUEST_IN * ven_req); |
633 | int cx231xx_send_usb_command(struct cx231xx_i2c *i2c_bus, | 628 | int cx231xx_send_usb_command(struct cx231xx_i2c *i2c_bus, |
634 | struct cx231xx_i2c_xfer_data *req_data); | 629 | struct cx231xx_i2c_xfer_data *req_data); |
635 | 630 | ||
636 | /* Gpio related functions */ | 631 | /* Gpio related functions */ |
637 | int cx231xx_send_gpio_cmd(struct cx231xx *dev, u32 gpio_bit, u8* gpio_val, | 632 | int cx231xx_send_gpio_cmd(struct cx231xx *dev, u32 gpio_bit, u8 * gpio_val, |
638 | u8 len, u8 request, u8 direction); | 633 | u8 len, u8 request, u8 direction); |
639 | int cx231xx_set_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8* gpio_val); | 634 | int cx231xx_set_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8 * gpio_val); |
640 | int cx231xx_get_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8* gpio_val); | 635 | int cx231xx_get_gpio_bit(struct cx231xx *dev, u32 gpio_bit, u8 * gpio_val); |
641 | int cx231xx_set_gpio_value(struct cx231xx *dev, int pin_number, int pin_value); | 636 | int cx231xx_set_gpio_value(struct cx231xx *dev, int pin_number, int pin_value); |
642 | int cx231xx_set_gpio_direction(struct cx231xx *dev, int pin_number, int pin_value); | 637 | int cx231xx_set_gpio_direction(struct cx231xx *dev, int pin_number, |
638 | int pin_value); | ||
643 | 639 | ||
644 | int cx231xx_gpio_i2c_start(struct cx231xx *dev); | 640 | int cx231xx_gpio_i2c_start(struct cx231xx *dev); |
645 | int cx231xx_gpio_i2c_end(struct cx231xx *dev); | 641 | int cx231xx_gpio_i2c_end(struct cx231xx *dev); |
646 | int cx231xx_gpio_i2c_write_byte(struct cx231xx *dev, u8 data); | 642 | int cx231xx_gpio_i2c_write_byte(struct cx231xx *dev, u8 data); |
647 | int cx231xx_gpio_i2c_read_byte(struct cx231xx *dev, u8 *buf); | 643 | int cx231xx_gpio_i2c_read_byte(struct cx231xx *dev, u8 * buf); |
648 | int cx231xx_gpio_i2c_read_ack(struct cx231xx *dev); | 644 | int cx231xx_gpio_i2c_read_ack(struct cx231xx *dev); |
649 | int cx231xx_gpio_i2c_write_ack(struct cx231xx *dev); | 645 | int cx231xx_gpio_i2c_write_ack(struct cx231xx *dev); |
650 | int cx231xx_gpio_i2c_write_nak(struct cx231xx *dev); | 646 | int cx231xx_gpio_i2c_write_nak(struct cx231xx *dev); |
651 | 647 | ||
652 | int cx231xx_gpio_i2c_read(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len); | 648 | int cx231xx_gpio_i2c_read(struct cx231xx *dev, u8 dev_addr, u8 * buf, u8 len); |
653 | int cx231xx_gpio_i2c_write(struct cx231xx *dev, u8 dev_addr, u8 *buf ,u8 len); | 649 | int cx231xx_gpio_i2c_write(struct cx231xx *dev, u8 dev_addr, u8 * buf, u8 len); |
654 | 650 | ||
655 | /* audio related functions */ | 651 | /* audio related functions */ |
656 | int cx231xx_set_audio_decoder_input(struct cx231xx *dev, enum AUDIO_INPUT audio_input); | 652 | int cx231xx_set_audio_decoder_input(struct cx231xx *dev, |
653 | enum AUDIO_INPUT audio_input); | ||
657 | 654 | ||
658 | int cx231xx_capture_start(struct cx231xx *dev, int start, u8 media_type); | 655 | int cx231xx_capture_start(struct cx231xx *dev, int start, u8 media_type); |
659 | int cx231xx_resolution_set(struct cx231xx *dev); | 656 | int cx231xx_resolution_set(struct cx231xx *dev); |
660 | int cx231xx_set_video_alternate(struct cx231xx *dev); | 657 | int cx231xx_set_video_alternate(struct cx231xx *dev); |
661 | int cx231xx_set_alt_setting(struct cx231xx *dev, u8 index, u8 alt); | 658 | int cx231xx_set_alt_setting(struct cx231xx *dev, u8 index, u8 alt); |
662 | int cx231xx_init_isoc(struct cx231xx *dev, int max_packets, | 659 | int cx231xx_init_isoc(struct cx231xx *dev, int max_packets, |
663 | int num_bufs, int max_pkt_size, | 660 | int num_bufs, int max_pkt_size, |
664 | int (*isoc_copy) (struct cx231xx *dev, struct urb *urb)); | 661 | int (*isoc_copy) (struct cx231xx * dev, |
662 | struct urb * urb)); | ||
665 | void cx231xx_uninit_isoc(struct cx231xx *dev); | 663 | void cx231xx_uninit_isoc(struct cx231xx *dev); |
666 | int cx231xx_set_mode(struct cx231xx *dev, enum cx231xx_mode set_mode); | 664 | int cx231xx_set_mode(struct cx231xx *dev, enum cx231xx_mode set_mode); |
667 | int cx231xx_gpio_set(struct cx231xx *dev, struct cx231xx_reg_seq *gpio); | 665 | int cx231xx_gpio_set(struct cx231xx *dev, struct cx231xx_reg_seq *gpio); |
@@ -673,7 +671,7 @@ int cx231xx_register_analog_devices(struct cx231xx *dev); | |||
673 | void cx231xx_remove_from_devlist(struct cx231xx *dev); | 671 | void cx231xx_remove_from_devlist(struct cx231xx *dev); |
674 | void cx231xx_add_into_devlist(struct cx231xx *dev); | 672 | void cx231xx_add_into_devlist(struct cx231xx *dev); |
675 | struct cx231xx *cx231xx_get_device(int minor, | 673 | struct cx231xx *cx231xx_get_device(int minor, |
676 | enum v4l2_buf_type *fh_type, int *has_radio); | 674 | enum v4l2_buf_type *fh_type, int *has_radio); |
677 | void cx231xx_init_extension(struct cx231xx *dev); | 675 | void cx231xx_init_extension(struct cx231xx *dev); |
678 | void cx231xx_close_extension(struct cx231xx *dev); | 676 | void cx231xx_close_extension(struct cx231xx *dev); |
679 | 677 | ||
@@ -695,7 +693,8 @@ int cx231xx_power_suspend(struct cx231xx *dev); | |||
695 | 693 | ||
696 | /* chip specific control functions */ | 694 | /* chip specific control functions */ |
697 | int cx231xx_init_ctrl_pin_status(struct cx231xx *dev); | 695 | int cx231xx_init_ctrl_pin_status(struct cx231xx *dev); |
698 | int cx231xx_set_agc_analog_digital_mux_select(struct cx231xx *dev, u8 analog_or_digital); | 696 | int cx231xx_set_agc_analog_digital_mux_select(struct cx231xx *dev, |
697 | u8 analog_or_digital); | ||
699 | int cx231xx_enable_i2c_for_tuner(struct cx231xx *dev, u8 I2CIndex); | 698 | int cx231xx_enable_i2c_for_tuner(struct cx231xx *dev, u8 I2CIndex); |
700 | 699 | ||
701 | /* video audio decoder related functions */ | 700 | /* video audio decoder related functions */ |
@@ -705,8 +704,8 @@ int cx231xx_set_decoder_video_input(struct cx231xx *dev, u8 pin_type, u8 input); | |||
705 | int cx231xx_do_mode_ctrl_overrides(struct cx231xx *dev); | 704 | int cx231xx_do_mode_ctrl_overrides(struct cx231xx *dev); |
706 | int cx231xx_set_audio_input(struct cx231xx *dev, u8 input); | 705 | int cx231xx_set_audio_input(struct cx231xx *dev, u8 input); |
707 | void get_scale(struct cx231xx *dev, | 706 | void get_scale(struct cx231xx *dev, |
708 | unsigned int width, unsigned int height, | 707 | unsigned int width, unsigned int height, |
709 | unsigned int *hscale, unsigned int *vscale); | 708 | unsigned int *hscale, unsigned int *vscale); |
710 | 709 | ||
711 | /* Provided by cx231xx-video.c */ | 710 | /* Provided by cx231xx-video.c */ |
712 | int cx231xx_register_extension(struct cx231xx_ops *dev); | 711 | int cx231xx_register_extension(struct cx231xx_ops *dev); |
@@ -743,7 +742,6 @@ int cx231xx_ir_fini(struct cx231xx *dev); | |||
743 | printk(KERN_WARNING "%s: "fmt,\ | 742 | printk(KERN_WARNING "%s: "fmt,\ |
744 | dev->name , ##arg); } while (0) | 743 | dev->name , ##arg); } while (0) |
745 | 744 | ||
746 | |||
747 | static inline unsigned int norm_maxw(struct cx231xx *dev) | 745 | static inline unsigned int norm_maxw(struct cx231xx *dev) |
748 | { | 746 | { |
749 | if (dev->board.max_range_640_480) | 747 | if (dev->board.max_range_640_480) |