mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-12 18:31:37 +00:00
lavc/vvc: Validate explicit subpic locations
Implement the missing requirements from H.266 (V3) p. 106 on the position and size of subpictures whose dimensions are provided explicitly. Signed-off-by: Frank Plowman <post@frankplowman.com>
This commit is contained in:
parent
01701bdcd5
commit
93281630a7
@ -1061,7 +1061,7 @@ static int FUNC(sps)(CodedBitstreamContext *ctx, RWContext *rw,
|
|||||||
unsigned int ctb_log2_size_y, min_cb_log2_size_y,
|
unsigned int ctb_log2_size_y, min_cb_log2_size_y,
|
||||||
min_qt_log2_size_intra_y, min_qt_log2_size_inter_y,
|
min_qt_log2_size_intra_y, min_qt_log2_size_inter_y,
|
||||||
ctb_size_y, max_num_merge_cand, tmp_width_val, tmp_height_val;
|
ctb_size_y, max_num_merge_cand, tmp_width_val, tmp_height_val;
|
||||||
uint8_t qp_bd_offset;
|
uint8_t qp_bd_offset, sub_width_c, sub_height_c;
|
||||||
|
|
||||||
static const uint8_t h266_sub_width_c[] = {
|
static const uint8_t h266_sub_width_c[] = {
|
||||||
1, 2, 2, 1
|
1, 2, 2, 1
|
||||||
@ -1089,6 +1089,9 @@ static int FUNC(sps)(CodedBitstreamContext *ctx, RWContext *rw,
|
|||||||
|
|
||||||
u(3, sps_max_sublayers_minus1, 0, VVC_MAX_SUBLAYERS - 1);
|
u(3, sps_max_sublayers_minus1, 0, VVC_MAX_SUBLAYERS - 1);
|
||||||
u(2, sps_chroma_format_idc, 0, 3);
|
u(2, sps_chroma_format_idc, 0, 3);
|
||||||
|
sub_width_c = h266_sub_width_c[current->sps_chroma_format_idc];
|
||||||
|
sub_height_c = h266_sub_height_c[current->sps_chroma_format_idc];
|
||||||
|
|
||||||
u(2, sps_log2_ctu_size_minus5, 0, 3);
|
u(2, sps_log2_ctu_size_minus5, 0, 3);
|
||||||
ctb_log2_size_y = current->sps_log2_ctu_size_minus5 + 5;
|
ctb_log2_size_y = current->sps_log2_ctu_size_minus5 + 5;
|
||||||
ctb_size_y = 1 << ctb_log2_size_y;
|
ctb_size_y = 1 << ctb_log2_size_y;
|
||||||
@ -1110,8 +1113,6 @@ static int FUNC(sps)(CodedBitstreamContext *ctx, RWContext *rw,
|
|||||||
|
|
||||||
flag(sps_conformance_window_flag);
|
flag(sps_conformance_window_flag);
|
||||||
if (current->sps_conformance_window_flag) {
|
if (current->sps_conformance_window_flag) {
|
||||||
uint8_t sub_width_c = h266_sub_width_c[current->sps_chroma_format_idc];
|
|
||||||
uint8_t sub_height_c = h266_sub_height_c[current->sps_chroma_format_idc];
|
|
||||||
uint16_t width = current->sps_pic_width_max_in_luma_samples / sub_width_c;
|
uint16_t width = current->sps_pic_width_max_in_luma_samples / sub_width_c;
|
||||||
uint16_t height = current->sps_pic_height_max_in_luma_samples / sub_height_c;
|
uint16_t height = current->sps_pic_height_max_in_luma_samples / sub_height_c;
|
||||||
ue(sps_conf_win_left_offset, 0, width);
|
ue(sps_conf_win_left_offset, 0, width);
|
||||||
@ -1160,19 +1161,37 @@ static int FUNC(sps)(CodedBitstreamContext *ctx, RWContext *rw,
|
|||||||
}
|
}
|
||||||
for (i = 1; i <= current->sps_num_subpics_minus1; i++) {
|
for (i = 1; i <= current->sps_num_subpics_minus1; i++) {
|
||||||
if (!current->sps_subpic_same_size_flag) {
|
if (!current->sps_subpic_same_size_flag) {
|
||||||
if (current->sps_pic_width_max_in_luma_samples > ctb_size_y)
|
if (current->sps_pic_width_max_in_luma_samples > ctb_size_y) {
|
||||||
ubs(wlen, sps_subpic_ctu_top_left_x[i], 1, i);
|
const unsigned int win_right_edge =
|
||||||
else
|
current->sps_pic_width_max_in_luma_samples
|
||||||
|
- current->sps_conf_win_right_offset * sub_width_c;
|
||||||
|
us(wlen, sps_subpic_ctu_top_left_x[i], 0,
|
||||||
|
AV_CEIL_RSHIFT(win_right_edge, ctb_log2_size_y) - 1,
|
||||||
|
1, i);
|
||||||
|
} else
|
||||||
infer(sps_subpic_ctu_top_left_x[i], 0);
|
infer(sps_subpic_ctu_top_left_x[i], 0);
|
||||||
if (current->sps_pic_height_max_in_luma_samples >
|
if (current->sps_pic_height_max_in_luma_samples >
|
||||||
ctb_size_y)
|
ctb_size_y) {
|
||||||
ubs(hlen, sps_subpic_ctu_top_left_y[i], 1, i);
|
const unsigned int win_bottom_edge =
|
||||||
else
|
current->sps_pic_height_max_in_luma_samples
|
||||||
|
- current->sps_conf_win_bottom_offset * sub_height_c;
|
||||||
|
us(hlen, sps_subpic_ctu_top_left_y[i], 0,
|
||||||
|
AV_CEIL_RSHIFT(win_bottom_edge, ctb_log2_size_y) - 1,
|
||||||
|
1, i);
|
||||||
|
} else
|
||||||
infer(sps_subpic_ctu_top_left_y[i], 0);
|
infer(sps_subpic_ctu_top_left_y[i], 0);
|
||||||
if (i < current->sps_num_subpics_minus1 &&
|
if (i < current->sps_num_subpics_minus1 &&
|
||||||
current->sps_pic_width_max_in_luma_samples >
|
current->sps_pic_width_max_in_luma_samples >
|
||||||
ctb_size_y) {
|
ctb_size_y) {
|
||||||
ubs(wlen, sps_subpic_width_minus1[i], 1, i);
|
const unsigned int win_left_edge =
|
||||||
|
current->sps_conf_win_left_offset * sub_width_c;
|
||||||
|
const unsigned int win_left_edge_ctus =
|
||||||
|
AV_CEIL_RSHIFT(win_left_edge, ctb_log2_size_y);
|
||||||
|
us(wlen, sps_subpic_width_minus1[i],
|
||||||
|
win_left_edge_ctus > current->sps_subpic_ctu_top_left_x[i]
|
||||||
|
? win_left_edge_ctus - current->sps_subpic_ctu_top_left_x[i]
|
||||||
|
: 0,
|
||||||
|
MAX_UINT_BITS(wlen), 1, i);
|
||||||
} else {
|
} else {
|
||||||
infer(sps_subpic_width_minus1[i],
|
infer(sps_subpic_width_minus1[i],
|
||||||
tmp_width_val -
|
tmp_width_val -
|
||||||
@ -1181,7 +1200,15 @@ static int FUNC(sps)(CodedBitstreamContext *ctx, RWContext *rw,
|
|||||||
if (i < current->sps_num_subpics_minus1 &&
|
if (i < current->sps_num_subpics_minus1 &&
|
||||||
current->sps_pic_height_max_in_luma_samples >
|
current->sps_pic_height_max_in_luma_samples >
|
||||||
ctb_size_y) {
|
ctb_size_y) {
|
||||||
ubs(hlen, sps_subpic_height_minus1[i], 1, i);
|
const unsigned int win_top_edge =
|
||||||
|
current->sps_conf_win_top_offset * sub_height_c;
|
||||||
|
const unsigned int win_top_edge_ctus =
|
||||||
|
AV_CEIL_RSHIFT(win_top_edge, ctb_log2_size_y);
|
||||||
|
us(hlen, sps_subpic_height_minus1[i],
|
||||||
|
win_top_edge_ctus > current->sps_subpic_ctu_top_left_y[i]
|
||||||
|
? win_top_edge_ctus - current->sps_subpic_ctu_top_left_y[i]
|
||||||
|
: 0,
|
||||||
|
MAX_UINT_BITS(wlen), 1, i);
|
||||||
} else {
|
} else {
|
||||||
infer(sps_subpic_height_minus1[i],
|
infer(sps_subpic_height_minus1[i],
|
||||||
tmp_height_val -
|
tmp_height_val -
|
||||||
|
Loading…
Reference in New Issue
Block a user