changeset 41:b892b9f97291 libavformat

added DVD LPCM decoding support
author bellard
date Fri, 31 Jan 2003 17:04:46 +0000
parents 721705c1f995
children cfc262e9955c
files mpeg.c
diffstat 1 files changed, 20 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/mpeg.c	Wed Jan 29 12:00:11 2003 +0000
+++ b/mpeg.c	Fri Jan 31 17:04:46 2003 +0000
@@ -598,6 +598,9 @@
     } else if (startcode >= 0x80 && startcode <= 0x9f) {
         type = CODEC_TYPE_AUDIO;
         codec_id = CODEC_ID_AC3;
+    } else if (startcode >= 0xa0 && startcode <= 0xbf) {
+        type = CODEC_TYPE_AUDIO;
+        codec_id = CODEC_ID_PCM_S16BE;
     } else {
     skip:
         /* skip packet */
@@ -611,6 +614,23 @@
     st->codec.codec_type = type;
     st->codec.codec_id = codec_id;
  found:
+    if (startcode >= 0xa0 && startcode <= 0xbf) {
+        int b1, freq;
+        static const int lpcm_freq_tab[4] = { 48000, 96000, 44100, 32000 };
+
+        /* for LPCM, we just skip the header and consider it is raw
+           audio data */
+        if (len <= 3)
+            goto skip;
+        get_byte(&s->pb); /* emphasis (1), muse(1), reserved(1), frame number(5) */
+        b1 = get_byte(&s->pb); /* quant (2), freq(2), reserved(1), channels(3) */
+        get_byte(&s->pb); /* dynamic range control (0x80 = off) */
+        len -= 3;
+        freq = (b1 >> 4) & 3;
+        st->codec.sample_rate = lpcm_freq_tab[freq];
+        st->codec.channels = 1 + (b1 & 7);
+        st->codec.bit_rate = st->codec.channels * st->codec.sample_rate * 2;
+    }
     av_new_packet(pkt, len);
     //printf("\nRead Packet ID: %x PTS: %f Size: %d", startcode,
     //       (float)pts/90000, len);