diff options
author | Mark Thompson <sw@jkqxz.net> | 2018-09-24 22:55:35 +0100 |
---|---|---|
committer | Mark Thompson <sw@jkqxz.net> | 2018-09-24 23:09:45 +0100 |
commit | 1215fbad96da6dc9f81cf335332fc7ebafd0c557 (patch) | |
tree | 80f2c2093acf8d91e50ace47ba43ac0136a690cc | |
parent | feb1cf08ab393070cd3d830dc7006100de487b74 (diff) | |
download | ffmpeg-1215fbad96da6dc9f81cf335332fc7ebafd0c557.tar.gz |
lavc/h265_profile_level: Fix level guessing with no PTL structure
Fixes CID #1439661.
-rw-r--r-- | libavcodec/h265_profile_level.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/libavcodec/h265_profile_level.c b/libavcodec/h265_profile_level.c index bc67fdc951..6604ca254d 100644 --- a/libavcodec/h265_profile_level.c +++ b/libavcodec/h265_profile_level.c @@ -175,7 +175,7 @@ const H265LevelDescriptor *ff_h265_guess_level(const H265RawProfileTierLevel *pt int max_dec_pic_buffering) { const H265ProfileDescriptor *profile; - int pic_size, hbr_factor; + int pic_size, lbr_flag, hbr_factor; int i; if (ptl) @@ -189,15 +189,19 @@ const H265LevelDescriptor *ff_h265_guess_level(const H265RawProfileTierLevel *pt pic_size = width * height; + if (ptl) + lbr_flag = ptl->general_lower_bit_rate_constraint_flag; + else + lbr_flag = profile->lower_bit_rate > 0; if (profile->profile_idc == 1 || profile->profile_idc == 2) { hbr_factor = 1; } else if (profile->high_throughput) { if (profile->intra) - hbr_factor = 24 - 12 * ptl->general_lower_bit_rate_constraint_flag; + hbr_factor = 24 - 12 * lbr_flag; else hbr_factor = 6; } else { - hbr_factor = 2 - ptl->general_lower_bit_rate_constraint_flag; + hbr_factor = 2 - lbr_flag; } for (i = 0; i < FF_ARRAY_ELEMS(h265_levels); i++) { @@ -218,7 +222,7 @@ const H265LevelDescriptor *ff_h265_guess_level(const H265RawProfileTierLevel *pt if (tile_cols > level->max_tile_cols) continue; - if (ptl->general_tier_flag) + if (ptl && ptl->general_tier_flag) max_br = level->max_br_high; else max_br = level->max_br_main; |