mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
lavu/frame: add QP side data
This adds a way for an API user to transfer QP data and metadata without having to keep the reference to AVFrame, and without having to explicitly care about QP APIs. It might also provide a way to finally remove the deprecated QP related fields. In the end, the QP table should be handled in a very similar way to e.g. AV_FRAME_DATA_MOTION_VECTORS. There are two side data types, because I didn't care about having to repack the QP data so the table and the metadata are in a single AVBufferRef. Otherwise it would have either required a copy on decoding (extra slowdown for something as obscure as the QP data), or would have required making intrusive changes to the codecs which support export of this data. The new side data types are added under deprecation guards, because I don't intend to change the status of the QP export as being deprecated (as it was before this patch too).
This commit is contained in:
parent
36855abc0e
commit
4b86ac27a0
@ -15,6 +15,9 @@ libavutil: 2017-10-21
|
|||||||
|
|
||||||
API changes, most recent first:
|
API changes, most recent first:
|
||||||
|
|
||||||
|
2018-03-18 - xxxxxxx - lavu 56.11.100 - frame.h
|
||||||
|
Add AV_FRAME_DATA_QP_TABLE_PROPERTIES and AV_FRAME_DATA_QP_TABLE_DATA.
|
||||||
|
|
||||||
2018-03-15 - e0e72539cf - lavu 56.10.100 - opt.h
|
2018-03-15 - e0e72539cf - lavu 56.10.100 - opt.h
|
||||||
Add AV_OPT_FLAG_BSF_PARAM
|
Add AV_OPT_FLAG_BSF_PARAM
|
||||||
|
|
||||||
|
@ -46,8 +46,17 @@ MAKE_ACCESSORS(AVFrame, frame, enum AVColorRange, color_range)
|
|||||||
av_get_channel_layout_nb_channels((frame)->channel_layout))
|
av_get_channel_layout_nb_channels((frame)->channel_layout))
|
||||||
|
|
||||||
#if FF_API_FRAME_QP
|
#if FF_API_FRAME_QP
|
||||||
|
struct qp_properties {
|
||||||
|
int stride;
|
||||||
|
int type;
|
||||||
|
};
|
||||||
|
|
||||||
int av_frame_set_qp_table(AVFrame *f, AVBufferRef *buf, int stride, int qp_type)
|
int av_frame_set_qp_table(AVFrame *f, AVBufferRef *buf, int stride, int qp_type)
|
||||||
{
|
{
|
||||||
|
struct qp_properties *p;
|
||||||
|
AVFrameSideData *sd;
|
||||||
|
AVBufferRef *ref;
|
||||||
|
|
||||||
FF_DISABLE_DEPRECATION_WARNINGS
|
FF_DISABLE_DEPRECATION_WARNINGS
|
||||||
av_buffer_unref(&f->qp_table_buf);
|
av_buffer_unref(&f->qp_table_buf);
|
||||||
|
|
||||||
@ -57,20 +66,56 @@ FF_DISABLE_DEPRECATION_WARNINGS
|
|||||||
f->qscale_type = qp_type;
|
f->qscale_type = qp_type;
|
||||||
FF_ENABLE_DEPRECATION_WARNINGS
|
FF_ENABLE_DEPRECATION_WARNINGS
|
||||||
|
|
||||||
|
av_frame_remove_side_data(f, AV_FRAME_DATA_QP_TABLE_PROPERTIES);
|
||||||
|
av_frame_remove_side_data(f, AV_FRAME_DATA_QP_TABLE_DATA);
|
||||||
|
|
||||||
|
ref = av_buffer_ref(buf);
|
||||||
|
if (!av_frame_new_side_data_from_buf(f, AV_FRAME_DATA_QP_TABLE_DATA, ref)) {
|
||||||
|
av_buffer_unref(&ref);
|
||||||
|
return AVERROR(ENOMEM);
|
||||||
|
}
|
||||||
|
|
||||||
|
sd = av_frame_new_side_data(f, AV_FRAME_DATA_QP_TABLE_PROPERTIES,
|
||||||
|
sizeof(struct qp_properties));
|
||||||
|
if (!sd)
|
||||||
|
return AVERROR(ENOMEM);
|
||||||
|
|
||||||
|
p = (struct qp_properties *)sd->data;
|
||||||
|
p->stride = stride;
|
||||||
|
p->type = qp_type;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int8_t *av_frame_get_qp_table(AVFrame *f, int *stride, int *type)
|
int8_t *av_frame_get_qp_table(AVFrame *f, int *stride, int *type)
|
||||||
{
|
{
|
||||||
|
AVBufferRef *buf = NULL;
|
||||||
|
|
||||||
|
*stride = 0;
|
||||||
|
*type = 0;
|
||||||
|
|
||||||
FF_DISABLE_DEPRECATION_WARNINGS
|
FF_DISABLE_DEPRECATION_WARNINGS
|
||||||
*stride = f->qstride;
|
if (f->qp_table_buf) {
|
||||||
*type = f->qscale_type;
|
*stride = f->qstride;
|
||||||
|
*type = f->qscale_type;
|
||||||
if (!f->qp_table_buf)
|
buf = f->qp_table_buf;
|
||||||
return NULL;
|
|
||||||
|
|
||||||
return f->qp_table_buf->data;
|
|
||||||
FF_ENABLE_DEPRECATION_WARNINGS
|
FF_ENABLE_DEPRECATION_WARNINGS
|
||||||
|
} else {
|
||||||
|
AVFrameSideData *sd;
|
||||||
|
struct qp_properties *p;
|
||||||
|
sd = av_frame_get_side_data(f, AV_FRAME_DATA_QP_TABLE_PROPERTIES);
|
||||||
|
if (!sd)
|
||||||
|
return NULL;
|
||||||
|
p = (struct qp_properties *)sd->data;
|
||||||
|
sd = av_frame_get_side_data(f, AV_FRAME_DATA_QP_TABLE_DATA);
|
||||||
|
if (!sd)
|
||||||
|
return NULL;
|
||||||
|
*stride = p->stride;
|
||||||
|
*type = p->type;
|
||||||
|
buf = sd->buf;
|
||||||
|
}
|
||||||
|
|
||||||
|
return buf ? buf->data : NULL;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -787,6 +832,8 @@ const char *av_frame_side_data_name(enum AVFrameSideDataType type)
|
|||||||
case AV_FRAME_DATA_CONTENT_LIGHT_LEVEL: return "Content light level metadata";
|
case AV_FRAME_DATA_CONTENT_LIGHT_LEVEL: return "Content light level metadata";
|
||||||
case AV_FRAME_DATA_GOP_TIMECODE: return "GOP timecode";
|
case AV_FRAME_DATA_GOP_TIMECODE: return "GOP timecode";
|
||||||
case AV_FRAME_DATA_ICC_PROFILE: return "ICC profile";
|
case AV_FRAME_DATA_ICC_PROFILE: return "ICC profile";
|
||||||
|
case AV_FRAME_DATA_QP_TABLE_PROPERTIES: return "QP table properties";
|
||||||
|
case AV_FRAME_DATA_QP_TABLE_DATA: return "QP table data";
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -141,6 +141,23 @@ enum AVFrameSideDataType {
|
|||||||
* metadata key entry "name".
|
* metadata key entry "name".
|
||||||
*/
|
*/
|
||||||
AV_FRAME_DATA_ICC_PROFILE,
|
AV_FRAME_DATA_ICC_PROFILE,
|
||||||
|
|
||||||
|
#if FF_API_FRAME_QP
|
||||||
|
/**
|
||||||
|
* Implementation-specific description of the format of AV_FRAME_QP_TABLE_DATA.
|
||||||
|
* The contents of this side data are undocumented and internal; use
|
||||||
|
* av_frame_set_qp_table() and av_frame_get_qp_table() to access this in a
|
||||||
|
* meaningful way instead.
|
||||||
|
*/
|
||||||
|
AV_FRAME_DATA_QP_TABLE_PROPERTIES,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Raw QP table data. Its format is described by
|
||||||
|
* AV_FRAME_DATA_QP_TABLE_PROPERTIES. Use av_frame_set_qp_table() and
|
||||||
|
* av_frame_get_qp_table() to access this instead.
|
||||||
|
*/
|
||||||
|
AV_FRAME_DATA_QP_TABLE_DATA,
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
enum AVActiveFormatDescription {
|
enum AVActiveFormatDescription {
|
||||||
|
@ -79,7 +79,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#define LIBAVUTIL_VERSION_MAJOR 56
|
#define LIBAVUTIL_VERSION_MAJOR 56
|
||||||
#define LIBAVUTIL_VERSION_MINOR 10
|
#define LIBAVUTIL_VERSION_MINOR 11
|
||||||
#define LIBAVUTIL_VERSION_MICRO 100
|
#define LIBAVUTIL_VERSION_MICRO 100
|
||||||
|
|
||||||
#define LIBAVUTIL_VERSION_INT AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
|
#define LIBAVUTIL_VERSION_INT AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
|
||||||
|
@ -29,6 +29,12 @@ color_transfer=unknown
|
|||||||
chroma_location=center
|
chroma_location=center
|
||||||
TAG:UserComment=AppleMark
|
TAG:UserComment=AppleMark
|
||||||
|
|
||||||
|
[SIDE_DATA]
|
||||||
|
side_data_type=QP table data
|
||||||
|
[/SIDE_DATA]
|
||||||
|
[SIDE_DATA]
|
||||||
|
side_data_type=QP table properties
|
||||||
|
[/SIDE_DATA]
|
||||||
[/FRAME]
|
[/FRAME]
|
||||||
[FRAME]
|
[FRAME]
|
||||||
media_type=audio
|
media_type=audio
|
||||||
|
@ -229,4 +229,10 @@ TAG:ExposureMode= 0
|
|||||||
TAG:WhiteBalance= 0
|
TAG:WhiteBalance= 0
|
||||||
TAG:DigitalZoomRatio= 4000:4000
|
TAG:DigitalZoomRatio= 4000:4000
|
||||||
TAG:SceneCaptureType= 0
|
TAG:SceneCaptureType= 0
|
||||||
|
[SIDE_DATA]
|
||||||
|
side_data_type=QP table data
|
||||||
|
[/SIDE_DATA]
|
||||||
|
[SIDE_DATA]
|
||||||
|
side_data_type=QP table properties
|
||||||
|
[/SIDE_DATA]
|
||||||
[/FRAME]
|
[/FRAME]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user