diff options
| -rw-r--r-- | ChangeLog | 5 | ||||
| -rw-r--r-- | Todo | 4 | ||||
| -rw-r--r-- | softhddev.c | 15 | 
3 files changed, 21 insertions, 3 deletions
| @@ -1,4 +1,9 @@  User johns +Date: + +    Detect dvb LPCM stream and ignore it. + +User johns  Date: Thu Feb  2 23:29:35 CET 2012      Release Version 0.4.6 @@ -81,6 +81,9 @@ audio:      Make alsa thread/polled and oss thread/polled output module runtime      selectable.      software volume support +    add pause support for replay pause +    some plugin send a private LPCM stream (CODEC_ID_PCM_DVD), which +    isn't supported by ffmpeg, write own parser.  audio/alsa:      better downmix of >2 channels on 2 channel hardware @@ -113,6 +116,7 @@ setup:  unsorted:      Menu -> Setup -> Plugins -> skingenigmang -> General  	-> Try 8bpp single area: no, has missing parts. +    FSE Skin anthra FSE has missing parts      stoping vdr while plugin is suspended opens and closes a window.  future features (not planed for 1.0 - 1.5) diff --git a/softhddev.c b/softhddev.c index 32a21b9..b7af321 100644 --- a/softhddev.c +++ b/softhddev.c @@ -261,7 +261,7 @@ int PlayAudio(const uint8_t * data, int size,  	return osize;      }      // Detect audio code -    // MPEG-PS mp2 MPEG1, MPEG2, AC3 +    // MPEG-PS mp2 MPEG1, MPEG2, AC3, LPCM      // Syncword - 0x0B77      if (data[0] == 0x0B && data[1] == 0x77) { @@ -279,6 +279,14 @@ int PlayAudio(const uint8_t * data, int size,  	    CodecAudioOpen(MyAudioDecoder, NULL, CODEC_ID_MP2);  	    AudioCodecID = CODEC_ID_MP2;  	} +	// Private stram + LPCM ID +    } else if (data[-n - 9 + 3] == 0xBD && data[0] == 0xA0) { +	if (AudioCodecID != CODEC_ID_PCM_DVD) { +	    Debug(3, "[softhddev]%s: LPCM %d\n", __FUNCTION__, id); +	    CodecAudioClose(MyAudioDecoder); +	    //CodecAudioOpen(MyAudioDecoder, NULL, CODEC_ID_PCM_DVD); +	    AudioCodecID = CODEC_ID_PCM_DVD; +	}      } else {  	// no start package  	// FIXME: Nick/Viva sends this shit, need to find sync in packet @@ -307,8 +315,9 @@ int PlayAudio(const uint8_t * data, int size,      avpkt->data = (void *)data;      avpkt->size = size; -    //memset(avpkt->data + avpkt->size, 0, FF_INPUT_BUFFER_PADDING_SIZE); -    CodecAudioDecode(MyAudioDecoder, avpkt); +    if (AudioCodecID != CODEC_ID_PCM_DVD) { +	CodecAudioDecode(MyAudioDecoder, avpkt); +    }      return osize;  } | 
