Signed-off-by: Diego Biurrun <diego@biurrun.de>tags/n2.3
@@ -289,8 +289,8 @@ OBJS-$(CONFIG_ON2AVC_DECODER) += on2avc.o on2avcdata.o | |||||
OBJS-$(CONFIG_OPUS_DECODER) += opusdec.o opus.o opus_celt.o \ | OBJS-$(CONFIG_OPUS_DECODER) += opusdec.o opus.o opus_celt.o \ | ||||
opus_imdct.o opus_silk.o \ | opus_imdct.o opus_silk.o \ | ||||
vorbis_data.o | vorbis_data.o | ||||
OBJS-$(CONFIG_PAF_VIDEO_DECODER) += paf.o | |||||
OBJS-$(CONFIG_PAF_AUDIO_DECODER) += paf.o | |||||
OBJS-$(CONFIG_PAF_AUDIO_DECODER) += pafaudio.o | |||||
OBJS-$(CONFIG_PAF_VIDEO_DECODER) += pafvideo.o | |||||
OBJS-$(CONFIG_PAM_DECODER) += pnmdec.o pnm.o | OBJS-$(CONFIG_PAM_DECODER) += pnmdec.o pnm.o | ||||
OBJS-$(CONFIG_PAM_ENCODER) += pamenc.o | OBJS-$(CONFIG_PAM_ENCODER) += pamenc.o | ||||
OBJS-$(CONFIG_PBM_DECODER) += pnmdec.o pnm.o | OBJS-$(CONFIG_PBM_DECODER) += pnmdec.o pnm.o | ||||
@@ -0,0 +1,84 @@ | |||||
/* | |||||
* Packed Animation File audio decoder | |||||
* Copyright (c) 2012 Paul B Mahol | |||||
* | |||||
* This file is part of Libav. | |||||
* | |||||
* Libav 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. | |||||
* | |||||
* Libav 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 Libav; if not, write to the Free Software | |||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||||
*/ | |||||
#include "libavutil/intreadwrite.h" | |||||
#include "avcodec.h" | |||||
#include "internal.h" | |||||
#include "mathops.h" | |||||
#define PAF_SOUND_SAMPLES 2205 | |||||
#define PAF_SOUND_FRAME_SIZE ((256 + PAF_SOUND_SAMPLES) * 2) | |||||
static av_cold int paf_audio_init(AVCodecContext *avctx) | |||||
{ | |||||
if (avctx->channels != 2) { | |||||
av_log(avctx, AV_LOG_ERROR, "invalid number of channels\n"); | |||||
return AVERROR_INVALIDDATA; | |||||
} | |||||
avctx->channel_layout = AV_CH_LAYOUT_STEREO; | |||||
avctx->sample_fmt = AV_SAMPLE_FMT_S16; | |||||
return 0; | |||||
} | |||||
static int paf_audio_decode(AVCodecContext *avctx, void *data, | |||||
int *got_frame, AVPacket *pkt) | |||||
{ | |||||
AVFrame *frame = data; | |||||
int16_t *output_samples; | |||||
const uint8_t *src = pkt->data; | |||||
int frames, ret, i, j; | |||||
int16_t cb[256]; | |||||
frames = pkt->size / PAF_SOUND_FRAME_SIZE; | |||||
if (frames < 1) | |||||
return AVERROR_INVALIDDATA; | |||||
frame->nb_samples = PAF_SOUND_SAMPLES * frames; | |||||
if ((ret = ff_get_buffer(avctx, frame, 0)) < 0) | |||||
return ret; | |||||
output_samples = (int16_t *)frame->data[0]; | |||||
// codebook of 256 16-bit samples and 8-bit indices to it | |||||
for (j = 0; j < frames; j++) { | |||||
for (i = 0; i < 256; i++) | |||||
cb[i] = sign_extend(AV_RL16(src + i * 2), 16); | |||||
src += 256 * 2; | |||||
// always 2 channels | |||||
for (i = 0; i < PAF_SOUND_SAMPLES * 2; i++) | |||||
*output_samples++ = cb[*src++]; | |||||
} | |||||
*got_frame = 1; | |||||
return pkt->size; | |||||
} | |||||
AVCodec ff_paf_audio_decoder = { | |||||
.name = "paf_audio", | |||||
.long_name = NULL_IF_CONFIG_SMALL("Amazing Studio Packed Animation File Audio"), | |||||
.type = AVMEDIA_TYPE_AUDIO, | |||||
.id = AV_CODEC_ID_PAF_AUDIO, | |||||
.init = paf_audio_init, | |||||
.decode = paf_audio_decode, | |||||
.capabilities = CODEC_CAP_DR1, | |||||
}; |
@@ -1,5 +1,5 @@ | |||||
/* | /* | ||||
* Packed Animation File video and audio decoder | |||||
* Packed Animation File video decoder | |||||
* Copyright (c) 2012 Paul B Mahol | * Copyright (c) 2012 Paul B Mahol | ||||
* | * | ||||
* This file is part of Libav. | * This file is part of Libav. | ||||
@@ -20,16 +20,11 @@ | |||||
*/ | */ | ||||
#include "libavutil/imgutils.h" | #include "libavutil/imgutils.h" | ||||
#include "libavutil/intreadwrite.h" | |||||
#include "avcodec.h" | #include "avcodec.h" | ||||
#include "bytestream.h" | #include "bytestream.h" | ||||
#include "copy_block.h" | #include "copy_block.h" | ||||
#include "internal.h" | #include "internal.h" | ||||
#include "mathops.h" | |||||
#define PAF_SOUND_SAMPLES 2205 | |||||
#define PAF_SOUND_FRAME_SIZE ((256 + PAF_SOUND_SAMPLES) * 2) | |||||
static const uint8_t block_sequences[16][8] = { | static const uint8_t block_sequences[16][8] = { | ||||
{ 0, 0, 0, 0, 0, 0, 0, 0 }, { 2, 0, 0, 0, 0, 0, 0, 0 }, | { 0, 0, 0, 0, 0, 0, 0, 0 }, { 2, 0, 0, 0, 0, 0, 0, 0 }, | ||||
@@ -378,52 +373,6 @@ static int paf_video_decode(AVCodecContext *avctx, void *data, | |||||
return pkt->size; | return pkt->size; | ||||
} | } | ||||
static av_cold int paf_audio_init(AVCodecContext *avctx) | |||||
{ | |||||
if (avctx->channels != 2) { | |||||
av_log(avctx, AV_LOG_ERROR, "invalid number of channels\n"); | |||||
return AVERROR_INVALIDDATA; | |||||
} | |||||
avctx->channel_layout = AV_CH_LAYOUT_STEREO; | |||||
avctx->sample_fmt = AV_SAMPLE_FMT_S16; | |||||
return 0; | |||||
} | |||||
static int paf_audio_decode(AVCodecContext *avctx, void *data, | |||||
int *got_frame, AVPacket *pkt) | |||||
{ | |||||
AVFrame *frame = data; | |||||
int16_t *output_samples; | |||||
const uint8_t *src = pkt->data; | |||||
int frames, ret, i, j; | |||||
int16_t cb[256]; | |||||
frames = pkt->size / PAF_SOUND_FRAME_SIZE; | |||||
if (frames < 1) | |||||
return AVERROR_INVALIDDATA; | |||||
frame->nb_samples = PAF_SOUND_SAMPLES * frames; | |||||
if ((ret = ff_get_buffer(avctx, frame, 0)) < 0) | |||||
return ret; | |||||
output_samples = (int16_t *)frame->data[0]; | |||||
// codebook of 256 16-bit samples and 8-bit indices to it | |||||
for (j = 0; j < frames; j++) { | |||||
for (i = 0; i < 256; i++) | |||||
cb[i] = sign_extend(AV_RL16(src + i * 2), 16); | |||||
src += 256 * 2; | |||||
// always 2 channels | |||||
for (i = 0; i < PAF_SOUND_SAMPLES * 2; i++) | |||||
*output_samples++ = cb[*src++]; | |||||
} | |||||
*got_frame = 1; | |||||
return pkt->size; | |||||
} | |||||
#if CONFIG_PAF_VIDEO_DECODER | |||||
AVCodec ff_paf_video_decoder = { | AVCodec ff_paf_video_decoder = { | ||||
.name = "paf_video", | .name = "paf_video", | ||||
.long_name = NULL_IF_CONFIG_SMALL("Amazing Studio Packed Animation File Video"), | .long_name = NULL_IF_CONFIG_SMALL("Amazing Studio Packed Animation File Video"), | ||||
@@ -435,16 +384,3 @@ AVCodec ff_paf_video_decoder = { | |||||
.decode = paf_video_decode, | .decode = paf_video_decode, | ||||
.capabilities = CODEC_CAP_DR1, | .capabilities = CODEC_CAP_DR1, | ||||
}; | }; | ||||
#endif | |||||
#if CONFIG_PAF_AUDIO_DECODER | |||||
AVCodec ff_paf_audio_decoder = { | |||||
.name = "paf_audio", | |||||
.long_name = NULL_IF_CONFIG_SMALL("Amazing Studio Packed Animation File Audio"), | |||||
.type = AVMEDIA_TYPE_AUDIO, | |||||
.id = AV_CODEC_ID_PAF_AUDIO, | |||||
.init = paf_audio_init, | |||||
.decode = paf_audio_decode, | |||||
.capabilities = CODEC_CAP_DR1, | |||||
}; | |||||
#endif |