Commit d83a5b52 authored by Marton Balint's avatar Marton Balint

mpegts: add pcr filter for tracking standalone pcr pids

Signed-off-by: 's avatarMarton Balint <cus@passwd.hu>
parent 6bab55b8
...@@ -55,6 +55,7 @@ ...@@ -55,6 +55,7 @@
enum MpegTSFilterType { enum MpegTSFilterType {
MPEGTS_PES, MPEGTS_PES,
MPEGTS_SECTION, MPEGTS_SECTION,
MPEGTS_PCR,
}; };
typedef struct MpegTSFilter MpegTSFilter; typedef struct MpegTSFilter MpegTSFilter;
...@@ -467,6 +468,11 @@ static MpegTSFilter *mpegts_open_pes_filter(MpegTSContext *ts, unsigned int pid, ...@@ -467,6 +468,11 @@ static MpegTSFilter *mpegts_open_pes_filter(MpegTSContext *ts, unsigned int pid,
return filter; return filter;
} }
static MpegTSFilter *mpegts_open_pcr_filter(MpegTSContext *ts, unsigned int pid)
{
return mpegts_open_filter(ts, pid, MPEGTS_PCR);
}
static void mpegts_close_filter(MpegTSContext *ts, MpegTSFilter *filter) static void mpegts_close_filter(MpegTSContext *ts, MpegTSFilter *filter)
{ {
int pid; int pid;
...@@ -1824,6 +1830,9 @@ static void pmt_cb(MpegTSFilter *filter, const uint8_t *section, int section_len ...@@ -1824,6 +1830,9 @@ static void pmt_cb(MpegTSFilter *filter, const uint8_t *section, int section_len
p = desc_list_end; p = desc_list_end;
} }
if (!ts->pids[pcr_pid])
mpegts_open_pcr_filter(ts, pcr_pid);
out: out:
for (i = 0; i < mp4_descr_count; i++) for (i = 0; i < mp4_descr_count; i++)
av_free(mp4_descr[i].dec_config_descr); av_free(mp4_descr[i].dec_config_descr);
...@@ -2029,7 +2038,7 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet) ...@@ -2029,7 +2038,7 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet)
} }
} }
if (!has_payload) if (!has_payload && tss->type != MPEGTS_PCR)
return 0; return 0;
p = packet + 4; p = packet + 4;
if (has_adaptation) { if (has_adaptation) {
...@@ -2038,7 +2047,7 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet) ...@@ -2038,7 +2047,7 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet)
} }
/* if past the end of packet, ignore */ /* if past the end of packet, ignore */
p_end = packet + TS_PACKET_SIZE; p_end = packet + TS_PACKET_SIZE;
if (p >= p_end) if (p > p_end || (p == p_end && tss->type != MPEGTS_PCR))
return 0; return 0;
pos = avio_tell(ts->stream->pb); pos = avio_tell(ts->stream->pb);
...@@ -2096,10 +2105,12 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet) ...@@ -2096,10 +2105,12 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet)
if (parse_pcr(&pcr_h, &pcr_l, packet) == 0) if (parse_pcr(&pcr_h, &pcr_l, packet) == 0)
tss->last_pcr = pcr_h * 300 + pcr_l; tss->last_pcr = pcr_h * 300 + pcr_l;
// Note: The position here points actually behind the current packet. // Note: The position here points actually behind the current packet.
if (tss->type == MPEGTS_PES) {
if ((ret = tss->u.pes_filter.pes_cb(tss, p, p_end - p, is_start, if ((ret = tss->u.pes_filter.pes_cb(tss, p, p_end - p, is_start,
pos - ts->raw_packet_size)) < 0) pos - ts->raw_packet_size)) < 0)
return ret; return ret;
} }
}
return 0; return 0;
} }
......
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