Commit a1c592b7 authored by Steven Toth's avatar Steven Toth Committed by Mauro Carvalho Chehab

[media] saa7164: saa7164-buffer.c line 274 bugfix

Mark buffers free when the dvb dma engine stops.
Signed-off-by: default avatarSteven Toth <stoth@kernellabs.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 2e732d64
...@@ -143,6 +143,8 @@ static int saa7164_dvb_pause_port(struct saa7164_port *port) ...@@ -143,6 +143,8 @@ static int saa7164_dvb_pause_port(struct saa7164_port *port)
static int saa7164_dvb_stop_streaming(struct saa7164_port *port) static int saa7164_dvb_stop_streaming(struct saa7164_port *port)
{ {
struct saa7164_dev *dev = port->dev; struct saa7164_dev *dev = port->dev;
struct saa7164_buffer *buf;
struct list_head *p, *q;
int ret; int ret;
dprintk(DBGLVL_DVB, "%s(port=%d)\n", __func__, port->nr); dprintk(DBGLVL_DVB, "%s(port=%d)\n", __func__, port->nr);
...@@ -151,6 +153,14 @@ static int saa7164_dvb_stop_streaming(struct saa7164_port *port) ...@@ -151,6 +153,14 @@ static int saa7164_dvb_stop_streaming(struct saa7164_port *port)
ret = saa7164_dvb_acquire_port(port); ret = saa7164_dvb_acquire_port(port);
ret = saa7164_dvb_stop_port(port); ret = saa7164_dvb_stop_port(port);
/* Mark the hardware buffers as free */
mutex_lock(&port->dmaqueue_lock);
list_for_each_safe(p, q, &port->dmaqueue.list) {
buf = list_entry(p, struct saa7164_buffer, list);
buf->flags = SAA7164_BUFFER_FREE;
}
mutex_unlock(&port->dmaqueue_lock);
return ret; return ret;
} }
......
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