mirror of
https://github.com/nyanmisaka/ffmpeg-rockchip.git
synced 2025-10-08 18:21:14 +08:00
@@ -763,6 +763,7 @@ OBJS-$(CONFIG_ADPCM_G722_ENCODER) += g722.o g722dsp.o g722enc.o
|
|||||||
OBJS-$(CONFIG_ADPCM_G726_DECODER) += g726.o
|
OBJS-$(CONFIG_ADPCM_G726_DECODER) += g726.o
|
||||||
OBJS-$(CONFIG_ADPCM_G726_ENCODER) += g726.o
|
OBJS-$(CONFIG_ADPCM_G726_ENCODER) += g726.o
|
||||||
OBJS-$(CONFIG_ADPCM_G726LE_DECODER) += g726.o
|
OBJS-$(CONFIG_ADPCM_G726LE_DECODER) += g726.o
|
||||||
|
OBJS-$(CONFIG_ADPCM_G726LE_ENCODER) += g726.o
|
||||||
OBJS-$(CONFIG_ADPCM_IMA_AMV_DECODER) += adpcm.o adpcm_data.o
|
OBJS-$(CONFIG_ADPCM_IMA_AMV_DECODER) += adpcm.o adpcm_data.o
|
||||||
OBJS-$(CONFIG_ADPCM_IMA_APC_DECODER) += adpcm.o adpcm_data.o
|
OBJS-$(CONFIG_ADPCM_IMA_APC_DECODER) += adpcm.o adpcm_data.o
|
||||||
OBJS-$(CONFIG_ADPCM_IMA_DAT4_DECODER) += adpcm.o adpcm_data.o
|
OBJS-$(CONFIG_ADPCM_IMA_DAT4_DECODER) += adpcm.o adpcm_data.o
|
||||||
|
@@ -549,7 +549,7 @@ static void register_all(void)
|
|||||||
REGISTER_DECODER(ADPCM_EA_XAS, adpcm_ea_xas);
|
REGISTER_DECODER(ADPCM_EA_XAS, adpcm_ea_xas);
|
||||||
REGISTER_ENCDEC (ADPCM_G722, adpcm_g722);
|
REGISTER_ENCDEC (ADPCM_G722, adpcm_g722);
|
||||||
REGISTER_ENCDEC (ADPCM_G726, adpcm_g726);
|
REGISTER_ENCDEC (ADPCM_G726, adpcm_g726);
|
||||||
REGISTER_DECODER(ADPCM_G726LE, adpcm_g726le);
|
REGISTER_ENCDEC (ADPCM_G726LE, adpcm_g726le);
|
||||||
REGISTER_DECODER(ADPCM_IMA_AMV, adpcm_ima_amv);
|
REGISTER_DECODER(ADPCM_IMA_AMV, adpcm_ima_amv);
|
||||||
REGISTER_DECODER(ADPCM_IMA_APC, adpcm_ima_apc);
|
REGISTER_DECODER(ADPCM_IMA_APC, adpcm_ima_apc);
|
||||||
REGISTER_DECODER(ADPCM_IMA_DAT4, adpcm_ima_dat4);
|
REGISTER_DECODER(ADPCM_IMA_DAT4, adpcm_ima_dat4);
|
||||||
|
@@ -292,7 +292,7 @@ static av_cold int g726_reset(G726Context *c)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if CONFIG_ADPCM_G726_ENCODER
|
#if CONFIG_ADPCM_G726_ENCODER || CONFIG_ADPCM_G726LE_ENCODER
|
||||||
static int16_t g726_encode(G726Context* c, int16_t sig)
|
static int16_t g726_encode(G726Context* c, int16_t sig)
|
||||||
{
|
{
|
||||||
uint8_t i;
|
uint8_t i;
|
||||||
@@ -308,6 +308,8 @@ static av_cold int g726_encode_init(AVCodecContext *avctx)
|
|||||||
{
|
{
|
||||||
G726Context* c = avctx->priv_data;
|
G726Context* c = avctx->priv_data;
|
||||||
|
|
||||||
|
c->little_endian = !strcmp(avctx->codec->name, "g726le");
|
||||||
|
|
||||||
if (avctx->strict_std_compliance > FF_COMPLIANCE_UNOFFICIAL &&
|
if (avctx->strict_std_compliance > FF_COMPLIANCE_UNOFFICIAL &&
|
||||||
avctx->sample_rate != 8000) {
|
avctx->sample_rate != 8000) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "Sample rates other than 8kHz are not "
|
av_log(avctx, AV_LOG_ERROR, "Sample rates other than 8kHz are not "
|
||||||
@@ -356,9 +358,17 @@ static int g726_encode_frame(AVCodecContext *avctx, AVPacket *avpkt,
|
|||||||
init_put_bits(&pb, avpkt->data, avpkt->size);
|
init_put_bits(&pb, avpkt->data, avpkt->size);
|
||||||
|
|
||||||
for (i = 0; i < frame->nb_samples; i++)
|
for (i = 0; i < frame->nb_samples; i++)
|
||||||
|
if (c->little_endian) {
|
||||||
|
put_bits_le(&pb, c->code_size, g726_encode(c, *samples++));
|
||||||
|
} else {
|
||||||
put_bits(&pb, c->code_size, g726_encode(c, *samples++));
|
put_bits(&pb, c->code_size, g726_encode(c, *samples++));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (c->little_endian) {
|
||||||
|
flush_put_bits_le(&pb);
|
||||||
|
} else {
|
||||||
flush_put_bits(&pb);
|
flush_put_bits(&pb);
|
||||||
|
}
|
||||||
|
|
||||||
avpkt->size = out_size;
|
avpkt->size = out_size;
|
||||||
*got_packet_ptr = 1;
|
*got_packet_ptr = 1;
|
||||||
@@ -372,6 +382,13 @@ static const AVOption options[] = {
|
|||||||
{ NULL },
|
{ NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const AVCodecDefault defaults[] = {
|
||||||
|
{ "b", "0" },
|
||||||
|
{ NULL },
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_ADPCM_G726_ENCODER
|
||||||
static const AVClass g726_class = {
|
static const AVClass g726_class = {
|
||||||
.class_name = "g726",
|
.class_name = "g726",
|
||||||
.item_name = av_default_item_name,
|
.item_name = av_default_item_name,
|
||||||
@@ -379,11 +396,6 @@ static const AVClass g726_class = {
|
|||||||
.version = LIBAVUTIL_VERSION_INT,
|
.version = LIBAVUTIL_VERSION_INT,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const AVCodecDefault defaults[] = {
|
|
||||||
{ "b", "0" },
|
|
||||||
{ NULL },
|
|
||||||
};
|
|
||||||
|
|
||||||
AVCodec ff_adpcm_g726_encoder = {
|
AVCodec ff_adpcm_g726_encoder = {
|
||||||
.name = "g726",
|
.name = "g726",
|
||||||
.long_name = NULL_IF_CONFIG_SMALL("G.726 ADPCM"),
|
.long_name = NULL_IF_CONFIG_SMALL("G.726 ADPCM"),
|
||||||
@@ -400,6 +412,30 @@ AVCodec ff_adpcm_g726_encoder = {
|
|||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_ADPCM_G726LE_ENCODER
|
||||||
|
static const AVClass g726le_class = {
|
||||||
|
.class_name = "g726le",
|
||||||
|
.item_name = av_default_item_name,
|
||||||
|
.option = options,
|
||||||
|
.version = LIBAVUTIL_VERSION_INT,
|
||||||
|
};
|
||||||
|
|
||||||
|
AVCodec ff_adpcm_g726le_encoder = {
|
||||||
|
.name = "g726le",
|
||||||
|
.long_name = NULL_IF_CONFIG_SMALL("G.726 little endian ADPCM (\"right-justified\")"),
|
||||||
|
.type = AVMEDIA_TYPE_AUDIO,
|
||||||
|
.id = AV_CODEC_ID_ADPCM_G726LE,
|
||||||
|
.priv_data_size = sizeof(G726Context),
|
||||||
|
.init = g726_encode_init,
|
||||||
|
.encode2 = g726_encode_frame,
|
||||||
|
.capabilities = AV_CODEC_CAP_SMALL_LAST_FRAME,
|
||||||
|
.sample_fmts = (const enum AVSampleFormat[]){ AV_SAMPLE_FMT_S16,
|
||||||
|
AV_SAMPLE_FMT_NONE },
|
||||||
|
.priv_class = &g726le_class,
|
||||||
|
.defaults = defaults,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
#if CONFIG_ADPCM_G726_DECODER || CONFIG_ADPCM_G726LE_DECODER
|
#if CONFIG_ADPCM_G726_DECODER || CONFIG_ADPCM_G726LE_DECODER
|
||||||
static av_cold int g726_decode_init(AVCodecContext *avctx)
|
static av_cold int g726_decode_init(AVCodecContext *avctx)
|
||||||
{
|
{
|
||||||
|
@@ -119,6 +119,18 @@ static inline void flush_put_bits(PutBitContext *s)
|
|||||||
s->bit_buf = 0;
|
s->bit_buf = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void flush_put_bits_le(PutBitContext *s)
|
||||||
|
{
|
||||||
|
while (s->bit_left < 32) {
|
||||||
|
av_assert0(s->buf_ptr < s->buf_end);
|
||||||
|
*s->buf_ptr++ = s->bit_buf;
|
||||||
|
s->bit_buf >>= 8;
|
||||||
|
s->bit_left += 8;
|
||||||
|
}
|
||||||
|
s->bit_left = 32;
|
||||||
|
s->bit_buf = 0;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef BITSTREAM_WRITER_LE
|
#ifdef BITSTREAM_WRITER_LE
|
||||||
#define avpriv_align_put_bits align_put_bits_unsupported_here
|
#define avpriv_align_put_bits align_put_bits_unsupported_here
|
||||||
#define avpriv_put_string ff_put_string_unsupported_here
|
#define avpriv_put_string ff_put_string_unsupported_here
|
||||||
@@ -197,6 +209,34 @@ static inline void put_bits(PutBitContext *s, int n, unsigned int value)
|
|||||||
s->bit_left = bit_left;
|
s->bit_left = bit_left;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void put_bits_le(PutBitContext *s, int n, unsigned int value)
|
||||||
|
{
|
||||||
|
unsigned int bit_buf;
|
||||||
|
int bit_left;
|
||||||
|
|
||||||
|
av_assert2(n <= 31 && value < (1U << n));
|
||||||
|
|
||||||
|
bit_buf = s->bit_buf;
|
||||||
|
bit_left = s->bit_left;
|
||||||
|
|
||||||
|
bit_buf |= value << (32 - bit_left);
|
||||||
|
if (n >= bit_left) {
|
||||||
|
if (3 < s->buf_end - s->buf_ptr) {
|
||||||
|
AV_WL32(s->buf_ptr, bit_buf);
|
||||||
|
s->buf_ptr += 4;
|
||||||
|
} else {
|
||||||
|
av_log(NULL, AV_LOG_ERROR, "Internal error, put_bits buffer too small\n");
|
||||||
|
av_assert2(0);
|
||||||
|
}
|
||||||
|
bit_buf = value >> bit_left;
|
||||||
|
bit_left += 32;
|
||||||
|
}
|
||||||
|
bit_left -= n;
|
||||||
|
|
||||||
|
s->bit_buf = bit_buf;
|
||||||
|
s->bit_left = bit_left;
|
||||||
|
}
|
||||||
|
|
||||||
static inline void put_sbits(PutBitContext *pb, int n, int32_t value)
|
static inline void put_sbits(PutBitContext *pb, int n, int32_t value)
|
||||||
{
|
{
|
||||||
av_assert2(n >= 0 && n <= 31);
|
av_assert2(n >= 0 && n <= 31);
|
||||||
|
@@ -28,7 +28,7 @@
|
|||||||
#include "libavutil/version.h"
|
#include "libavutil/version.h"
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_MAJOR 57
|
#define LIBAVCODEC_VERSION_MAJOR 57
|
||||||
#define LIBAVCODEC_VERSION_MINOR 102
|
#define LIBAVCODEC_VERSION_MINOR 103
|
||||||
#define LIBAVCODEC_VERSION_MICRO 100
|
#define LIBAVCODEC_VERSION_MICRO 100
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
||||||
|
Reference in New Issue
Block a user