| @@ -159,6 +159,8 @@ OBJS-$(CONFIG_FLIC_DECODER) += flicvideo.o | |||||
| OBJS-$(CONFIG_FOURXM_DECODER) += 4xm.o | OBJS-$(CONFIG_FOURXM_DECODER) += 4xm.o | ||||
| OBJS-$(CONFIG_FRAPS_DECODER) += fraps.o | OBJS-$(CONFIG_FRAPS_DECODER) += fraps.o | ||||
| OBJS-$(CONFIG_FRWU_DECODER) += frwu.o | OBJS-$(CONFIG_FRWU_DECODER) += frwu.o | ||||
| OBJS-$(CONFIG_G723_1_DECODER) += g723_1.o acelp_vectors.o \ | |||||
| celp_filters.o celp_math.o | |||||
| OBJS-$(CONFIG_G729_DECODER) += g729dec.o lsp.o celp_math.o acelp_filters.o acelp_pitch_delay.o acelp_vectors.o g729postfilter.o | OBJS-$(CONFIG_G729_DECODER) += g729dec.o lsp.o celp_math.o acelp_filters.o acelp_pitch_delay.o acelp_vectors.o g729postfilter.o | ||||
| OBJS-$(CONFIG_GIF_DECODER) += gifdec.o lzw.o | OBJS-$(CONFIG_GIF_DECODER) += gifdec.o lzw.o | ||||
| OBJS-$(CONFIG_GIF_ENCODER) += gif.o lzwenc.o | OBJS-$(CONFIG_GIF_ENCODER) += gif.o lzwenc.o | ||||
| @@ -258,6 +258,7 @@ void avcodec_register_all(void) | |||||
| REGISTER_DECODER (DSICINAUDIO, dsicinaudio); | REGISTER_DECODER (DSICINAUDIO, dsicinaudio); | ||||
| REGISTER_ENCDEC (EAC3, eac3); | REGISTER_ENCDEC (EAC3, eac3); | ||||
| REGISTER_ENCDEC (FLAC, flac); | REGISTER_ENCDEC (FLAC, flac); | ||||
| REGISTER_DECODER (G723_1, g723_1); | |||||
| REGISTER_DECODER (G729, g729); | REGISTER_DECODER (G729, g729); | ||||
| REGISTER_DECODER (GSM, gsm); | REGISTER_DECODER (GSM, gsm); | ||||
| REGISTER_DECODER (GSM_MS, gsm_ms); | REGISTER_DECODER (GSM_MS, gsm_ms); | ||||
| @@ -345,6 +345,7 @@ enum CodecID { | |||||
| CODEC_ID_QDMC, | CODEC_ID_QDMC, | ||||
| CODEC_ID_CELT, | CODEC_ID_CELT, | ||||
| CODEC_ID_G729 = 0x15800, | CODEC_ID_G729 = 0x15800, | ||||
| CODEC_ID_G723_1= 0x15801, | |||||
| /* subtitle codecs */ | /* subtitle codecs */ | ||||
| CODEC_ID_FIRST_SUBTITLE = 0x17000, ///< A dummy ID pointing at the start of subtitle codecs. | CODEC_ID_FIRST_SUBTITLE = 0x17000, ///< A dummy ID pointing at the start of subtitle codecs. | ||||
| @@ -21,7 +21,7 @@ | |||||
| #define AVCODEC_VERSION_H | #define AVCODEC_VERSION_H | ||||
| #define LIBAVCODEC_VERSION_MAJOR 53 | #define LIBAVCODEC_VERSION_MAJOR 53 | ||||
| #define LIBAVCODEC_VERSION_MINOR 18 | |||||
| #define LIBAVCODEC_VERSION_MINOR 19 | |||||
| #define LIBAVCODEC_VERSION_MICRO 0 | #define LIBAVCODEC_VERSION_MICRO 0 | ||||
| #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ | #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ | ||||
| @@ -98,6 +98,7 @@ OBJS-$(CONFIG_GXF_DEMUXER) += gxf.o | |||||
| OBJS-$(CONFIG_GXF_MUXER) += gxfenc.o audiointerleave.o | OBJS-$(CONFIG_GXF_MUXER) += gxfenc.o audiointerleave.o | ||||
| OBJS-$(CONFIG_G722_DEMUXER) += rawdec.o | OBJS-$(CONFIG_G722_DEMUXER) += rawdec.o | ||||
| OBJS-$(CONFIG_G722_MUXER) += rawenc.o | OBJS-$(CONFIG_G722_MUXER) += rawenc.o | ||||
| OBJS-$(CONFIG_G723_1_DEMUXER) += g723_1.o | |||||
| OBJS-$(CONFIG_H261_DEMUXER) += h261dec.o rawdec.o | OBJS-$(CONFIG_H261_DEMUXER) += h261dec.o rawdec.o | ||||
| OBJS-$(CONFIG_H261_MUXER) += rawenc.o | OBJS-$(CONFIG_H261_MUXER) += rawenc.o | ||||
| OBJS-$(CONFIG_H263_DEMUXER) += h263dec.o rawdec.o | OBJS-$(CONFIG_H263_DEMUXER) += h263dec.o rawdec.o | ||||
| @@ -100,6 +100,7 @@ void av_register_all(void) | |||||
| REGISTER_MUXER (FRAMECRC, framecrc); | REGISTER_MUXER (FRAMECRC, framecrc); | ||||
| REGISTER_MUXER (FRAMEMD5, framemd5); | REGISTER_MUXER (FRAMEMD5, framemd5); | ||||
| REGISTER_MUXDEMUX (G722, g722); | REGISTER_MUXDEMUX (G722, g722); | ||||
| REGISTER_DEMUXER (G723_1, g723_1); | |||||
| REGISTER_MUXER (GIF, gif); | REGISTER_MUXER (GIF, gif); | ||||
| REGISTER_DEMUXER (GSM, gsm); | REGISTER_DEMUXER (GSM, gsm); | ||||
| REGISTER_MUXDEMUX (GXF, gxf); | REGISTER_MUXDEMUX (GXF, gxf); | ||||
| @@ -0,0 +1,83 @@ | |||||
| /* | |||||
| * G.723.1 demuxer | |||||
| * Copyright (c) 2010 Mohamed Naufal Basheer | |||||
| * | |||||
| * This file is part of FFmpeg. | |||||
| * | |||||
| * FFmpeg is free software; you can redistribute it and/or | |||||
| * modify it under the terms of the GNU Lesser General Public | |||||
| * License as published by the Free Software Foundation; either | |||||
| * version 2.1 of the License, or (at your option) any later version. | |||||
| * | |||||
| * FFmpeg 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 | |||||
| * Lesser General Public License for more details. | |||||
| * | |||||
| * You should have received a copy of the GNU Lesser General Public | |||||
| * License along with FFmpeg; if not, write to the Free Software | |||||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||||
| */ | |||||
| /** | |||||
| * @file | |||||
| * G.723.1 demuxer | |||||
| */ | |||||
| #include "avformat.h" | |||||
| static const uint8_t frame_size[4] = {24, 20, 4, 1}; | |||||
| static int g723_1_init(AVFormatContext *s, AVFormatParameters *ap) | |||||
| { | |||||
| AVStream *st; | |||||
| st = av_new_stream(s, 0); | |||||
| if (!st) | |||||
| return AVERROR(ENOMEM); | |||||
| st->codec->codec_type = AVMEDIA_TYPE_AUDIO; | |||||
| st->codec->codec_id = CODEC_ID_G723_1; | |||||
| st->codec->channels = 1; | |||||
| st->codec->sample_rate = 8000; | |||||
| av_set_pts_info(st, 64, 1, st->codec->sample_rate); | |||||
| return 0; | |||||
| } | |||||
| static int g723_1_read_packet(AVFormatContext *s, AVPacket *pkt) | |||||
| { | |||||
| int size, byte, ret; | |||||
| pkt->pos = url_ftell(s->pb); | |||||
| byte = get_byte(s->pb); | |||||
| size = frame_size[byte & 3]; | |||||
| ret = av_new_packet(pkt, size); | |||||
| if (ret < 0) | |||||
| return ret; | |||||
| pkt->data[0] = byte; | |||||
| pkt->duration = 240; | |||||
| pkt->stream_index = 0; | |||||
| ret = get_buffer(s->pb, pkt->data + 1, size - 1); | |||||
| if (ret < size - 1) { | |||||
| av_free_packet(pkt); | |||||
| return ret < 0 ? ret : AVERROR_EOF; | |||||
| } | |||||
| return pkt->size; | |||||
| } | |||||
| AVInputFormat ff_g723_1_demuxer = { | |||||
| "g723_1", | |||||
| NULL_IF_CONFIG_SMALL("G.723.1 format"), | |||||
| 0, | |||||
| NULL, | |||||
| g723_1_init, | |||||
| g723_1_read_packet, | |||||
| .extensions = "tco", | |||||
| .flags = AVFMT_GENERIC_INDEX | |||||
| }; | |||||
| @@ -44,7 +44,7 @@ static const struct | |||||
| { | { | ||||
| {0, "PCMU", AVMEDIA_TYPE_AUDIO, CODEC_ID_PCM_MULAW, 8000, 1}, | {0, "PCMU", AVMEDIA_TYPE_AUDIO, CODEC_ID_PCM_MULAW, 8000, 1}, | ||||
| {3, "GSM", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 8000, 1}, | {3, "GSM", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 8000, 1}, | ||||
| {4, "G723", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 8000, 1}, | |||||
| {4, "G723", AVMEDIA_TYPE_AUDIO, CODEC_ID_G723_1, 8000, 1}, | |||||
| {5, "DVI4", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 8000, 1}, | {5, "DVI4", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 8000, 1}, | ||||
| {6, "DVI4", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 16000, 1}, | {6, "DVI4", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 16000, 1}, | ||||
| {7, "LPC", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 8000, 1}, | {7, "LPC", AVMEDIA_TYPE_AUDIO, CODEC_ID_NONE, 8000, 1}, | ||||