Signed-off-by: James Almer <[email protected]>
---
libavcodec/cbs_h2645.c | 6 ++++
libavcodec/cbs_h265.h | 16 ++++++++++
libavcodec/cbs_h265_syntax_template.c | 42 +++++++++++++++++++++++++++
3 files changed, 64 insertions(+)
diff --git a/libavcodec/cbs_h2645.c b/libavcodec/cbs_h2645.c
index 828e56b8c0..d73d77a985 100644
--- a/libavcodec/cbs_h2645.c
+++ b/libavcodec/cbs_h2645.c
@@ -2275,6 +2275,12 @@ static const SEIMessageTypeDescriptor
cbs_sei_h265_types[] = {
sizeof(H265RawSEIAlphaChannelInfo),
SEI_MESSAGE_RW(h265, sei_alpha_channel_info),
},
+ {
+ SEI_TYPE_THREE_DIMENSIONAL_REFERENCE_DISPLAYS_INFO,
+ 1, 0,
+ sizeof(H265RawSEI3DReferenceDisplaysInfo),
+ SEI_MESSAGE_RW(h265, sei_3d_reference_displays_info),
+ },
SEI_MESSAGE_TYPE_END
};
diff --git a/libavcodec/cbs_h265.h b/libavcodec/cbs_h265.h
index afb942ced5..52631f9bfb 100644
--- a/libavcodec/cbs_h265.h
+++ b/libavcodec/cbs_h265.h
@@ -715,6 +715,22 @@ typedef struct H265RawSEIAlphaChannelInfo {
uint8_t alpha_channel_clip_type_flag;
} H265RawSEIAlphaChannelInfo;
+typedef struct H265RawSEI3DReferenceDisplaysInfo {
+ uint8_t prec_ref_display_width;
+ uint8_t ref_viewing_distance_flag;
+ uint8_t prec_ref_viewing_dist;
+ uint8_t num_ref_displays_minus1;
+ uint8_t left_view_id[31];
+ uint8_t right_view_id[31];
+ uint8_t exponent_ref_display_width[31];
+ uint8_t mantissa_ref_display_width[31];
+ uint8_t exponent_ref_viewing_distance[31];
+ uint8_t mantissa_ref_viewing_distance[31];
+ uint8_t additional_shift_present_flag[31];
+ uint16_t num_sample_shift_plus512[31];
+ uint8_t three_dimensional_reference_displays_extension_flag;
+} H265RawSEI3DReferenceDisplaysInfo;
+
typedef struct H265RawSEI {
H265RawNALUnitHeader nal_unit_header;
SEIRawMessageList message_list;
diff --git a/libavcodec/cbs_h265_syntax_template.c
b/libavcodec/cbs_h265_syntax_template.c
index 1826950e8e..ee01b5e0d0 100644
--- a/libavcodec/cbs_h265_syntax_template.c
+++ b/libavcodec/cbs_h265_syntax_template.c
@@ -2189,6 +2189,48 @@ SEI_FUNC(sei_alpha_channel_info, (CodedBitstreamContext
*ctx, RWContext *rw,
return 0;
}
+SEI_FUNC(sei_3d_reference_displays_info, (CodedBitstreamContext *ctx,
RWContext *rw,
+ H265RawSEI3DReferenceDisplaysInfo
*current,
+ SEIMessageState *sei))
+{
+ int length;
+ int err, i;
+
+ HEADER("Three Dimensional Reference Displays Information");
+
+ ue(prec_ref_display_width, 0, 31);
+ flag(ref_viewing_distance_flag);
+ if (current->ref_viewing_distance_flag)
+ ue(prec_ref_viewing_dist, 0, 31);
+ ue(num_ref_displays_minus1, 0, 31);
+ for (i = 0; i <= current->num_ref_displays_minus1; i++) {
+ ues(left_view_id[i], 0, UINT8_MAX, 1, i);
+ ues(right_view_id[i], 0, UINT8_MAX, 1, i);
+ us(6, exponent_ref_display_width[i], 0, 62, 1, i);
+ if (!current->exponent_ref_display_width[i])
+ length = FFMAX(0, (int)current->prec_ref_display_width - 30);
+ else
+ length = FFMAX(0, (int)current->exponent_ref_display_width[i] +
+ (int)current->prec_ref_display_width - 31);
+ ubs(length, mantissa_ref_display_width[i], 1, i);
+ if (current->ref_viewing_distance_flag) {
+ us(6, exponent_ref_viewing_distance[i], 0, 62, 1, i);
+ if (!current->exponent_ref_viewing_distance[i])
+ length = FFMAX(0, (int)current->prec_ref_viewing_dist - 30);
+ else
+ length = FFMAX(0,
(int)current->exponent_ref_viewing_distance[i] +
+ (int)current->prec_ref_viewing_dist - 31);
+ ubs(length, mantissa_ref_viewing_distance[i], 1, i);
+ }
+ flags(additional_shift_present_flag[i], 1, i);
+ if (current->additional_shift_present_flag[i])
+ us(10, num_sample_shift_plus512[i], 0, 1023, 1, i);
+ }
+ flag(three_dimensional_reference_displays_extension_flag);
+
+ return 0;
+}
+
static int FUNC(sei)(CodedBitstreamContext *ctx, RWContext *rw,
H265RawSEI *current, int prefix)
{
--
2.45.2
_______________________________________________
ffmpeg-devel mailing list
[email protected]
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
To unsubscribe, visit link above, or email
[email protected] with subject "unsubscribe".