changeset 26327:fa91545f01bb

Split the aac header parsing out of aac demuxer to allow using libmpmux without libmpdemux.
author albeu
date Wed, 09 Apr 2008 00:43:19 +0000
parents 5bfc1d8bece9
children 11aac031b4b7
files libmpdemux/Makefile libmpdemux/aac_hdr.c libmpdemux/demux_aac.c
diffstat 3 files changed, 51 insertions(+), 20 deletions(-) [+]
line wrap: on
line diff
--- a/libmpdemux/Makefile	Wed Apr 09 00:36:28 2008 +0000
+++ b/libmpdemux/Makefile	Wed Apr 09 00:43:19 2008 +0000
@@ -3,7 +3,8 @@
 LIBNAME_COMMON   = libmpdemux.a
 LIBNAME_MENCODER = libmpmux.a
 
-SRCS_COMMON = asfheader.c \
+SRCS_COMMON = aac_hdr.c \
+              asfheader.c \
               aviheader.c \
               aviprint.c \
               demuxer.c \
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libmpdemux/aac_hdr.c	Wed Apr 09 00:43:19 2008 +0000
@@ -0,0 +1,48 @@
+/*
+ * Copyright (C) 2005 Nico Sabbi
+ *
+ * This file is part of MPlayer.
+ *
+ * MPlayer is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * MPlayer is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with MPlayer; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#include <stdlib.h>
+#include <inttypes.h>
+
+#include "config.h"
+
+/// \param srate (out) sample rate
+/// \param num (out) number of audio frames in this ADTS frame
+/// \return size of the ADTS frame in bytes
+/// aac_parse_frames needs a buffer at least 8 bytes long
+int aac_parse_frame(uint8_t *buf, int *srate, int *num)
+{
+	int i = 0, sr, fl = 0, id;
+	static int srates[] = {96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000, 0, 0, 0};
+	
+	if((buf[i] != 0xFF) || ((buf[i+1] & 0xF6) != 0xF0))
+		return 0;
+	
+	id = (buf[i+1] >> 3) & 0x01;	//id=1 mpeg2, 0: mpeg4
+	sr = (buf[i+2] >> 2)  & 0x0F;
+	if(sr > 11)
+		return 0;
+	*srate = srates[sr];
+
+	fl = ((buf[i+3] & 0x03) << 11) | (buf[i+4] << 3) | ((buf[i+5] >> 5) & 0x07);
+	*num = (buf[i+6] & 0x02) + 1;
+
+	return fl;
+}
--- a/libmpdemux/demux_aac.c	Wed Apr 09 00:36:28 2008 +0000
+++ b/libmpdemux/demux_aac.c	Wed Apr 09 00:43:19 2008 +0000
@@ -25,25 +25,7 @@
 /// \param num (out) number of audio frames in this ADTS frame
 /// \return size of the ADTS frame in bytes
 /// aac_parse_frames needs a buffer at least 8 bytes long
-int aac_parse_frame(uint8_t *buf, int *srate, int *num)
-{
-	int i = 0, sr, fl = 0, id;
-	static int srates[] = {96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000, 0, 0, 0};
-	
-	if((buf[i] != 0xFF) || ((buf[i+1] & 0xF6) != 0xF0))
-		return 0;
-	
-	id = (buf[i+1] >> 3) & 0x01;	//id=1 mpeg2, 0: mpeg4
-	sr = (buf[i+2] >> 2)  & 0x0F;
-	if(sr > 11)
-		return 0;
-	*srate = srates[sr];
-
-	fl = ((buf[i+3] & 0x03) << 11) | (buf[i+4] << 3) | ((buf[i+5] >> 5) & 0x07);
-	*num = (buf[i+6] & 0x02) + 1;
-
-	return fl;
-}
+int aac_parse_frame(uint8_t *buf, int *srate, int *num);
 
 static int demux_aac_init(demuxer_t *demuxer)
 {