summaryrefslogtreecommitdiff
path: root/libavcodec
diff options
context:
space:
mode:
authorNuo Mi <nuomi2021@gmail.com>2023-08-08 18:59:02 +0800
committerJames Almer <jamrial@gmail.com>2023-08-17 10:05:24 -0300
commit763eb591870161ddf38ee541dab1e2da550d8239 (patch)
treeab2a7413ddf6a5c6f6424822035a0878b4902dde /libavcodec
parent088bda0f8e33c803f5069dce7c7821ed083ca639 (diff)
cbs_h266: H266RawSliceHeader, expose NumRefIdxActive[]
Signed-off-by: James Almer <jamrial@gmail.com>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/cbs_h266.h1
-rw-r--r--libavcodec/cbs_h266_syntax_template.c41
2 files changed, 21 insertions, 21 deletions
diff --git a/libavcodec/cbs_h266.h b/libavcodec/cbs_h266.h
index 87a2d02cfd..3a6f6d96b5 100644
--- a/libavcodec/cbs_h266.h
+++ b/libavcodec/cbs_h266.h
@@ -833,6 +833,7 @@ typedef struct H266RawSliceHeader {
// derived values
uint32_t num_entry_points; ///< NumEntryPoints
+ uint8_t num_ref_idx_active[2]; ///< NumRefIdxActive[]
} H266RawSliceHeader;
diff --git a/libavcodec/cbs_h266_syntax_template.c b/libavcodec/cbs_h266_syntax_template.c
index 501c066faa..b26d7c1a72 100644
--- a/libavcodec/cbs_h266_syntax_template.c
+++ b/libavcodec/cbs_h266_syntax_template.c
@@ -3191,39 +3191,38 @@ static int FUNC(slice_header) (CodedBitstreamContext *ctx, RWContext *rw,
} else {
infer(sh_num_ref_idx_active_override_flag, 1);
}
+
+ for (i = 0; i < 2; i++) {
+ if (current->sh_slice_type == VVC_SLICE_TYPE_B ||
+ (current->sh_slice_type == VVC_SLICE_TYPE_P && i == 0)) {
+ if (current->sh_num_ref_idx_active_override_flag) {
+ current->num_ref_idx_active[i] = current->sh_num_ref_idx_active_minus1[i] + 1;
+ } else {
+ current->num_ref_idx_active[i] =
+ FFMIN(ref_pic_lists->rpl_ref_list[i].num_ref_entries,
+ pps->pps_num_ref_idx_default_active_minus1[i] + 1);
+ }
+ } else {
+ current->num_ref_idx_active[i] = 0;
+ }
+ }
+
if (current->sh_slice_type != VVC_SLICE_TYPE_I) {
if (pps->pps_cabac_init_present_flag)
flag(sh_cabac_init_flag);
else
infer(sh_cabac_init_flag, 0);
if (ph->ph_temporal_mvp_enabled_flag && !pps->pps_rpl_info_in_ph_flag) {
- uint8_t num_ref_idx_active[2];
- for (i = 0; i < 2; i++) {
- if (current->sh_slice_type == VVC_SLICE_TYPE_B ||
- (current->sh_slice_type == VVC_SLICE_TYPE_P && i == 0)) {
- if (current->sh_num_ref_idx_active_override_flag) {
- num_ref_idx_active[i] =
- current->sh_num_ref_idx_active_minus1[i] + 1;
- } else {
- num_ref_idx_active[i] =
- FFMIN(ref_pic_lists->rpl_ref_list[i].num_ref_entries,
- pps->pps_num_ref_idx_default_active_minus1[i] + 1);
- }
- } else {
- num_ref_idx_active[i] = 0;
- }
- }
-
if (current->sh_slice_type == VVC_SLICE_TYPE_B)
flag(sh_collocated_from_l0_flag);
else
infer(sh_collocated_from_l0_flag, 1);
if ((current->sh_collocated_from_l0_flag &&
- num_ref_idx_active[0] > 1) ||
+ current->num_ref_idx_active[0] > 1) ||
(!current->sh_collocated_from_l0_flag &&
- num_ref_idx_active[1] > 1)) {
+ current->num_ref_idx_active[1] > 1)) {
unsigned int idx = current->sh_collocated_from_l0_flag ? 0 : 1;
- ue(sh_collocated_ref_idx, 0, num_ref_idx_active[idx] - 1);
+ ue(sh_collocated_ref_idx, 0, current->num_ref_idx_active[idx] - 1);
} else {
infer(sh_collocated_ref_idx, 0);
}
@@ -3233,7 +3232,7 @@ static int FUNC(slice_header) (CodedBitstreamContext *ctx, RWContext *rw,
(pps->pps_weighted_bipred_flag &&
current->sh_slice_type == VVC_SLICE_TYPE_B))) {
CHECK(FUNC(pred_weight_table) (ctx, rw, sps, pps, ref_pic_lists,
- num_ref_idx_active,
+ current->num_ref_idx_active,
&current->sh_pred_weight_table));
}
}