Commit ad689d54 authored by Andy Walls's avatar Andy Walls Committed by Mauro Carvalho Chehab

V4L/DVB (13433): cx18: Remove duplicate list traversal when processing incoming MDLs

Update the incoming MDL's buffers' bytesused and sync the buffers for the cpu
in one pass instead of two.
Signed-off-by: default avatarAndy Walls <awalls@radix.net>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 127ce5f0
...@@ -100,8 +100,8 @@ struct cx18_mdl *cx18_dequeue(struct cx18_stream *s, struct cx18_queue *q) ...@@ -100,8 +100,8 @@ struct cx18_mdl *cx18_dequeue(struct cx18_stream *s, struct cx18_queue *q)
return mdl; return mdl;
} }
static void _cx18_mdl_set_buf_bytesused(struct cx18_stream *s, static void _cx18_mdl_update_bufs_for_cpu(struct cx18_stream *s,
struct cx18_mdl *mdl) struct cx18_mdl *mdl)
{ {
struct cx18_buffer *buf; struct cx18_buffer *buf;
u32 buf_size = s->buf_size; u32 buf_size = s->buf_size;
...@@ -116,11 +116,12 @@ static void _cx18_mdl_set_buf_bytesused(struct cx18_stream *s, ...@@ -116,11 +116,12 @@ static void _cx18_mdl_set_buf_bytesused(struct cx18_stream *s,
buf->bytesused = bytesused; buf->bytesused = bytesused;
bytesused = 0; bytesused = 0;
} }
cx18_buf_sync_for_cpu(s, buf);
} }
} }
static inline void cx18_mdl_set_buf_bytesused(struct cx18_stream *s, static inline void cx18_mdl_update_bufs_for_cpu(struct cx18_stream *s,
struct cx18_mdl *mdl) struct cx18_mdl *mdl)
{ {
struct cx18_buffer *buf; struct cx18_buffer *buf;
...@@ -129,8 +130,9 @@ static inline void cx18_mdl_set_buf_bytesused(struct cx18_stream *s, ...@@ -129,8 +130,9 @@ static inline void cx18_mdl_set_buf_bytesused(struct cx18_stream *s,
list); list);
buf->bytesused = mdl->bytesused; buf->bytesused = mdl->bytesused;
buf->readpos = 0; buf->readpos = 0;
cx18_buf_sync_for_cpu(s, buf);
} else { } else {
_cx18_mdl_set_buf_bytesused(s, mdl); _cx18_mdl_update_bufs_for_cpu(s, mdl);
} }
} }
...@@ -191,8 +193,7 @@ struct cx18_mdl *cx18_queue_get_mdl(struct cx18_stream *s, u32 id, ...@@ -191,8 +193,7 @@ struct cx18_mdl *cx18_queue_get_mdl(struct cx18_stream *s, u32 id,
ret->bytesused = bytesused; ret->bytesused = bytesused;
ret->skipped = 0; ret->skipped = 0;
/* 0'ed readpos, m_flags & curr_buf when mdl went on q_busy */ /* 0'ed readpos, m_flags & curr_buf when mdl went on q_busy */
cx18_mdl_set_buf_bytesused(s, ret); cx18_mdl_update_bufs_for_cpu(s, ret);
cx18_mdl_sync_for_cpu(s, ret);
if (s->type != CX18_ENC_STREAM_TYPE_TS) if (s->type != CX18_ENC_STREAM_TYPE_TS)
set_bit(CX18_F_M_NEED_SWAP, &ret->m_flags); set_bit(CX18_F_M_NEED_SWAP, &ret->m_flags);
} }
...@@ -331,18 +332,6 @@ void cx18_load_queues(struct cx18_stream *s) ...@@ -331,18 +332,6 @@ void cx18_load_queues(struct cx18_stream *s)
} }
} }
void _cx18_mdl_sync_for_cpu(struct cx18_stream *s, struct cx18_mdl *mdl)
{
int dma = s->dma;
u32 buf_size = s->buf_size;
struct pci_dev *pci_dev = s->cx->pci_dev;
struct cx18_buffer *buf;
list_for_each_entry(buf, &mdl->buf_list, list)
pci_dma_sync_single_for_cpu(pci_dev, buf->dma_handle,
buf_size, dma);
}
void _cx18_mdl_sync_for_device(struct cx18_stream *s, struct cx18_mdl *mdl) void _cx18_mdl_sync_for_device(struct cx18_stream *s, struct cx18_mdl *mdl)
{ {
int dma = s->dma; int dma = s->dma;
......
...@@ -33,19 +33,6 @@ static inline void cx18_buf_sync_for_cpu(struct cx18_stream *s, ...@@ -33,19 +33,6 @@ static inline void cx18_buf_sync_for_cpu(struct cx18_stream *s,
s->buf_size, s->dma); s->buf_size, s->dma);
} }
void _cx18_mdl_sync_for_cpu(struct cx18_stream *s, struct cx18_mdl *mdl);
static inline void cx18_mdl_sync_for_cpu(struct cx18_stream *s,
struct cx18_mdl *mdl)
{
if (list_is_singular(&mdl->buf_list))
cx18_buf_sync_for_cpu(s, list_first_entry(&mdl->buf_list,
struct cx18_buffer,
list));
else
_cx18_mdl_sync_for_cpu(s, mdl);
}
static inline void cx18_buf_sync_for_device(struct cx18_stream *s, static inline void cx18_buf_sync_for_device(struct cx18_stream *s,
struct cx18_buffer *buf) struct cx18_buffer *buf)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment