mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-01-21 02:10:17 +01:00
radeonsi/vcn: Set H264 video signal parameters in bitstream
Reviewed-by: Ruijing Dong <ruijing.dong@amd.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/24174>
This commit is contained in:
parent
8a21efce3a
commit
f44697239d
3 changed files with 28 additions and 1 deletions
|
|
@ -169,11 +169,20 @@ static void radeon_vcn_enc_h264_get_vui_param(struct radeon_encoder *enc,
|
|||
pic->seq.vui_flags.aspect_ratio_info_present_flag;
|
||||
enc->enc_pic.vui_info.flags.timing_info_present_flag =
|
||||
pic->seq.vui_flags.timing_info_present_flag;
|
||||
enc->enc_pic.vui_info.flags.video_signal_type_present_flag =
|
||||
pic->seq.vui_flags.video_signal_type_present_flag;
|
||||
enc->enc_pic.vui_info.flags.colour_description_present_flag =
|
||||
pic->seq.vui_flags.colour_description_present_flag;
|
||||
enc->enc_pic.vui_info.aspect_ratio_idc = pic->seq.aspect_ratio_idc;
|
||||
enc->enc_pic.vui_info.sar_width = pic->seq.sar_width;
|
||||
enc->enc_pic.vui_info.sar_height = pic->seq.sar_height;
|
||||
enc->enc_pic.vui_info.num_units_in_tick = pic->seq.num_units_in_tick;
|
||||
enc->enc_pic.vui_info.time_scale = pic->seq.time_scale;
|
||||
enc->enc_pic.vui_info.video_format = pic->seq.video_format;
|
||||
enc->enc_pic.vui_info.video_full_range_flag = pic->seq.video_full_range_flag;
|
||||
enc->enc_pic.vui_info.colour_primaries = pic->seq.colour_primaries;
|
||||
enc->enc_pic.vui_info.transfer_characteristics = pic->seq.transfer_characteristics;
|
||||
enc->enc_pic.vui_info.matrix_coefficients = pic->seq.matrix_coefficients;
|
||||
}
|
||||
|
||||
/* only checking the first slice to get num of mbs in slice to
|
||||
|
|
|
|||
|
|
@ -562,12 +562,19 @@ typedef struct rvcn_enc_vui_info_s
|
|||
struct {
|
||||
uint32_t aspect_ratio_info_present_flag : 1;
|
||||
uint32_t timing_info_present_flag : 1;
|
||||
uint32_t video_signal_type_present_flag : 1;
|
||||
uint32_t colour_description_present_flag : 1;
|
||||
} flags;
|
||||
uint32_t aspect_ratio_idc;
|
||||
uint32_t sar_width;
|
||||
uint32_t sar_height;
|
||||
uint32_t num_units_in_tick;
|
||||
uint32_t time_scale;
|
||||
uint32_t video_format;
|
||||
uint32_t video_full_range_flag;
|
||||
uint32_t colour_primaries;
|
||||
uint32_t transfer_characteristics;
|
||||
uint32_t matrix_coefficients;
|
||||
}rvcn_enc_vui_info;
|
||||
|
||||
typedef struct rvcn_enc_input_format_s
|
||||
|
|
|
|||
|
|
@ -304,7 +304,18 @@ static void radeon_enc_nalu_sps(struct radeon_encoder *enc)
|
|||
}
|
||||
}
|
||||
radeon_enc_code_fixed_bits(enc, 0x0, 1); /* overscan info present flag */
|
||||
radeon_enc_code_fixed_bits(enc, 0x0, 1); /* video signal type present flag */
|
||||
/* video signal type present flag */
|
||||
radeon_enc_code_fixed_bits(enc, pic->vui_info.flags.video_signal_type_present_flag, 1);
|
||||
if (pic->vui_info.flags.video_signal_type_present_flag) {
|
||||
radeon_enc_code_fixed_bits(enc, pic->vui_info.video_format, 3);
|
||||
radeon_enc_code_fixed_bits(enc, pic->vui_info.video_full_range_flag, 1);
|
||||
radeon_enc_code_fixed_bits(enc, pic->vui_info.flags.colour_description_present_flag, 1);
|
||||
if (pic->vui_info.flags.colour_description_present_flag) {
|
||||
radeon_enc_code_fixed_bits(enc, pic->vui_info.colour_primaries, 8);
|
||||
radeon_enc_code_fixed_bits(enc, pic->vui_info.transfer_characteristics, 8);
|
||||
radeon_enc_code_fixed_bits(enc, pic->vui_info.matrix_coefficients, 8);
|
||||
}
|
||||
}
|
||||
radeon_enc_code_fixed_bits(enc, 0x0, 1); /* chroma loc info present flag */
|
||||
/* timing info present flag */
|
||||
radeon_enc_code_fixed_bits(enc, (pic->vui_info.flags.timing_info_present_flag), 1);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue