mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 15:10:38 +00:00
7f8e438b90
When encoding a video as HEVC, the allegro driver needs to generate the Non-VCL NAL units for HEVC. Do the same as for H.264 and add a module that takes C structs for the VPS/SPS/PPS and encodes the fields as RBPS as specified by "ITU-T Rec. H.265 (02/2018) high efficiency video coding". [hverkuil: add missing static for nal_hevc_write/read_start_code_prefix] [hverkuil: fix typo: pps -> vps in nal_hevc_write_vps] Signed-off-by: Michael Tretter <m.tretter@pengutronix.de> Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
351 lines
12 KiB
C
351 lines
12 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (C) 2019 Pengutronix, Michael Tretter <kernel@pengutronix.de>
|
|
*
|
|
* Convert NAL units between raw byte sequence payloads (RBSP) and C structs.
|
|
*/
|
|
|
|
#ifndef __NAL_HEVC_H__
|
|
#define __NAL_HEVC_H__
|
|
|
|
#include <linux/kernel.h>
|
|
#include <linux/types.h>
|
|
#include <media/v4l2-ctrls.h>
|
|
|
|
struct nal_hevc_profile_tier_level {
|
|
unsigned int general_profile_space;
|
|
unsigned int general_tier_flag;
|
|
unsigned int general_profile_idc;
|
|
unsigned int general_profile_compatibility_flag[32];
|
|
unsigned int general_progressive_source_flag;
|
|
unsigned int general_interlaced_source_flag;
|
|
unsigned int general_non_packed_constraint_flag;
|
|
unsigned int general_frame_only_constraint_flag;
|
|
union {
|
|
struct {
|
|
unsigned int general_max_12bit_constraint_flag;
|
|
unsigned int general_max_10bit_constraint_flag;
|
|
unsigned int general_max_8bit_constraint_flag;
|
|
unsigned int general_max_422chroma_constraint_flag;
|
|
unsigned int general_max_420chroma_constraint_flag;
|
|
unsigned int general_max_monochrome_constraint_flag;
|
|
unsigned int general_intra_constraint_flag;
|
|
unsigned int general_one_picture_only_constraint_flag;
|
|
unsigned int general_lower_bit_rate_constraint_flag;
|
|
union {
|
|
struct {
|
|
unsigned int general_max_14bit_constraint_flag;
|
|
unsigned int general_reserved_zero_33bits;
|
|
};
|
|
unsigned int general_reserved_zero_34bits;
|
|
};
|
|
};
|
|
struct {
|
|
unsigned int general_reserved_zero_7bits;
|
|
/* unsigned int general_one_picture_only_constraint_flag; */
|
|
unsigned int general_reserved_zero_35bits;
|
|
};
|
|
unsigned int general_reserved_zero_43bits;
|
|
};
|
|
union {
|
|
unsigned int general_inbld_flag;
|
|
unsigned int general_reserved_zero_bit;
|
|
};
|
|
unsigned int general_level_idc;
|
|
};
|
|
|
|
/**
|
|
* struct nal_hevc_vps - Video parameter set
|
|
*
|
|
* C struct representation of the video parameter set NAL unit as defined by
|
|
* Rec. ITU-T H.265 (02/2018) 7.3.2.1 Video parameter set RBSP syntax
|
|
*/
|
|
struct nal_hevc_vps {
|
|
unsigned int video_parameter_set_id;
|
|
unsigned int base_layer_internal_flag;
|
|
unsigned int base_layer_available_flag;
|
|
unsigned int max_layers_minus1;
|
|
unsigned int max_sub_layers_minus1;
|
|
unsigned int temporal_id_nesting_flag;
|
|
struct nal_hevc_profile_tier_level profile_tier_level;
|
|
unsigned int sub_layer_ordering_info_present_flag;
|
|
struct {
|
|
unsigned int max_dec_pic_buffering_minus1[7];
|
|
unsigned int max_num_reorder_pics[7];
|
|
unsigned int max_latency_increase_plus1[7];
|
|
};
|
|
unsigned int max_layer_id;
|
|
unsigned int num_layer_sets_minus1;
|
|
unsigned int layer_id_included_flag[1024][64];
|
|
unsigned int timing_info_present_flag;
|
|
struct {
|
|
unsigned int num_units_in_tick;
|
|
unsigned int time_scale;
|
|
unsigned int poc_proportional_to_timing_flag;
|
|
unsigned int num_ticks_poc_diff_one_minus1;
|
|
unsigned int num_hrd_parameters;
|
|
struct {
|
|
unsigned int hrd_layer_set_idx[0];
|
|
unsigned int cprms_present_flag[0];
|
|
};
|
|
/* hrd_parameters( cprms_present_flag[ i ], max_sub_layers_minus1 ) */
|
|
};
|
|
unsigned int extension_flag;
|
|
unsigned int extension_data_flag;
|
|
};
|
|
|
|
struct nal_hevc_sub_layer_hrd_parameters {
|
|
unsigned int bit_rate_value_minus1[1];
|
|
unsigned int cpb_size_value_minus1[1];
|
|
unsigned int cbr_flag[1];
|
|
};
|
|
|
|
struct nal_hevc_hrd_parameters {
|
|
unsigned int nal_hrd_parameters_present_flag;
|
|
unsigned int vcl_hrd_parameters_present_flag;
|
|
struct {
|
|
unsigned int sub_pic_hrd_params_present_flag;
|
|
struct {
|
|
unsigned int tick_divisor_minus2;
|
|
unsigned int du_cpb_removal_delay_increment_length_minus1;
|
|
unsigned int sub_pic_cpb_params_in_pic_timing_sei_flag;
|
|
unsigned int dpb_output_delay_du_length_minus1;
|
|
};
|
|
unsigned int bit_rate_scale;
|
|
unsigned int cpb_size_scale;
|
|
unsigned int cpb_size_du_scale;
|
|
unsigned int initial_cpb_removal_delay_length_minus1;
|
|
unsigned int au_cpb_removal_delay_length_minus1;
|
|
unsigned int dpb_output_delay_length_minus1;
|
|
};
|
|
struct {
|
|
unsigned int fixed_pic_rate_general_flag[1];
|
|
unsigned int fixed_pic_rate_within_cvs_flag[1];
|
|
unsigned int elemental_duration_in_tc_minus1[1];
|
|
unsigned int low_delay_hrd_flag[1];
|
|
unsigned int cpb_cnt_minus1[1];
|
|
struct nal_hevc_sub_layer_hrd_parameters nal_hrd[1];
|
|
struct nal_hevc_sub_layer_hrd_parameters vcl_hrd[1];
|
|
};
|
|
};
|
|
|
|
/**
|
|
* struct nal_hevc_vui_parameters - VUI parameters
|
|
*
|
|
* C struct representation of the VUI parameters as defined by Rec. ITU-T
|
|
* H.265 (02/2018) E.2.1 VUI parameters syntax.
|
|
*/
|
|
struct nal_hevc_vui_parameters {
|
|
unsigned int aspect_ratio_info_present_flag;
|
|
struct {
|
|
unsigned int aspect_ratio_idc;
|
|
unsigned int sar_width;
|
|
unsigned int sar_height;
|
|
};
|
|
unsigned int overscan_info_present_flag;
|
|
unsigned int overscan_appropriate_flag;
|
|
unsigned int video_signal_type_present_flag;
|
|
struct {
|
|
unsigned int video_format;
|
|
unsigned int video_full_range_flag;
|
|
unsigned int colour_description_present_flag;
|
|
struct {
|
|
unsigned int colour_primaries;
|
|
unsigned int transfer_characteristics;
|
|
unsigned int matrix_coeffs;
|
|
};
|
|
};
|
|
unsigned int chroma_loc_info_present_flag;
|
|
struct {
|
|
unsigned int chroma_sample_loc_type_top_field;
|
|
unsigned int chroma_sample_loc_type_bottom_field;
|
|
};
|
|
unsigned int neutral_chroma_indication_flag;
|
|
unsigned int field_seq_flag;
|
|
unsigned int frame_field_info_present_flag;
|
|
unsigned int default_display_window_flag;
|
|
struct {
|
|
unsigned int def_disp_win_left_offset;
|
|
unsigned int def_disp_win_right_offset;
|
|
unsigned int def_disp_win_top_offset;
|
|
unsigned int def_disp_win_bottom_offset;
|
|
};
|
|
unsigned int vui_timing_info_present_flag;
|
|
struct {
|
|
unsigned int vui_num_units_in_tick;
|
|
unsigned int vui_time_scale;
|
|
unsigned int vui_poc_proportional_to_timing_flag;
|
|
unsigned int vui_num_ticks_poc_diff_one_minus1;
|
|
unsigned int vui_hrd_parameters_present_flag;
|
|
struct nal_hevc_hrd_parameters nal_hrd_parameters;
|
|
};
|
|
unsigned int bitstream_restriction_flag;
|
|
struct {
|
|
unsigned int tiles_fixed_structure_flag;
|
|
unsigned int motion_vectors_over_pic_boundaries_flag;
|
|
unsigned int restricted_ref_pic_lists_flag;
|
|
unsigned int min_spatial_segmentation_idc;
|
|
unsigned int max_bytes_per_pic_denom;
|
|
unsigned int max_bits_per_min_cu_denom;
|
|
unsigned int log2_max_mv_length_horizontal;
|
|
unsigned int log2_max_mv_length_vertical;
|
|
};
|
|
};
|
|
|
|
/**
|
|
* struct nal_hevc_sps - Sequence parameter set
|
|
*
|
|
* C struct representation of the video parameter set NAL unit as defined by
|
|
* Rec. ITU-T H.265 (02/2018) 7.3.2.2 Sequence parameter set RBSP syntax
|
|
*/
|
|
struct nal_hevc_sps {
|
|
unsigned int video_parameter_set_id;
|
|
unsigned int max_sub_layers_minus1;
|
|
unsigned int temporal_id_nesting_flag;
|
|
struct nal_hevc_profile_tier_level profile_tier_level;
|
|
unsigned int seq_parameter_set_id;
|
|
unsigned int chroma_format_idc;
|
|
unsigned int separate_colour_plane_flag;
|
|
unsigned int pic_width_in_luma_samples;
|
|
unsigned int pic_height_in_luma_samples;
|
|
unsigned int conformance_window_flag;
|
|
struct {
|
|
unsigned int conf_win_left_offset;
|
|
unsigned int conf_win_right_offset;
|
|
unsigned int conf_win_top_offset;
|
|
unsigned int conf_win_bottom_offset;
|
|
};
|
|
|
|
unsigned int bit_depth_luma_minus8;
|
|
unsigned int bit_depth_chroma_minus8;
|
|
unsigned int log2_max_pic_order_cnt_lsb_minus4;
|
|
unsigned int sub_layer_ordering_info_present_flag;
|
|
struct {
|
|
unsigned int max_dec_pic_buffering_minus1[7];
|
|
unsigned int max_num_reorder_pics[7];
|
|
unsigned int max_latency_increase_plus1[7];
|
|
};
|
|
unsigned int log2_min_luma_coding_block_size_minus3;
|
|
unsigned int log2_diff_max_min_luma_coding_block_size;
|
|
unsigned int log2_min_luma_transform_block_size_minus2;
|
|
unsigned int log2_diff_max_min_luma_transform_block_size;
|
|
unsigned int max_transform_hierarchy_depth_inter;
|
|
unsigned int max_transform_hierarchy_depth_intra;
|
|
|
|
unsigned int scaling_list_enabled_flag;
|
|
unsigned int scaling_list_data_present_flag;
|
|
unsigned int amp_enabled_flag;
|
|
unsigned int sample_adaptive_offset_enabled_flag;
|
|
unsigned int pcm_enabled_flag;
|
|
struct {
|
|
unsigned int pcm_sample_bit_depth_luma_minus1;
|
|
unsigned int pcm_sample_bit_depth_chroma_minus1;
|
|
unsigned int log2_min_pcm_luma_coding_block_size_minus3;
|
|
unsigned int log2_diff_max_min_pcm_luma_coding_block_size;
|
|
unsigned int pcm_loop_filter_disabled_flag;
|
|
};
|
|
|
|
unsigned int num_short_term_ref_pic_sets;
|
|
unsigned int long_term_ref_pics_present_flag;
|
|
unsigned int sps_temporal_mvp_enabled_flag;
|
|
unsigned int strong_intra_smoothing_enabled_flag;
|
|
unsigned int vui_parameters_present_flag;
|
|
struct nal_hevc_vui_parameters vui;
|
|
unsigned int extension_present_flag;
|
|
struct {
|
|
unsigned int sps_range_extension_flag;
|
|
unsigned int sps_multilayer_extension_flag;
|
|
unsigned int sps_3d_extension_flag;
|
|
unsigned int sps_scc_extension_flag;
|
|
unsigned int sps_extension_4bits;
|
|
};
|
|
};
|
|
|
|
struct nal_hevc_pps {
|
|
unsigned int pps_pic_parameter_set_id;
|
|
unsigned int pps_seq_parameter_set_id;
|
|
unsigned int dependent_slice_segments_enabled_flag;
|
|
unsigned int output_flag_present_flag;
|
|
unsigned int num_extra_slice_header_bits;
|
|
unsigned int sign_data_hiding_enabled_flag;
|
|
unsigned int cabac_init_present_flag;
|
|
unsigned int num_ref_idx_l0_default_active_minus1;
|
|
unsigned int num_ref_idx_l1_default_active_minus1;
|
|
int init_qp_minus26;
|
|
unsigned int constrained_intra_pred_flag;
|
|
unsigned int transform_skip_enabled_flag;
|
|
unsigned int cu_qp_delta_enabled_flag;
|
|
unsigned int diff_cu_qp_delta_depth;
|
|
int pps_cb_qp_offset;
|
|
int pps_cr_qp_offset;
|
|
unsigned int pps_slice_chroma_qp_offsets_present_flag;
|
|
unsigned int weighted_pred_flag;
|
|
unsigned int weighted_bipred_flag;
|
|
unsigned int transquant_bypass_enabled_flag;
|
|
unsigned int tiles_enabled_flag;
|
|
unsigned int entropy_coding_sync_enabled_flag;
|
|
struct {
|
|
unsigned int num_tile_columns_minus1;
|
|
unsigned int num_tile_rows_minus1;
|
|
unsigned int uniform_spacing_flag;
|
|
struct {
|
|
unsigned int column_width_minus1[1];
|
|
unsigned int row_height_minus1[1];
|
|
};
|
|
unsigned int loop_filter_across_tiles_enabled_flag;
|
|
};
|
|
unsigned int pps_loop_filter_across_slices_enabled_flag;
|
|
unsigned int deblocking_filter_control_present_flag;
|
|
struct {
|
|
unsigned int deblocking_filter_override_enabled_flag;
|
|
unsigned int pps_deblocking_filter_disabled_flag;
|
|
struct {
|
|
int pps_beta_offset_div2;
|
|
int pps_tc_offset_div2;
|
|
};
|
|
};
|
|
unsigned int pps_scaling_list_data_present_flag;
|
|
unsigned int lists_modification_present_flag;
|
|
unsigned int log2_parallel_merge_level_minus2;
|
|
unsigned int slice_segment_header_extension_present_flag;
|
|
unsigned int pps_extension_present_flag;
|
|
struct {
|
|
unsigned int pps_range_extension_flag;
|
|
unsigned int pps_multilayer_extension_flag;
|
|
unsigned int pps_3d_extension_flag;
|
|
unsigned int pps_scc_extension_flag;
|
|
unsigned int pps_extension_4bits;
|
|
};
|
|
};
|
|
|
|
int nal_hevc_profile_from_v4l2(enum v4l2_mpeg_video_hevc_profile profile);
|
|
int nal_hevc_tier_from_v4l2(enum v4l2_mpeg_video_hevc_tier tier);
|
|
int nal_hevc_level_from_v4l2(enum v4l2_mpeg_video_hevc_level level);
|
|
|
|
int nal_range_from_v4l2(enum v4l2_quantization quantization);
|
|
int nal_color_primaries_from_v4l2(enum v4l2_colorspace colorspace);
|
|
int nal_transfer_characteristics_from_v4l2(enum v4l2_colorspace colorspace,
|
|
enum v4l2_xfer_func xfer_func);
|
|
int nal_matrix_coeffs_from_v4l2(enum v4l2_colorspace colorspace,
|
|
enum v4l2_ycbcr_encoding ycbcr_encoding);
|
|
|
|
ssize_t nal_hevc_write_vps(const struct device *dev,
|
|
void *dest, size_t n, struct nal_hevc_vps *vps);
|
|
ssize_t nal_hevc_read_vps(const struct device *dev,
|
|
struct nal_hevc_vps *vps, void *src, size_t n);
|
|
|
|
ssize_t nal_hevc_write_sps(const struct device *dev,
|
|
void *dest, size_t n, struct nal_hevc_sps *sps);
|
|
ssize_t nal_hevc_read_sps(const struct device *dev,
|
|
struct nal_hevc_sps *sps, void *src, size_t n);
|
|
|
|
ssize_t nal_hevc_write_pps(const struct device *dev,
|
|
void *dest, size_t n, struct nal_hevc_pps *pps);
|
|
ssize_t nal_hevc_read_pps(const struct device *dev,
|
|
struct nal_hevc_pps *pps, void *src, size_t n);
|
|
|
|
ssize_t nal_hevc_write_filler(const struct device *dev, void *dest, size_t n);
|
|
ssize_t nal_hevc_read_filler(const struct device *dev, void *src, size_t n);
|
|
|
|
#endif /* __NAL_HEVC_H__ */
|