mirror of
https://github.com/VDR4Arch/vdr.git
synced 2023-10-10 13:36:52 +02:00
Added a workaround for recovering from wrongfully interpreted "pre 1.3.19 PS1 packets"
This commit is contained in:
parent
2fa568654d
commit
06f813d2a8
3
HISTORY
3
HISTORY
@ -5488,7 +5488,7 @@ Video Disk Recorder Revision History
|
||||
both opening and closing section filters (thanks to Rolf Ahrenberg).
|
||||
- Some fixes to PLUGINS.html (thanks to Rolf Ahrenberg).
|
||||
|
||||
2007-10-21: Version 1.5.11
|
||||
2007-11-03: Version 1.5.11
|
||||
|
||||
- Fixed checking compatibility mode for old subtitles plugin (thanks to Marco
|
||||
Schlüßler).
|
||||
@ -5502,3 +5502,4 @@ Video Disk Recorder Revision History
|
||||
- Added more special characters to the list of allowed characters when entering
|
||||
strings (thanks to Thomas Günther).
|
||||
- Added Ukrainian language texts (thanks to Yarema Aka Knedlyk).
|
||||
- Added a workaround for recovering from wrongfully interpreted "pre 1.3.19 PS1 packets".
|
||||
|
24
device.c
24
device.c
@ -4,7 +4,7 @@
|
||||
* See the main source file 'vdr.c' for copyright information and
|
||||
* how to reach the author.
|
||||
*
|
||||
* $Id: device.c 1.146 2007/10/17 18:31:02 kls Exp $
|
||||
* $Id: device.c 1.147 2007/11/03 13:30:09 kls Exp $
|
||||
*/
|
||||
|
||||
#include "device.h"
|
||||
@ -209,6 +209,9 @@ int cPesAssembler::PacketSize(const uchar *data)
|
||||
// The default priority for non-primary devices:
|
||||
#define DEFAULTPRIORITY -1
|
||||
|
||||
// The minimum number of unknown PS1 packets to consider this a "pre 1.3.19 private stream":
|
||||
#define MIN_PRE_1_3_19_PRIVATESTREAM 10
|
||||
|
||||
int cDevice::numDevices = 0;
|
||||
int cDevice::useDevice = 0;
|
||||
int cDevice::nextCardIndex = 0;
|
||||
@ -931,7 +934,7 @@ void cDevice::ClrAvailableTracks(bool DescriptionsOnly, bool IdsOnly)
|
||||
}
|
||||
else
|
||||
memset(availableTracks, 0, sizeof(availableTracks));
|
||||
pre_1_3_19_PrivateStream = false;
|
||||
pre_1_3_19_PrivateStream = 0;
|
||||
SetAudioChannel(0); // fall back to stereo
|
||||
currentAudioTrackMissingCount = 0;
|
||||
currentAudioTrack = ttNone;
|
||||
@ -1245,11 +1248,13 @@ int cDevice::PlayPesPacket(const uchar *Data, int Length, bool VideoOnly)
|
||||
|
||||
// Compatibility mode for old VDR recordings, where 0xBD was only AC3:
|
||||
pre_1_3_19_PrivateStreamDeteced:
|
||||
if (pre_1_3_19_PrivateStream) {
|
||||
if (pre_1_3_19_PrivateStream > MIN_PRE_1_3_19_PRIVATESTREAM) {
|
||||
SubStreamId = c;
|
||||
SubStreamType = 0x80;
|
||||
SubStreamIndex = 0;
|
||||
}
|
||||
else if (pre_1_3_19_PrivateStream)
|
||||
pre_1_3_19_PrivateStream--; // every known PS1 packet counts down towards 0 to recover from glitches...
|
||||
switch (SubStreamType) {
|
||||
case 0x20: // SPU
|
||||
case 0x30: // SPU
|
||||
@ -1277,11 +1282,14 @@ pre_1_3_19_PrivateStreamDeteced:
|
||||
break;
|
||||
default:
|
||||
// Compatibility mode for old VDR recordings, where 0xBD was only AC3:
|
||||
if (!pre_1_3_19_PrivateStream) {
|
||||
dsyslog("switching to pre 1.3.19 Dolby Digital compatibility mode");
|
||||
ClrAvailableTracks();
|
||||
pre_1_3_19_PrivateStream = true;
|
||||
goto pre_1_3_19_PrivateStreamDeteced;
|
||||
if (pre_1_3_19_PrivateStream <= MIN_PRE_1_3_19_PRIVATESTREAM) {
|
||||
dsyslog("unknown PS1 packet, substream id = %02X (counter is at %d)", SubStreamId, pre_1_3_19_PrivateStream);
|
||||
pre_1_3_19_PrivateStream += 2; // ...and every unknown PS1 packet counts up (the very first one counts twice, but that's ok)
|
||||
if (pre_1_3_19_PrivateStream > MIN_PRE_1_3_19_PRIVATESTREAM) {
|
||||
dsyslog("switching to pre 1.3.19 Dolby Digital compatibility mode - substream id = %02X", SubStreamId);
|
||||
ClrAvailableTracks();
|
||||
goto pre_1_3_19_PrivateStreamDeteced;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
4
device.h
4
device.h
@ -4,7 +4,7 @@
|
||||
* See the main source file 'vdr.c' for copyright information and
|
||||
* how to reach the author.
|
||||
*
|
||||
* $Id: device.h 1.85 2007/10/14 13:09:12 kls Exp $
|
||||
* $Id: device.h 1.86 2007/11/03 13:30:00 kls Exp $
|
||||
*/
|
||||
|
||||
#ifndef __DEVICE_H
|
||||
@ -377,7 +377,7 @@ private:
|
||||
cMutex mutexCurrentSubtitleTrack;
|
||||
int currentAudioTrackMissingCount;
|
||||
bool autoSelectPreferredSubtitleLanguage;
|
||||
bool pre_1_3_19_PrivateStream;
|
||||
int pre_1_3_19_PrivateStream;
|
||||
protected:
|
||||
virtual void SetAudioTrackDevice(eTrackType Type);
|
||||
///< Sets the current audio track to the given value.
|
||||
|
Loading…
Reference in New Issue
Block a user