aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/cx18/cx18-driver.c
diff options
context:
space:
mode:
authorAndy Walls <awalls@radix.net>2008-11-15 23:38:19 -0500
committerMauro Carvalho Chehab <mchehab@redhat.com>2008-12-30 06:38:07 -0500
commitee2d64f5ccc71b5c5191e92ea91a12b65f9ca060 (patch)
tree0f01253a1e517f9c1f705901d873ca25bb2c872f /drivers/media/video/cx18/cx18-driver.c
parentba38ee8ebe4a42ce2213802152b0b86a95dc109f (diff)
V4L/DVB (9720): cx18: Major rewrite of interrupt handling for incoming mailbox processing
A major rewrite of interrupt handling for incoming mailbox processing, to split the timing critical steps from the the deferrable steps as the sending XPU on the CX23418 will time out and overwrite our incoming mailboxes rather quickly. Setup a pool of work "order forms" for the irq handler to send jobs to the new work handler routine which uses the kernel default work queue to do the deferrable work. Started optimizing some of the cx18-io calls as they are now the low hanging fruit for recoving microseconds back from the timeline. Future optimizations will get rid of mmio read retries, mmio stats logging, and combine smaller functions in the irq path into the larger ones to save ~2 us each. Signed-off-by: Andy Walls <awalls@radix.net> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/cx18/cx18-driver.c')
-rw-r--r--drivers/media/video/cx18/cx18-driver.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/media/video/cx18/cx18-driver.c b/drivers/media/video/cx18/cx18-driver.c
index 8ef11d578b8d..434cc7fdee36 100644
--- a/drivers/media/video/cx18/cx18-driver.c
+++ b/drivers/media/video/cx18/cx18-driver.c
@@ -440,6 +440,8 @@ done:
440 */ 440 */
441static int __devinit cx18_init_struct1(struct cx18 *cx) 441static int __devinit cx18_init_struct1(struct cx18 *cx)
442{ 442{
443 int i;
444
443 cx->base_addr = pci_resource_start(cx->dev, 0); 445 cx->base_addr = pci_resource_start(cx->dev, 0);
444 446
445 mutex_init(&cx->serialize_lock); 447 mutex_init(&cx->serialize_lock);
@@ -451,7 +453,11 @@ static int __devinit cx18_init_struct1(struct cx18 *cx)
451 453
452 spin_lock_init(&cx->lock); 454 spin_lock_init(&cx->lock);
453 455
454 INIT_WORK(&cx->work, cx18_work_handler); 456 for (i = 0; i < CX18_MAX_EPU_WORK_ORDERS; i++) {
457 cx->epu_work_order[i].cx = cx;
458 cx->epu_work_order[i].str = cx->epu_debug_str;
459 INIT_WORK(&cx->epu_work_order[i].work, cx18_epu_work_handler);
460 }
455 461
456 /* start counting open_id at 1 */ 462 /* start counting open_id at 1 */
457 cx->open_id = 1; 463 cx->open_id = 1;