mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
adpcm: convert ea_maxis_xa to bytestream2.
This commit is contained in:
parent
4a876eba8d
commit
e60d09918c
@ -413,7 +413,7 @@ static int get_nb_samples(AVCodecContext *avctx, const uint8_t *buf,
|
|||||||
nb_samples = (buf_size - (4 + 8 * ch)) * 2 / ch;
|
nb_samples = (buf_size - (4 + 8 * ch)) * 2 / ch;
|
||||||
break;
|
break;
|
||||||
case CODEC_ID_ADPCM_EA_MAXIS_XA:
|
case CODEC_ID_ADPCM_EA_MAXIS_XA:
|
||||||
nb_samples = ((buf_size - ch) / (2 * ch)) * 2 * ch;
|
nb_samples = (buf_size - ch) / ch * 2;
|
||||||
break;
|
break;
|
||||||
case CODEC_ID_ADPCM_EA_R1:
|
case CODEC_ID_ADPCM_EA_R1:
|
||||||
case CODEC_ID_ADPCM_EA_R2:
|
case CODEC_ID_ADPCM_EA_R2:
|
||||||
@ -921,15 +921,19 @@ static int adpcm_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
int coeff[2][2], shift[2];
|
int coeff[2][2], shift[2];
|
||||||
|
|
||||||
for(channel = 0; channel < avctx->channels; channel++) {
|
for(channel = 0; channel < avctx->channels; channel++) {
|
||||||
|
int byte = bytestream2_get_byteu(&gb);
|
||||||
for (i=0; i<2; i++)
|
for (i=0; i<2; i++)
|
||||||
coeff[channel][i] = ea_adpcm_table[(*src >> 4) + 4*i];
|
coeff[channel][i] = ea_adpcm_table[(byte >> 4) + 4*i];
|
||||||
shift[channel] = 20 - (*src & 0x0F);
|
shift[channel] = 20 - (byte & 0x0F);
|
||||||
src++;
|
|
||||||
}
|
}
|
||||||
for (count1 = 0; count1 < nb_samples / 2; count1++) {
|
for (count1 = 0; count1 < nb_samples / 2; count1++) {
|
||||||
|
int byte[2];
|
||||||
|
|
||||||
|
byte[0] = bytestream2_get_byteu(&gb);
|
||||||
|
if (st) byte[1] = bytestream2_get_byteu(&gb);
|
||||||
for(i = 4; i >= 0; i-=4) { /* Pairwise samples LL RR (st) or LL LL (mono) */
|
for(i = 4; i >= 0; i-=4) { /* Pairwise samples LL RR (st) or LL LL (mono) */
|
||||||
for(channel = 0; channel < avctx->channels; channel++) {
|
for(channel = 0; channel < avctx->channels; channel++) {
|
||||||
int32_t sample = sign_extend(src[channel] >> i, 4) << shift[channel];
|
int sample = sign_extend(byte[channel] >> i, 4) << shift[channel];
|
||||||
sample = (sample +
|
sample = (sample +
|
||||||
c->status[channel].sample1 * coeff[channel][0] +
|
c->status[channel].sample1 * coeff[channel][0] +
|
||||||
c->status[channel].sample2 * coeff[channel][1] + 0x80) >> 8;
|
c->status[channel].sample2 * coeff[channel][1] + 0x80) >> 8;
|
||||||
@ -938,10 +942,8 @@ static int adpcm_decode_frame(AVCodecContext *avctx, void *data,
|
|||||||
*samples++ = c->status[channel].sample1;
|
*samples++ = c->status[channel].sample1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
src+=avctx->channels;
|
|
||||||
}
|
}
|
||||||
/* consume whole packet */
|
bytestream2_seek(&gb, 0, SEEK_END);
|
||||||
src = buf + buf_size;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case CODEC_ID_ADPCM_EA_R1:
|
case CODEC_ID_ADPCM_EA_R1:
|
||||||
|
Loading…
Reference in New Issue
Block a user