diff options
author | Andy Walls <awalls@radix.net> | 2008-11-15 23:38:19 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2008-12-30 06:38:07 -0500 |
commit | ee2d64f5ccc71b5c5191e92ea91a12b65f9ca060 (patch) | |
tree | 0f01253a1e517f9c1f705901d873ca25bb2c872f /drivers/media/video/cx18/cx18-dvb.c | |
parent | ba38ee8ebe4a42ce2213802152b0b86a95dc109f (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-dvb.c')
-rw-r--r-- | drivers/media/video/cx18/cx18-dvb.c | 25 |
1 files changed, 0 insertions, 25 deletions
diff --git a/drivers/media/video/cx18/cx18-dvb.c b/drivers/media/video/cx18/cx18-dvb.c index 4845f732ef48..b74253b1377e 100644 --- a/drivers/media/video/cx18/cx18-dvb.c +++ b/drivers/media/video/cx18/cx18-dvb.c | |||
@@ -23,8 +23,6 @@ | |||
23 | #include "cx18-dvb.h" | 23 | #include "cx18-dvb.h" |
24 | #include "cx18-io.h" | 24 | #include "cx18-io.h" |
25 | #include "cx18-streams.h" | 25 | #include "cx18-streams.h" |
26 | #include "cx18-queue.h" | ||
27 | #include "cx18-scb.h" | ||
28 | #include "cx18-cards.h" | 26 | #include "cx18-cards.h" |
29 | #include "s5h1409.h" | 27 | #include "s5h1409.h" |
30 | #include "mxl5005s.h" | 28 | #include "mxl5005s.h" |
@@ -305,26 +303,3 @@ static int dvb_register(struct cx18_stream *stream) | |||
305 | 303 | ||
306 | return ret; | 304 | return ret; |
307 | } | 305 | } |
308 | |||
309 | void cx18_dvb_work_handler(struct cx18 *cx) | ||
310 | { | ||
311 | struct cx18_buffer *buf; | ||
312 | struct cx18_stream *s = &cx->streams[CX18_ENC_STREAM_TYPE_TS]; | ||
313 | |||
314 | while ((buf = cx18_dequeue(s, &s->q_full)) != NULL) { | ||
315 | if (s->dvb.enabled) | ||
316 | dvb_dmx_swfilter(&s->dvb.demux, buf->buf, | ||
317 | buf->bytesused); | ||
318 | |||
319 | cx18_buf_sync_for_device(s, buf); | ||
320 | cx18_enqueue(s, buf, &s->q_free); | ||
321 | |||
322 | if (s->handle == CX18_INVALID_TASK_HANDLE || | ||
323 | !test_bit(CX18_F_S_STREAMING, &s->s_flags)) | ||
324 | continue; | ||
325 | |||
326 | cx18_vapi(cx, CX18_CPU_DE_SET_MDL, 5, s->handle, | ||
327 | (void __iomem *)&cx->scb->cpu_mdl[buf->id] - cx->enc_mem, | ||
328 | 1, buf->id, s->buf_size); | ||
329 | } | ||
330 | } | ||