|
|
|
@@ -34,8 +34,6 @@ |
|
|
|
|
|
|
|
static av_cold int gsm_init(AVCodecContext *avctx) |
|
|
|
{ |
|
|
|
GSMContext *s = avctx->priv_data; |
|
|
|
|
|
|
|
avctx->channels = 1; |
|
|
|
avctx->channel_layout = AV_CH_LAYOUT_MONO; |
|
|
|
avctx->sample_rate = 8000; |
|
|
|
@@ -51,16 +49,13 @@ static av_cold int gsm_init(AVCodecContext *avctx) |
|
|
|
avctx->block_align = GSM_MS_BLOCK_SIZE; |
|
|
|
} |
|
|
|
|
|
|
|
avcodec_get_frame_defaults(&s->frame); |
|
|
|
avctx->coded_frame = &s->frame; |
|
|
|
|
|
|
|
return 0; |
|
|
|
} |
|
|
|
|
|
|
|
static int gsm_decode_frame(AVCodecContext *avctx, void *data, |
|
|
|
int *got_frame_ptr, AVPacket *avpkt) |
|
|
|
{ |
|
|
|
GSMContext *s = avctx->priv_data; |
|
|
|
AVFrame *frame = data; |
|
|
|
int res; |
|
|
|
GetBitContext gb; |
|
|
|
const uint8_t *buf = avpkt->data; |
|
|
|
@@ -73,12 +68,12 @@ static int gsm_decode_frame(AVCodecContext *avctx, void *data, |
|
|
|
} |
|
|
|
|
|
|
|
/* get output buffer */ |
|
|
|
s->frame.nb_samples = avctx->frame_size; |
|
|
|
if ((res = ff_get_buffer(avctx, &s->frame)) < 0) { |
|
|
|
frame->nb_samples = avctx->frame_size; |
|
|
|
if ((res = ff_get_buffer(avctx, frame)) < 0) { |
|
|
|
av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); |
|
|
|
return res; |
|
|
|
} |
|
|
|
samples = (int16_t *)s->frame.data[0]; |
|
|
|
samples = (int16_t *)frame->data[0]; |
|
|
|
|
|
|
|
switch (avctx->codec_id) { |
|
|
|
case AV_CODEC_ID_GSM: |
|
|
|
@@ -95,8 +90,7 @@ static int gsm_decode_frame(AVCodecContext *avctx, void *data, |
|
|
|
return res; |
|
|
|
} |
|
|
|
|
|
|
|
*got_frame_ptr = 1; |
|
|
|
*(AVFrame *)data = s->frame; |
|
|
|
*got_frame_ptr = 1; |
|
|
|
|
|
|
|
return avctx->block_align; |
|
|
|
} |
|
|
|
|