mirror of
https://github.com/VDR4Arch/vdr.git
synced 2023-10-10 13:36:52 +02:00
Fixed handling TS packets in cTS2PES
This commit is contained in:
parent
fb641c9149
commit
e9e8241d0d
@ -1014,6 +1014,7 @@ Reinhard Nissl <rnissl@gmx.de>
|
||||
for improving TS/PES conversion to better handle lost TS packets
|
||||
for suggesting to make the DVB devices retune (and, if applicable, resend the
|
||||
DiSEqC data) if the lock is lost
|
||||
for fixing handling TS packets in cTS2PES
|
||||
|
||||
Richard Robson <richard_robson@beeb.net>
|
||||
for reporting freezing replay if a timer starts while in Transfer Mode from the
|
||||
|
1
HISTORY
1
HISTORY
@ -4066,3 +4066,4 @@ Video Disk Recorder Revision History
|
||||
- The cTimer constructor can now take an optional cChannel (suggested by
|
||||
Patrick Fischer).
|
||||
- Fixed setting the main thread id if VDR is running as a daemon.
|
||||
- Fixed handling TS packets in cTS2PES (thanks to Reinhard Nissl).
|
||||
|
16
remux.c
16
remux.c
@ -11,7 +11,7 @@
|
||||
* The cRepacker family's code was originally written by Reinhard Nissl <rnissl@gmx.de>,
|
||||
* and adapted to the VDR coding style by Klaus.Schmidinger@cadsoft.de.
|
||||
*
|
||||
* $Id: remux.c 1.51 2006/01/01 14:58:53 kls Exp $
|
||||
* $Id: remux.c 1.52 2006/01/03 10:55:45 kls Exp $
|
||||
*/
|
||||
|
||||
#include "remux.h"
|
||||
@ -1281,9 +1281,10 @@ int cDolbyRepacker::BreakAt(const uchar *Data, int Count)
|
||||
#define CONT_CNT_MASK 0x0F
|
||||
|
||||
// Flags:
|
||||
#define PAY_LOAD 0x10
|
||||
#define ADAPT_FIELD 0x20
|
||||
#define PAY_START 0x40
|
||||
#define TS_ERROR 0x80
|
||||
#define ADAPT_FIELD 0x20
|
||||
|
||||
#define MAX_PLENGTH 0xFFFF // the maximum PES packet length (theoretically)
|
||||
#define MMAX_PLENGTH (64*MAX_PLENGTH) // some stations send PES packets that are extremely large, e.g. DVB-T in Finland or HDTV 1920x1080
|
||||
@ -1668,7 +1669,11 @@ void cTS2PES::ts_to_pes(const uint8_t *Buf) // don't need count (=188)
|
||||
|
||||
if (Buf[1] & TS_ERROR)
|
||||
tsErrors++;
|
||||
if ((Buf[3] ^ ccCounter) & CONT_CNT_MASK) {
|
||||
|
||||
if (!(Buf[3] & (ADAPT_FIELD | PAY_LOAD)))
|
||||
return; // discard TS packet with adaption_field_control set to '00'.
|
||||
|
||||
if ((Buf[3] & PAY_LOAD) && ((Buf[3] ^ ccCounter) & CONT_CNT_MASK)) {
|
||||
// This should check duplicates and packets which do not increase the counter.
|
||||
// But as the errors usually come in bursts this should be enough to
|
||||
// show you there is something wrong with signal quality.
|
||||
@ -1684,11 +1689,13 @@ void cTS2PES::ts_to_pes(const uint8_t *Buf) // don't need count (=188)
|
||||
|
||||
if (Buf[1] & PAY_START) {
|
||||
if (found > 6) {
|
||||
if (plength != MMAX_PLENGTH - 6 && plength != found - 6)
|
||||
dsyslog("PES packet shortened to %d bytes (expected: %d bytes)", found, plength + 6);
|
||||
plength = found - 6;
|
||||
found = 0;
|
||||
send_ipack();
|
||||
reset_ipack();
|
||||
}
|
||||
found = 0;
|
||||
}
|
||||
|
||||
uint8_t off = 0;
|
||||
@ -1699,6 +1706,7 @@ void cTS2PES::ts_to_pes(const uint8_t *Buf) // don't need count (=188)
|
||||
return;
|
||||
}
|
||||
|
||||
if (Buf[3] & PAY_LOAD)
|
||||
instant_repack(Buf + 4 + off, TS_SIZE - 4 - off);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user