avcodec/decode: consistently set channel info when parsing param change side data
avctx->ch_layout was being left unchanged. Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
@ -104,15 +104,26 @@ FF_DISABLE_DEPRECATION_WARNINGS
|
|||||||
ret = AVERROR_INVALIDDATA;
|
ret = AVERROR_INVALIDDATA;
|
||||||
goto fail2;
|
goto fail2;
|
||||||
}
|
}
|
||||||
avctx->channels = val;
|
av_channel_layout_uninit(&avctx->ch_layout);
|
||||||
|
avctx->ch_layout.nb_channels = val;
|
||||||
|
avctx->ch_layout.order = AV_CHANNEL_ORDER_UNSPEC;
|
||||||
size -= 4;
|
size -= 4;
|
||||||
}
|
}
|
||||||
if (flags & AV_SIDE_DATA_PARAM_CHANGE_CHANNEL_LAYOUT) {
|
if (flags & AV_SIDE_DATA_PARAM_CHANGE_CHANNEL_LAYOUT) {
|
||||||
if (size < 8)
|
if (size < 8)
|
||||||
goto fail;
|
goto fail;
|
||||||
avctx->channel_layout = bytestream_get_le64(&data);
|
av_channel_layout_uninit(&avctx->ch_layout);
|
||||||
|
ret = av_channel_layout_from_mask(&avctx->ch_layout, bytestream_get_le64(&data));
|
||||||
|
if (ret < 0)
|
||||||
|
goto fail2;
|
||||||
size -= 8;
|
size -= 8;
|
||||||
}
|
}
|
||||||
|
if (flags & (AV_SIDE_DATA_PARAM_CHANGE_CHANNEL_COUNT |
|
||||||
|
AV_SIDE_DATA_PARAM_CHANGE_CHANNEL_LAYOUT)) {
|
||||||
|
avctx->channels = avctx->ch_layout.nb_channels;
|
||||||
|
avctx->channel_layout = (avctx->ch_layout.order == AV_CHANNEL_ORDER_NATIVE) ?
|
||||||
|
avctx->ch_layout.u.mask : 0;
|
||||||
|
}
|
||||||
FF_ENABLE_DEPRECATION_WARNINGS
|
FF_ENABLE_DEPRECATION_WARNINGS
|
||||||
#endif
|
#endif
|
||||||
if (flags & AV_SIDE_DATA_PARAM_CHANGE_SAMPLE_RATE) {
|
if (flags & AV_SIDE_DATA_PARAM_CHANGE_SAMPLE_RATE) {
|
||||||
|
Reference in New Issue
Block a user