mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2024-12-24 08:12:44 +00:00
hca: convert to new channel layout API
Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
parent
3928c4ae45
commit
b5b18440f1
@ -114,7 +114,7 @@ static av_cold int decode_init(AVCodecContext *avctx)
|
||||
avctx->sample_fmt = AV_SAMPLE_FMT_FLTP;
|
||||
c->crc_table = av_crc_get_table(AV_CRC_16_ANSI);
|
||||
|
||||
if (avctx->channels <= 0 || avctx->channels > 16)
|
||||
if (avctx->ch_layout.nb_channels <= 0 || avctx->ch_layout.nb_channels > 16)
|
||||
return AVERROR(EINVAL);
|
||||
|
||||
ret = init_get_bits8(gb, avctx->extradata, avctx->extradata_size);
|
||||
@ -194,7 +194,7 @@ static av_cold int decode_init(AVCodecContext *avctx)
|
||||
if (!c->track_count)
|
||||
c->track_count = 1;
|
||||
|
||||
b = avctx->channels / c->track_count;
|
||||
b = avctx->ch_layout.nb_channels / c->track_count;
|
||||
if (c->stereo_band_count && b > 1) {
|
||||
int8_t *x = r;
|
||||
|
||||
@ -239,7 +239,7 @@ static av_cold int decode_init(AVCodecContext *avctx)
|
||||
if (c->base_band_count + c->stereo_band_count + (unsigned long)c->hfr_group_count > 128ULL)
|
||||
return AVERROR_INVALIDDATA;
|
||||
|
||||
for (int i = 0; i < avctx->channels; i++) {
|
||||
for (int i = 0; i < avctx->ch_layout.nb_channels; i++) {
|
||||
c->ch[i].chan_type = r[i];
|
||||
c->ch[i].count = c->base_band_count + ((r[i] != 2) ? c->stereo_band_count : 0);
|
||||
c->ch[i].hfr_scale = &c->ch[i].scale_factors[c->base_band_count + c->stereo_band_count];
|
||||
@ -413,20 +413,20 @@ static int decode_frame(AVCodecContext *avctx, void *data,
|
||||
|
||||
packed_noise_level = (get_bits(gb, 9) << 8) - get_bits(gb, 7);
|
||||
|
||||
for (ch = 0; ch < avctx->channels; ch++)
|
||||
for (ch = 0; ch < avctx->ch_layout.nb_channels; ch++)
|
||||
unpack(c, &c->ch[ch], c->hfr_group_count, packed_noise_level, c->ath);
|
||||
|
||||
for (int i = 0; i < 8; i++) {
|
||||
for (ch = 0; ch < avctx->channels; ch++)
|
||||
for (ch = 0; ch < avctx->ch_layout.nb_channels; ch++)
|
||||
dequantize_coefficients(c, &c->ch[ch]);
|
||||
for (ch = 0; ch < avctx->channels; ch++)
|
||||
for (ch = 0; ch < avctx->ch_layout.nb_channels; ch++)
|
||||
reconstruct_hfr(c, &c->ch[ch], c->hfr_group_count, c->bands_per_hfr_group,
|
||||
c->stereo_band_count + c->base_band_count, c->total_band_count);
|
||||
for (ch = 0; ch < avctx->channels - 1; ch++)
|
||||
for (ch = 0; ch < avctx->ch_layout.nb_channels - 1; ch++)
|
||||
apply_intensity_stereo(c, &c->ch[ch], &c->ch[ch+1], i,
|
||||
c->total_band_count - c->base_band_count,
|
||||
c->base_band_count, c->stereo_band_count);
|
||||
for (ch = 0; ch < avctx->channels; ch++)
|
||||
for (ch = 0; ch < avctx->ch_layout.nb_channels; ch++)
|
||||
run_imdct(c, &c->ch[ch], i, samples[ch] + i * 128);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user