mirror of
https://gitee.com/openharmony/third_party_ffmpeg
synced 2024-11-27 05:00:37 +00:00
avcodec/hevc_ps: Remove gotos from ff_hevc_parse_sps()
They are currently unnecessary Found-by: James Almer <jamrial@gmail.com> Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
parent
4a5074d798
commit
15893adbdb
@ -756,35 +756,31 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
sps->vps_id = get_bits(gb, 4);
|
||||
if (sps->vps_id >= MAX_VPS_COUNT) {
|
||||
av_log(avctx, AV_LOG_ERROR, "VPS id out of range: %d\n", sps->vps_id);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
if (vps_list && !vps_list[sps->vps_id]) {
|
||||
av_log(avctx, AV_LOG_ERROR, "VPS %d does not exist\n",
|
||||
sps->vps_id);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
sps->max_sub_layers = get_bits(gb, 3) + 1;
|
||||
if (sps->max_sub_layers > MAX_SUB_LAYERS) {
|
||||
av_log(avctx, AV_LOG_ERROR, "sps_max_sub_layers out of range: %d\n",
|
||||
sps->max_sub_layers);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
skip_bits1(gb); // temporal_id_nesting_flag
|
||||
|
||||
if ((ret = parse_ptl(gb, avctx, &sps->ptl, sps->max_sub_layers)) < 0)
|
||||
goto err;
|
||||
return ret;
|
||||
|
||||
*sps_id = get_ue_golomb_long(gb);
|
||||
if (*sps_id >= MAX_SPS_COUNT) {
|
||||
av_log(avctx, AV_LOG_ERROR, "SPS id out of range: %d\n", *sps_id);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
sps->chroma_format_idc = get_ue_golomb_long(gb);
|
||||
@ -799,7 +795,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
sps->height = get_ue_golomb_long(gb);
|
||||
if ((ret = av_image_check_size(sps->width,
|
||||
sps->height, 0, avctx)) < 0)
|
||||
goto err;
|
||||
return ret;
|
||||
|
||||
if (get_bits1(gb)) { // pic_conformance_flag
|
||||
//TODO: * 2 is only valid for 420
|
||||
@ -832,8 +828,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
"Luma bit depth (%d) is different from chroma bit depth (%d), "
|
||||
"this is unsupported.\n",
|
||||
sps->bit_depth, bit_depth_chroma);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
switch (sps->bit_depth) {
|
||||
@ -864,14 +859,12 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
default:
|
||||
av_log(avctx, AV_LOG_ERROR,
|
||||
"4:2:0, 4:2:2, 4:4:4 supports are currently specified for 8, 10 and 12 bits.\n");
|
||||
ret = AVERROR_PATCHWELCOME;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
desc = av_pix_fmt_desc_get(sps->pix_fmt);
|
||||
if (!desc) {
|
||||
ret = AVERROR(EINVAL);
|
||||
goto err;
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
|
||||
sps->hshift[0] = sps->vshift[0] = 0;
|
||||
@ -884,8 +877,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
if (sps->log2_max_poc_lsb > 16) {
|
||||
av_log(avctx, AV_LOG_ERROR, "log2_max_pic_order_cnt_lsb_minus4 out range: %d\n",
|
||||
sps->log2_max_poc_lsb - 4);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
sublayer_ordering_info = get_bits1(gb);
|
||||
@ -897,16 +889,14 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
if (sps->temporal_layer[i].max_dec_pic_buffering > MAX_DPB_SIZE) {
|
||||
av_log(avctx, AV_LOG_ERROR, "sps_max_dec_pic_buffering_minus1 out of range: %d\n",
|
||||
sps->temporal_layer[i].max_dec_pic_buffering - 1);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
if (sps->temporal_layer[i].num_reorder_pics > sps->temporal_layer[i].max_dec_pic_buffering - 1) {
|
||||
av_log(avctx, AV_LOG_WARNING, "sps_max_num_reorder_pics out of range: %d\n",
|
||||
sps->temporal_layer[i].num_reorder_pics);
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE ||
|
||||
sps->temporal_layer[i].num_reorder_pics > MAX_DPB_SIZE - 1) {
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
sps->temporal_layer[i].max_dec_pic_buffering = sps->temporal_layer[i].num_reorder_pics + 1;
|
||||
}
|
||||
@ -929,26 +919,22 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
|
||||
if (sps->log2_min_cb_size < 3 || sps->log2_min_cb_size > 30) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Invalid value %d for log2_min_cb_size", sps->log2_min_cb_size);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
if (sps->log2_diff_max_min_coding_block_size > 30) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Invalid value %d for log2_diff_max_min_coding_block_size", sps->log2_diff_max_min_coding_block_size);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
if (sps->log2_min_tb_size >= sps->log2_min_cb_size || sps->log2_min_tb_size < 2) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Invalid value for log2_min_tb_size");
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
if (log2_diff_max_min_transform_block_size < 0 || log2_diff_max_min_transform_block_size > 30) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Invalid value %d for log2_diff_max_min_transform_block_size", log2_diff_max_min_transform_block_size);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
sps->max_transform_hierarchy_depth_inter = get_ue_golomb_long(gb);
|
||||
@ -961,7 +947,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
if (get_bits1(gb)) {
|
||||
ret = scaling_list_data(gb, avctx, &sps->scaling_list, sps);
|
||||
if (ret < 0)
|
||||
goto err;
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
||||
@ -979,8 +965,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
av_log(avctx, AV_LOG_ERROR,
|
||||
"PCM bit depth (%d) is greater than normal bit depth (%d)\n",
|
||||
sps->pcm.bit_depth, sps->bit_depth);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
sps->pcm.loop_filter_disable_flag = get_bits1(gb);
|
||||
@ -990,15 +975,13 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
if (sps->nb_st_rps > MAX_SHORT_TERM_RPS_COUNT) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Too many short term RPS: %d.\n",
|
||||
sps->nb_st_rps);
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
for (i = 0; i < sps->nb_st_rps; i++) {
|
||||
if ((ret = ff_hevc_decode_short_term_rps(gb, avctx, &sps->st_rps[i],
|
||||
sps, 0)) < 0)
|
||||
goto err;
|
||||
return ret;
|
||||
}
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
|
||||
sps->long_term_ref_pics_present_flag = get_bits1(gb);
|
||||
if (sps->long_term_ref_pics_present_flag) {
|
||||
@ -1006,7 +989,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
if (sps->num_long_term_ref_pics_sps > 31U) {
|
||||
av_log(avctx, AV_LOG_ERROR, "num_long_term_ref_pics_sps %d is out of range.\n",
|
||||
sps->num_long_term_ref_pics_sps);
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
for (i = 0; i < sps->num_long_term_ref_pics_sps; i++) {
|
||||
sps->lt_ref_pic_poc_lsb_sps[i] = get_bits(gb, sps->log2_max_poc_lsb);
|
||||
@ -1078,8 +1061,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
av_log(avctx, AV_LOG_WARNING, "Invalid visible frame dimensions: %dx%d.\n",
|
||||
sps->output_width, sps->output_height);
|
||||
if (avctx->err_recognition & AV_EF_EXPLODE) {
|
||||
ret = AVERROR_INVALIDDATA;
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
av_log(avctx, AV_LOG_WARNING,
|
||||
"Displaying the whole video surface.\n");
|
||||
@ -1096,7 +1078,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
|
||||
if (sps->log2_ctb_size > MAX_LOG2_CTB_SIZE) {
|
||||
av_log(avctx, AV_LOG_ERROR, "CTB size out of range: 2^%d\n", sps->log2_ctb_size);
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
if (sps->log2_ctb_size < 4) {
|
||||
av_log(avctx,
|
||||
@ -1104,7 +1086,7 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
"log2_ctb_size %d differs from the bounds of any known profile\n",
|
||||
sps->log2_ctb_size);
|
||||
avpriv_request_sample(avctx, "log2_ctb_size %d", sps->log2_ctb_size);
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
sps->ctb_width = (sps->width + (1 << sps->log2_ctb_size) - 1) >> sps->log2_ctb_size;
|
||||
@ -1124,36 +1106,33 @@ int ff_hevc_parse_sps(HEVCSPS *sps, GetBitContext *gb, unsigned int *sps_id,
|
||||
if (av_mod_uintp2(sps->width, sps->log2_min_cb_size) ||
|
||||
av_mod_uintp2(sps->height, sps->log2_min_cb_size)) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Invalid coded frame dimensions.\n");
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
if (sps->max_transform_hierarchy_depth_inter > sps->log2_ctb_size - sps->log2_min_tb_size) {
|
||||
av_log(avctx, AV_LOG_ERROR, "max_transform_hierarchy_depth_inter out of range: %d\n",
|
||||
sps->max_transform_hierarchy_depth_inter);
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
if (sps->max_transform_hierarchy_depth_intra > sps->log2_ctb_size - sps->log2_min_tb_size) {
|
||||
av_log(avctx, AV_LOG_ERROR, "max_transform_hierarchy_depth_intra out of range: %d\n",
|
||||
sps->max_transform_hierarchy_depth_intra);
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
if (sps->log2_max_trafo_size > FFMIN(sps->log2_ctb_size, 5)) {
|
||||
av_log(avctx, AV_LOG_ERROR,
|
||||
"max transform block size out of range: %d\n",
|
||||
sps->log2_max_trafo_size);
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
if (get_bits_left(gb) < 0) {
|
||||
av_log(avctx, AV_LOG_ERROR,
|
||||
"Overread SPS by %d bits\n", -get_bits_left(gb));
|
||||
goto err;
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
||||
err:
|
||||
return ret;
|
||||
}
|
||||
|
||||
int ff_hevc_decode_nal_sps(HEVCContext *s)
|
||||
|
Loading…
Reference in New Issue
Block a user