mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-23 00:36:51 +00:00
sys/dvb/gstdvbsrc.*: Force PAT to always be in the filter.
Original commit message from CVS: 2006-11-07 Zaheer Abbas Merali <zaheerabbas at merali dot org> * sys/dvb/gstdvbsrc.c: (read_device), (gst_dvbsrc_create), (gst_dvbsrc_output_frontend_stats), (gst_dvbsrc_tune), (gst_dvbsrc_set_pes_filter): * sys/dvb/gstdvbsrc.h: Force PAT to always be in the filter. Try to continue reading after failing 10 times.
This commit is contained in:
parent
de0a7a01a1
commit
303b9278c7
3 changed files with 50 additions and 22 deletions
|
@ -1,3 +1,12 @@
|
||||||
|
2006-11-07 Zaheer Abbas Merali <zaheerabbas at merali dot org>
|
||||||
|
|
||||||
|
* sys/dvb/gstdvbsrc.c: (read_device), (gst_dvbsrc_create),
|
||||||
|
(gst_dvbsrc_output_frontend_stats), (gst_dvbsrc_tune),
|
||||||
|
(gst_dvbsrc_set_pes_filter):
|
||||||
|
* sys/dvb/gstdvbsrc.h:
|
||||||
|
Force PAT to always be in the filter.
|
||||||
|
Try to continue reading after failing 10 times.
|
||||||
|
|
||||||
2006-11-04 Thomas Vander Stichele <thomas at apestaart dot org>
|
2006-11-04 Thomas Vander Stichele <thomas at apestaart dot org>
|
||||||
|
|
||||||
* po/POTFILES.in:
|
* po/POTFILES.in:
|
||||||
|
|
|
@ -73,7 +73,7 @@ static GstElementDetails dvbsrc_details = {
|
||||||
* </para>
|
* </para>
|
||||||
* <para>
|
* <para>
|
||||||
* <programlisting>
|
* <programlisting>
|
||||||
* gst-launch dvbsrc modulation="QAM 64" trans-mode=8k bandwidth=8MHz freq=514000000 code-rate-lp=AUTO code-rate-hp=2/3 guard=4 hierarchy=0 pids=256:257 ! flutsdemux crc-check=false name=demux es-pids=256:257 ! queue max-size-buffers=0 max-size-time=0 ! flumpeg2vdec ! xvimagesink sync=false demux. ! queue max-size-buffers=0 max-size-time=0 ! flump3dec ! alsasink sync=false
|
* gst-launch dvbsrc modulation="QAM 64" trans-mode=8k bandwidth=8 freq=514000000 code-rate-lp=AUTO code-rate-hp=2/3 guard=4 hierarchy=0 pids=256:257 ! flutsdemux crc-check=false name=demux es-pids=256:257 ! queue max-size-buffers=0 max-size-time=0 ! flumpeg2vdec ! xvimagesink sync=false demux. ! queue max-size-buffers=0 max-size-time=0 ! flump3dec ! alsasink sync=false
|
||||||
* </programlisting>
|
* </programlisting>
|
||||||
* This pipeline captures a partial transport stream from dvb card 0 that is a DVB-T card for a program at tuned frequency 514000000 and pids of 256:257 with other parameters as seen in the pipeline and outputs the program with the pids 256 and 257. The reason the sinks have to be set to
|
* This pipeline captures a partial transport stream from dvb card 0 that is a DVB-T card for a program at tuned frequency 514000000 and pids of 256:257 with other parameters as seen in the pipeline and outputs the program with the pids 256 and 257. The reason the sinks have to be set to
|
||||||
* have sync=false is due to bug #340482.
|
* have sync=false is due to bug #340482.
|
||||||
|
@ -773,7 +773,7 @@ read_device (int fd, const char *fd_name, int size)
|
||||||
int count = 0;
|
int count = 0;
|
||||||
struct pollfd pfd[1];
|
struct pollfd pfd[1];
|
||||||
int ret_val = 0;
|
int ret_val = 0;
|
||||||
int attempts = 0;
|
guint attempts = 0;
|
||||||
const int TIMEOUT = 100;
|
const int TIMEOUT = 100;
|
||||||
|
|
||||||
GstBuffer *buf = gst_buffer_new_and_alloc (size);
|
GstBuffer *buf = gst_buffer_new_and_alloc (size);
|
||||||
|
@ -797,12 +797,11 @@ read_device (int fd, const char *fd_name, int size)
|
||||||
if (tmp < 0) {
|
if (tmp < 0) {
|
||||||
GST_WARNING ("Unable to read from device: %s (%d)", fd_name, errno);
|
GST_WARNING ("Unable to read from device: %s (%d)", fd_name, errno);
|
||||||
attempts += 1;
|
attempts += 1;
|
||||||
if (attempts == MAX_ATTEMPTS) {
|
if (attempts % 10 == 0) {
|
||||||
GST_WARNING
|
GST_WARNING
|
||||||
("Unable to read from device after too many attempts: %s",
|
("Unable to read from device after %u attempts: %s",
|
||||||
fd_name);
|
attempts, fd_name);
|
||||||
|
gst_dvbsrc_output_frontend_stats (src);
|
||||||
goto fail;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else
|
} else
|
||||||
|
@ -814,9 +813,10 @@ read_device (int fd, const char *fd_name, int size)
|
||||||
attempts += 1;
|
attempts += 1;
|
||||||
GST_INFO ("Reading from device %s timedout (%d)", fd_name, attempts);
|
GST_INFO ("Reading from device %s timedout (%d)", fd_name, attempts);
|
||||||
|
|
||||||
if (attempts == MAX_ATTEMPTS) {
|
if (attempts % 10 == 0) {
|
||||||
GST_WARNING ("Unable to read from device: %s (%d)", fd_name, errno);
|
GST_WARNING ("Unable to read after %u attempts from device: %s (%d)",
|
||||||
goto fail;
|
attempts, fd_name, errno);
|
||||||
|
gst_dvbsrc_output_frontend_stats (src);
|
||||||
}
|
}
|
||||||
} else if (errno == -EINTR) { // poll interrupted
|
} else if (errno == -EINTR) { // poll interrupted
|
||||||
;
|
;
|
||||||
|
@ -826,13 +826,6 @@ read_device (int fd, const char *fd_name, int size)
|
||||||
|
|
||||||
GST_BUFFER_SIZE (buf) = count;
|
GST_BUFFER_SIZE (buf) = count;
|
||||||
GST_BUFFER_TIMESTAMP (buf) = GST_CLOCK_TIME_NONE;
|
GST_BUFFER_TIMESTAMP (buf) = GST_CLOCK_TIME_NONE;
|
||||||
goto end;
|
|
||||||
|
|
||||||
fail:
|
|
||||||
gst_buffer_unref (buf);
|
|
||||||
buf = NULL;
|
|
||||||
|
|
||||||
end:
|
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -846,8 +839,10 @@ gst_dvbsrc_create (GstPushSrc * element, GstBuffer ** buf)
|
||||||
GstDvbSrc *object = NULL;
|
GstDvbSrc *object = NULL;
|
||||||
|
|
||||||
g_return_val_if_fail (GST_IS_DVBSRC (element), GST_FLOW_ERROR);
|
g_return_val_if_fail (GST_IS_DVBSRC (element), GST_FLOW_ERROR);
|
||||||
g_return_val_if_fail (buf != NULL, GST_FLOW_ERROR);
|
|
||||||
object = GST_DVBSRC (element);
|
object = GST_DVBSRC (element);
|
||||||
|
GST_LOG ("buf: 0x%x fd_dvr: %d", buf, object->fd_dvr);
|
||||||
|
|
||||||
|
g_return_val_if_fail (buf != NULL, GST_FLOW_ERROR);
|
||||||
//g_object_get(G_OBJECT(object), "blocksize", &buffer_size, NULL);
|
//g_object_get(G_OBJECT(object), "blocksize", &buffer_size, NULL);
|
||||||
buffer_size = DEFAULT_BUFFER_SIZE;
|
buffer_size = DEFAULT_BUFFER_SIZE;
|
||||||
|
|
||||||
|
@ -1187,7 +1182,7 @@ gst_dvbsrc_set_pes_filter (GstDvbSrc * object)
|
||||||
|
|
||||||
for (i = 0; i < MAX_FILTERS; i++) {
|
for (i = 0; i < MAX_FILTERS; i++) {
|
||||||
if (object->pids[i] == 0)
|
if (object->pids[i] == 0)
|
||||||
continue;
|
break;
|
||||||
|
|
||||||
fd = &object->fd_filters[i];
|
fd = &object->fd_filters[i];
|
||||||
pid = object->pids[i];
|
pid = object->pids[i];
|
||||||
|
@ -1209,7 +1204,32 @@ gst_dvbsrc_set_pes_filter (GstDvbSrc * object)
|
||||||
pes_filter.pid, pes_filter.pes_type);
|
pes_filter.pid, pes_filter.pes_type);
|
||||||
|
|
||||||
if (ioctl (*fd, DMX_SET_PES_FILTER, &pes_filter) < 0)
|
if (ioctl (*fd, DMX_SET_PES_FILTER, &pes_filter) < 0)
|
||||||
g_warning ("Error setting PES filter on %s: %s", object->demux_dev,
|
GST_WARNING_OBJECT (object, "Error setting PES filter on %s: %s",
|
||||||
strerror (errno));
|
object->demux_dev, strerror (errno));
|
||||||
}
|
}
|
||||||
|
/* always have PAT in the filter if we haven't used all our filter slots */
|
||||||
|
if (object->pids[0] != 8192 && i < MAX_FILTERS) {
|
||||||
|
/* pid 8192 means get whole ts */
|
||||||
|
pes_filter.pid = 0;
|
||||||
|
pes_filter.input = DMX_IN_FRONTEND;
|
||||||
|
pes_filter.output = DMX_OUT_TS_TAP;
|
||||||
|
pes_filter.pes_type = DMX_PES_OTHER;
|
||||||
|
pes_filter.flags = DMX_IMMEDIATE_START;
|
||||||
|
|
||||||
|
fd = &object->fd_filters[i];
|
||||||
|
close (*fd);
|
||||||
|
if ((*fd = open (object->demux_dev, O_RDWR)) < 0) {
|
||||||
|
GST_WARNING_OBJECT ("Error opening demuxer: %s (%s)",
|
||||||
|
strerror (errno), object->demux_dev);
|
||||||
|
} else {
|
||||||
|
GST_INFO_OBJECT (object, "Setting pes-filter, pid = %d, type = %d",
|
||||||
|
pes_filter.pid, pes_filter.pes_type);
|
||||||
|
|
||||||
|
if (ioctl (*fd, DMX_SET_PES_FILTER, &pes_filter) < 0)
|
||||||
|
GST_WARNING_OBJECT (object, "Error setting PES filter on %s: %s",
|
||||||
|
object->demux_dev, strerror (errno));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,6 @@ extern "C"
|
||||||
#define IPACKS 2048
|
#define IPACKS 2048
|
||||||
#define TS_SIZE 188
|
#define TS_SIZE 188
|
||||||
#define IN_SIZE TS_SIZE*10
|
#define IN_SIZE TS_SIZE*10
|
||||||
#define MAX_ATTEMPTS 10 /* limit timeouts for poll */
|
|
||||||
|
|
||||||
#define DEFAULT_DEVICE "/dev/dvb/adapter0"
|
#define DEFAULT_DEVICE "/dev/dvb/adapter0"
|
||||||
#define DEFAULT_SYMBOL_RATE 0
|
#define DEFAULT_SYMBOL_RATE 0
|
||||||
|
|
Loading…
Reference in a new issue