mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-04-01 22:49:21 +00:00
avcodec/cbs_h264: add support for Alternative Transfer Characteristics SEI message
Reviewed-by: Mark Thompson <sw@jkqxz.net> Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
parent
2880a32c66
commit
ff2a638c83
@ -314,6 +314,10 @@ typedef struct H264RawSEIMasteringDisplayColourVolume {
|
|||||||
uint32_t min_display_mastering_luminance;
|
uint32_t min_display_mastering_luminance;
|
||||||
} H264RawSEIMasteringDisplayColourVolume;
|
} H264RawSEIMasteringDisplayColourVolume;
|
||||||
|
|
||||||
|
typedef struct H264RawSEIAlternativeTransferCharacteristics {
|
||||||
|
uint8_t preferred_transfer_characteristics;
|
||||||
|
} H264RawSEIAlternativeTransferCharacteristics;
|
||||||
|
|
||||||
typedef struct H264RawSEIPayload {
|
typedef struct H264RawSEIPayload {
|
||||||
uint32_t payload_type;
|
uint32_t payload_type;
|
||||||
uint32_t payload_size;
|
uint32_t payload_size;
|
||||||
@ -327,6 +331,8 @@ typedef struct H264RawSEIPayload {
|
|||||||
H264RawSEIRecoveryPoint recovery_point;
|
H264RawSEIRecoveryPoint recovery_point;
|
||||||
H264RawSEIDisplayOrientation display_orientation;
|
H264RawSEIDisplayOrientation display_orientation;
|
||||||
H264RawSEIMasteringDisplayColourVolume mastering_display_colour_volume;
|
H264RawSEIMasteringDisplayColourVolume mastering_display_colour_volume;
|
||||||
|
H264RawSEIAlternativeTransferCharacteristics
|
||||||
|
alternative_transfer_characteristics;
|
||||||
struct {
|
struct {
|
||||||
uint8_t *data;
|
uint8_t *data;
|
||||||
size_t data_length;
|
size_t data_length;
|
||||||
|
@ -458,6 +458,7 @@ static void cbs_h264_free_sei_payload(H264RawSEIPayload *payload)
|
|||||||
case H264_SEI_TYPE_RECOVERY_POINT:
|
case H264_SEI_TYPE_RECOVERY_POINT:
|
||||||
case H264_SEI_TYPE_DISPLAY_ORIENTATION:
|
case H264_SEI_TYPE_DISPLAY_ORIENTATION:
|
||||||
case H264_SEI_TYPE_MASTERING_DISPLAY_COLOUR_VOLUME:
|
case H264_SEI_TYPE_MASTERING_DISPLAY_COLOUR_VOLUME:
|
||||||
|
case H264_SEI_TYPE_ALTERNATIVE_TRANSFER:
|
||||||
break;
|
break;
|
||||||
case H264_SEI_TYPE_USER_DATA_REGISTERED:
|
case H264_SEI_TYPE_USER_DATA_REGISTERED:
|
||||||
av_buffer_unref(&payload->payload.user_data_registered.data_ref);
|
av_buffer_unref(&payload->payload.user_data_registered.data_ref);
|
||||||
|
@ -815,6 +815,19 @@ static int FUNC(sei_mastering_display_colour_volume)(CodedBitstreamContext *ctx,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int FUNC(sei_alternative_transfer_characteristics)(CodedBitstreamContext *ctx,
|
||||||
|
RWContext *rw,
|
||||||
|
H264RawSEIAlternativeTransferCharacteristics *current)
|
||||||
|
{
|
||||||
|
int err;
|
||||||
|
|
||||||
|
HEADER("Alternative Transfer Characteristics");
|
||||||
|
|
||||||
|
ub(8, preferred_transfer_characteristics);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int FUNC(sei_payload)(CodedBitstreamContext *ctx, RWContext *rw,
|
static int FUNC(sei_payload)(CodedBitstreamContext *ctx, RWContext *rw,
|
||||||
H264RawSEIPayload *current)
|
H264RawSEIPayload *current)
|
||||||
{
|
{
|
||||||
@ -866,6 +879,10 @@ static int FUNC(sei_payload)(CodedBitstreamContext *ctx, RWContext *rw,
|
|||||||
CHECK(FUNC(sei_mastering_display_colour_volume)
|
CHECK(FUNC(sei_mastering_display_colour_volume)
|
||||||
(ctx, rw, ¤t->payload.mastering_display_colour_volume));
|
(ctx, rw, ¤t->payload.mastering_display_colour_volume));
|
||||||
break;
|
break;
|
||||||
|
case H264_SEI_TYPE_ALTERNATIVE_TRANSFER:
|
||||||
|
CHECK(FUNC(sei_alternative_transfer_characteristics)
|
||||||
|
(ctx, rw, ¤t->payload.alternative_transfer_characteristics));
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
#ifdef READ
|
#ifdef READ
|
||||||
|
Loading…
Reference in New Issue
Block a user