summaryrefslogtreecommitdiffstats
path: root/libmpdemux/demux_real.c
diff options
context:
space:
mode:
authorattila <attila@b3059339-0415-0410-9bf9-f77b7e298cf2>2004-01-29 12:11:13 +0000
committerattila <attila@b3059339-0415-0410-9bf9-f77b7e298cf2>2004-01-29 12:11:13 +0000
commit5a69fab2f06a4d89a17b7d99f7e268a2008a9339 (patch)
tree6f49b34200a064cabb1711367e22ec413cb631dd /libmpdemux/demux_real.c
parentd40666618db8c46f03af6d0034986b2e305f2f6e (diff)
downloadmpv-5a69fab2f06a4d89a17b7d99f7e268a2008a9339.tar.bz2
mpv-5a69fab2f06a4d89a17b7d99f7e268a2008a9339.tar.xz
add support for aac in real media files
patch by Moritz Bunkus <moritz@bunkus.org> git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@11878 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpdemux/demux_real.c')
-rw-r--r--libmpdemux/demux_real.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/libmpdemux/demux_real.c b/libmpdemux/demux_real.c
index 6ae98880a3..a9cc452bc6 100644
--- a/libmpdemux/demux_real.c
+++ b/libmpdemux/demux_real.c
@@ -581,6 +581,26 @@ got_audio:
static int cnt=0;
static int cnt2=CRACK_MATRIX;
#endif
+ if (((sh_audio_t *)ds->sh)->format == mmioFOURCC('M', 'P', '4', 'A')) {
+ uint16_t *sub_packet_lengths, sub_packets, i;
+ /* AAC in Real: several AAC frames in one Real packet. */
+ /* Second byte, upper four bits: number of AAC frames */
+ /* next n * 2 bytes: length of the AAC frames in bytes, BE */
+ sub_packets = (stream_read_word(demuxer->stream) & 0xf0) >> 4;
+ sub_packet_lengths = calloc(sub_packets, sizeof(uint16_t));
+ for (i = 0; i < sub_packets; i++)
+ sub_packet_lengths[i] = stream_read_word(demuxer->stream);
+ for (i = 0; i < sub_packets; i++) {
+ demux_packet_t *dp = new_demux_packet(sub_packet_lengths[i]);
+ stream_read(demuxer->stream, dp->buffer, sub_packet_lengths[i]);
+ dp->pts = (priv->a_pts == timestamp) ? 0 : (timestamp / 1000.0f);
+ priv->a_pts = timestamp;
+ dp->pos = demuxer->filepos;
+ ds_add_packet(ds, dp);
+ }
+ free(sub_packet_lengths);
+ return 1;
+ }
demux_packet_t *dp = new_demux_packet(len);
stream_read(demuxer->stream, dp->buffer, len);
#ifdef CRACK_MATRIX
@@ -1193,6 +1213,23 @@ void demux_open_real(demuxer_t* demuxer)
// stream_read(demuxer->stream, ((char*)(sh->wf+1))+6, 24); // extras
stream_read(demuxer->stream, ((char*)(sh->wf+1))+10, codecdata_length); // extras
break;
+ case MKTAG('r', 'a', 'a', 'c'):
+ case MKTAG('r', 'a', 'c', 'p'):
+ /* This is just AAC. The two or five bytes of */
+ /* config data needed for libfaad are stored */
+ /* after the audio headers. */
+ stream_skip(demuxer->stream,3); // Skip 3 unknown bytes
+ if (version==5)
+ stream_skip(demuxer->stream,1); // Skip 1 additional unknown byte
+ codecdata_length=stream_read_dword(demuxer->stream);
+ if (codecdata_length>=1) {
+ sh->codecdata_len = codecdata_length - 1;
+ sh->codecdata = calloc(sh->codecdata_len, 1);
+ stream_skip(demuxer->stream, 1);
+ stream_read(demuxer->stream, sh->codecdata, sh->codecdata_len);
+ }
+ sh->format = mmioFOURCC('M', 'P', '4', 'A');
+ break;
default:
mp_msg(MSGT_DEMUX,MSGL_V,"Audio: Unknown (%s)\n", buf);
}