- let ahdr = NAAudioInfo::new(rate as u32, channels as u8, if (aflags & 4) != 0 { SND_S16_FORMAT } else { SND_U8_FORMAT }, 2);
- let ainfo = NACodecInfo::new("audio-gdv", NACodecTypeInfo::Audio(ahdr), None);
- self.a_id = self.dmx.add_stream(NAStream::new(StreamType::Audio, 1, ainfo));
+ let packed = if (aflags & 8) != 0 { 1 } else { 0 };
+ let depth = if (aflags & 4) != 0 { 16 } else { 8 };
+
+ let ahdr = NAAudioInfo::new(rate as u32, channels as u8, if depth == 16 { SND_S16_FORMAT } else { SND_U8_FORMAT }, 2);
+ let ainfo = NACodecInfo::new(if packed != 0 { "gdv-audio" } else { "pcm" },
+ NACodecTypeInfo::Audio(ahdr), None);
+ self.a_id = self.dmx.add_stream(NAStream::new(StreamType::Audio, 1, ainfo, 1, rate as u32));