summaryrefslogtreecommitdiff
path: root/softhddev.c
diff options
context:
space:
mode:
authorJohns <johns98@gmx.net>2011-12-10 00:15:38 +0100
committerJohns <johns98@gmx.net>2011-12-10 00:15:38 +0100
commit749b0d672142c685556fa9f3788bff732920460b (patch)
treecff47acb11c9bd55688790ba4904d8845d6eddeb /softhddev.c
parente1d8609143bc661b9ad84c91abb815ca0e9f9e36 (diff)
downloadvdr-plugin-softhddevice-749b0d672142c685556fa9f3788bff732920460b.tar.gz
vdr-plugin-softhddevice-749b0d672142c685556fa9f3788bff732920460b.tar.bz2
Video enhancements.
Pass PTS to video codec. Flush audio buffer on channel change. Sync audio + video stream. Add workaround for Intel VA-API driver that forgets OSD position/size.
Diffstat (limited to 'softhddev.c')
-rw-r--r--softhddev.c31
1 files changed, 22 insertions, 9 deletions
diff --git a/softhddev.c b/softhddev.c
index 067b8f5..60187db 100644
--- a/softhddev.c
+++ b/softhddev.c
@@ -90,7 +90,7 @@ void PlayAudio(const uint8_t * data, int size, uint8_t id)
avpkt->pts =
(int64_t) (data[9] & 0x0E) << 29 | data[10] << 22 | (data[11] &
0xFE) << 14 | data[12] << 7 | (data[13] & 0xFE) >> 1;
- // Debug(3, "audio: pts %#012" PRIx64 "\n", avpkt->pts);
+ //Debug(3, "audio: pts %#012" PRIx64 "\n", avpkt->pts);
}
if (0) { // dts is unused
if (data[7] & 0x40) {
@@ -234,13 +234,17 @@ static void VideoPacketInit(void)
/**
** Place video data in packet ringbuffer.
*/
-static void VideoEnqueue(const void *data, int size)
+static void VideoEnqueue(int64_t pts, const void *data, int size)
{
AVPacket *avpkt;
// Debug(3, "video: enqueue %d\n", size);
avpkt = &VideoPacketRb[VideoPacketWrite];
+ if (!avpkt->stream_index) { // add pts only for first added
+ avpkt->pts = pts;
+ avpkt->dts = pts;
+ }
if (avpkt->stream_index + size + FF_INPUT_BUFFER_PADDING_SIZE >=
avpkt->size) {
@@ -255,9 +259,9 @@ static void VideoEnqueue(const void *data, int size)
abort();
}
}
-#ifdef DEBUG
+#ifdef xxDEBUG
if (!avpkt->stream_index) { // debug save time of first packet
- avpkt->dts = GetMsTicks();
+ avpkt->pos = GetMsTicks();
}
#endif
if (!VideoStartTick) { // tick of first valid packet
@@ -329,6 +333,14 @@ int VideoDecode(void)
// Debug(3, "video: decode no packets buffered\n");
return -1;
}
+#if 0
+ // FIXME: flush buffers, if close is in the queue
+ while (filled) {
+ avpkt = &VideoPacketRb[VideoPacketRead];
+ if ((int)(size_t) avpkt->priv == CODEC_ID_NONE) {
+ }
+ }
+#endif
avpkt = &VideoPacketRb[VideoPacketRead];
//
@@ -430,9 +442,9 @@ void VideoWakeup(void)
while (filled) {
avpkt = &VideoPacketRb[VideoPacketRead];
now = GetMsTicks();
- if (avpkt->dts + 500 > now) {
+ if (avpkt->pos + 500 > now) {
Debug(3, "video: %d packets %u delayed\n", filled,
- (unsigned)(now - avpkt->dts));
+ (unsigned)(now - avpkt->pos));
return;
}
filled = atomic_read(&VideoPacketsFilled);
@@ -474,7 +486,7 @@ static void StartVideo(void)
void PlayVideo(const uint8_t * data, int size)
{
const uint8_t *check;
- uint64_t pts;
+ int64_t pts;
int n;
if (BrokenThreadsAndPlugins) {
@@ -513,7 +525,7 @@ void PlayVideo(const uint8_t * data, int size)
pts =
(int64_t) (data[9] & 0x0E) << 29 | data[10] << 22 | (data[11] &
0xFE) << 14 | data[12] << 7 | (data[13] & 0xFE) >> 1;
- // Debug(3, "video: pts %#012" PRIx64 "\n", pts);
+ //Debug(3, "video: pts %#012" PRIx64 "\n", pts);
}
// FIXME: no valid mpeg2/h264 detection yet
@@ -527,6 +539,7 @@ void PlayVideo(const uint8_t * data, int size)
if (VideoCodecID == CODEC_ID_MPEG2VIDEO) {
VideoNextPacket(CODEC_ID_MPEG2VIDEO);
} else {
+ Debug(3, "video: mpeg2 detected\n");
VideoCodecID = CODEC_ID_MPEG2VIDEO;
}
// Access Unit Delimiter
@@ -552,7 +565,7 @@ void PlayVideo(const uint8_t * data, int size)
// SKIP PES header
size -= 9 + n;
- VideoEnqueue(check, size);
+ VideoEnqueue(pts, check, size);
}
//////////////////////////////////////////////////////////////////////////////