Browse Source

lavd/alsa: fix timestamp calculation

Current implementation didn't include duration of
last processed packet.
Device may return negative timestamps without
this correction.

Signed-off-by: Lukasz Marek <lukasz.m.luki@gmail.com>
tags/n2.2-rc1
Lukasz Marek Nicolas George 11 years ago
parent
commit
6ac9afd16e
2 changed files with 6 additions and 1 deletions
  1. +5
    -1
      libavdevice/alsa-audio-enc.c
  2. +1
    -0
      libavdevice/alsa-audio.h

+ 5
- 1
libavdevice/alsa-audio-enc.c View File

@@ -80,6 +80,10 @@ static int audio_write_packet(AVFormatContext *s1, AVPacket *pkt)
uint8_t *buf = pkt->data;

size /= s->frame_size;
if (pkt->dts != AV_NOPTS_VALUE)
s->timestamp = pkt->dts;
s->timestamp += pkt->duration ? pkt->duration : size;

if (s->reorder_func) {
if (size > s->reorder_buf_size)
if (ff_alsa_extend_reorder_buf(s, size))
@@ -112,7 +116,7 @@ audio_get_output_timestamp(AVFormatContext *s1, int stream,
snd_pcm_sframes_t delay = 0;
*wall = av_gettime();
snd_pcm_delay(s->h, &delay);
*dts = s1->streams[0]->cur_dts - delay;
*dts = s->timestamp - delay;
}

AVOutputFormat ff_alsa_muxer = {


+ 1
- 0
libavdevice/alsa-audio.h View File

@@ -57,6 +57,7 @@ typedef struct AlsaData {
void (*reorder_func)(const void *, void *, int);
void *reorder_buf;
int reorder_buf_size; ///< in frames
int64_t timestamp; ///< current timestamp, without latency applied.
} AlsaData;

/**


Loading…
Cancel
Save