| @@ -21,9 +21,12 @@ | |||
| #include <vo-amrwbenc/enc_if.h> | |||
| #include "avcodec.h" | |||
| #include "libavutil/avstring.h" | |||
| #include "libavutil/opt.h" | |||
| #include "avcodec.h" | |||
| #include "internal.h" | |||
| #define MAX_PACKET_SIZE (1 + (477 + 7) / 8) | |||
| typedef struct AMRWBContext { | |||
| AVClass *av_class; | |||
| @@ -86,9 +89,12 @@ static av_cold int amr_wb_encode_init(AVCodecContext *avctx) | |||
| s->last_bitrate = avctx->bit_rate; | |||
| avctx->frame_size = 320; | |||
| avctx->delay = 80; | |||
| #if FF_API_OLD_ENCODE_AUDIO | |||
| avctx->coded_frame = avcodec_alloc_frame(); | |||
| if (!avctx->coded_frame) | |||
| return AVERROR(ENOMEM); | |||
| #endif | |||
| s->state = E_IF_init(); | |||
| @@ -104,19 +110,34 @@ static int amr_wb_encode_close(AVCodecContext *avctx) | |||
| return 0; | |||
| } | |||
| static int amr_wb_encode_frame(AVCodecContext *avctx, | |||
| unsigned char *frame/*out*/, | |||
| int buf_size, void *data/*in*/) | |||
| static int amr_wb_encode_frame(AVCodecContext *avctx, AVPacket *avpkt, | |||
| const AVFrame *frame, int *got_packet_ptr) | |||
| { | |||
| AMRWBContext *s = avctx->priv_data; | |||
| int size; | |||
| const int16_t *samples = (const int16_t *)frame->data[0]; | |||
| int size, ret; | |||
| if ((ret = ff_alloc_packet(avpkt, MAX_PACKET_SIZE))) { | |||
| av_log(avctx, AV_LOG_ERROR, "Error getting output packet\n"); | |||
| return ret; | |||
| } | |||
| if (s->last_bitrate != avctx->bit_rate) { | |||
| s->mode = get_wb_bitrate_mode(avctx->bit_rate, avctx); | |||
| s->last_bitrate = avctx->bit_rate; | |||
| } | |||
| size = E_IF_encode(s->state, s->mode, data, frame, s->allow_dtx); | |||
| return size; | |||
| size = E_IF_encode(s->state, s->mode, samples, avpkt->data, s->allow_dtx); | |||
| if (size <= 0 || size > MAX_PACKET_SIZE) { | |||
| av_log(avctx, AV_LOG_ERROR, "Error encoding frame\n"); | |||
| return AVERROR(EINVAL); | |||
| } | |||
| if (frame->pts != AV_NOPTS_VALUE) | |||
| avpkt->pts = frame->pts - ff_samples_to_time_base(avctx, avctx->delay); | |||
| avpkt->size = size; | |||
| *got_packet_ptr = 1; | |||
| return 0; | |||
| } | |||
| AVCodec ff_libvo_amrwbenc_encoder = { | |||
| @@ -125,7 +146,7 @@ AVCodec ff_libvo_amrwbenc_encoder = { | |||
| .id = CODEC_ID_AMR_WB, | |||
| .priv_data_size = sizeof(AMRWBContext), | |||
| .init = amr_wb_encode_init, | |||
| .encode = amr_wb_encode_frame, | |||
| .encode2 = amr_wb_encode_frame, | |||
| .close = amr_wb_encode_close, | |||
| .sample_fmts = (const enum AVSampleFormat[]){AV_SAMPLE_FMT_S16,AV_SAMPLE_FMT_NONE}, | |||
| .long_name = NULL_IF_CONFIG_SMALL("Android VisualOn Adaptive Multi-Rate " | |||