|
|
|
/*
|
|
|
|
* This file is part of FFmpeg.
|
|
|
|
*
|
|
|
|
* FFmpeg is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* FFmpeg is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with FFmpeg; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
* AV1 common definitions
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef AVCODEC_AV1_H
|
|
|
|
#define AVCODEC_AV1_H
|
|
|
|
|
|
|
|
// OBU types (section 6.2.2).
|
|
|
|
typedef enum {
|
|
|
|
// 0 reserved.
|
|
|
|
AV1_OBU_SEQUENCE_HEADER = 1,
|
|
|
|
AV1_OBU_TEMPORAL_DELIMITER = 2,
|
|
|
|
AV1_OBU_FRAME_HEADER = 3,
|
|
|
|
AV1_OBU_TILE_GROUP = 4,
|
|
|
|
AV1_OBU_METADATA = 5,
|
|
|
|
AV1_OBU_FRAME = 6,
|
|
|
|
AV1_OBU_REDUNDANT_FRAME_HEADER = 7,
|
|
|
|
AV1_OBU_TILE_LIST = 8,
|
|
|
|
// 9-14 reserved.
|
|
|
|
AV1_OBU_PADDING = 15,
|
|
|
|
} AV1_OBU_Type;
|
|
|
|
|
|
|
|
// Metadata types (section 6.7.1).
|
|
|
|
enum {
|
|
|
|
AV1_METADATA_TYPE_HDR_CLL = 1,
|
|
|
|
AV1_METADATA_TYPE_HDR_MDCV = 2,
|
|
|
|
AV1_METADATA_TYPE_SCALABILITY = 3,
|
|
|
|
AV1_METADATA_TYPE_ITUT_T35 = 4,
|
|
|
|
AV1_METADATA_TYPE_TIMECODE = 5,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Frame types (section 6.8.2).
|
|
|
|
enum {
|
|
|
|
AV1_FRAME_KEY = 0,
|
|
|
|
AV1_FRAME_INTER = 1,
|
|
|
|
AV1_FRAME_INTRA_ONLY = 2,
|
|
|
|
AV1_FRAME_SWITCH = 3,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Reference frames (section 6.10.24).
|
|
|
|
enum {
|
|
|
|
AV1_REF_FRAME_INTRA = 0,
|
|
|
|
AV1_REF_FRAME_LAST = 1,
|
|
|
|
AV1_REF_FRAME_LAST2 = 2,
|
|
|
|
AV1_REF_FRAME_LAST3 = 3,
|
|
|
|
AV1_REF_FRAME_GOLDEN = 4,
|
|
|
|
AV1_REF_FRAME_BWDREF = 5,
|
|
|
|
AV1_REF_FRAME_ALTREF2 = 6,
|
|
|
|
AV1_REF_FRAME_ALTREF = 7,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Constants (section 3).
|
|
|
|
enum {
|
|
|
|
AV1_MAX_OPERATING_POINTS = 32,
|
|
|
|
|
|
|
|
AV1_MAX_SB_SIZE = 128,
|
|
|
|
AV1_MI_SIZE = 4,
|
|
|
|
|
|
|
|
AV1_MAX_TILE_WIDTH = 4096,
|
|
|
|
AV1_MAX_TILE_AREA = 4096 * 2304,
|
|
|
|
AV1_MAX_TILE_ROWS = 64,
|
|
|
|
AV1_MAX_TILE_COLS = 64,
|
|
|
|
|
|
|
|
AV1_NUM_REF_FRAMES = 8,
|
|
|
|
AV1_REFS_PER_FRAME = 7,
|
|
|
|
AV1_TOTAL_REFS_PER_FRAME = 8,
|
|
|
|
AV1_PRIMARY_REF_NONE = 7,
|
|
|
|
|
|
|
|
AV1_MAX_SEGMENTS = 8,
|
|
|
|
AV1_SEG_LVL_MAX = 8,
|
|
|
|
|
|
|
|
AV1_SEG_LVL_ALT_Q = 0,
|
|
|
|
AV1_SEG_LVL_ALT_LF_Y_V = 1,
|
|
|
|
AV1_SEG_LVL_REF_FRAME = 5,
|
|
|
|
AV1_SEG_LVL_SKIP = 6,
|
|
|
|
AV1_SEG_LVL_GLOBAL_MV = 7,
|
|
|
|
|
|
|
|
AV1_SELECT_SCREEN_CONTENT_TOOLS = 2,
|
|
|
|
AV1_SELECT_INTEGER_MV = 2,
|
|
|
|
|
|
|
|
AV1_SUPERRES_NUM = 8,
|
|
|
|
AV1_SUPERRES_DENOM_MIN = 9,
|
|
|
|
|
|
|
|
AV1_INTERPOLATION_FILTER_SWITCHABLE = 4,
|
|
|
|
|
|
|
|
AV1_GM_ABS_ALPHA_BITS = 12,
|
|
|
|
AV1_GM_ALPHA_PREC_BITS = 15,
|
|
|
|
AV1_GM_ABS_TRANS_ONLY_BITS = 9,
|
|
|
|
AV1_GM_TRANS_ONLY_PREC_BITS = 3,
|
|
|
|
AV1_GM_ABS_TRANS_BITS = 12,
|
|
|
|
AV1_GM_TRANS_PREC_BITS = 6,
|
|
|
|
AV1_WARPEDMODEL_PREC_BITS = 16,
|
|
|
|
|
|
|
|
AV1_WARP_MODEL_IDENTITY = 0,
|
|
|
|
AV1_WARP_MODEL_TRANSLATION = 1,
|
|
|
|
AV1_WARP_MODEL_ROTZOOM = 2,
|
|
|
|
AV1_WARP_MODEL_AFFINE = 3,
|
|
|
|
AV1_WARP_PARAM_REDUCE_BITS = 6,
|
|
|
|
|
|
|
|
AV1_DIV_LUT_BITS = 8,
|
|
|
|
AV1_DIV_LUT_PREC_BITS = 14,
|
|
|
|
AV1_DIV_LUT_NUM = 257,
|
|
|
|
|
|
|
|
AV1_MAX_LOOP_FILTER = 63,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// The main colour configuration information uses the same ISO/IEC 23001-8
|
|
|
|
// (H.273) enums as FFmpeg does, so separate definitions are not required.
|
|
|
|
|
|
|
|
// Chroma sample position.
|
|
|
|
enum {
|
|
|
|
AV1_CSP_UNKNOWN = 0,
|
|
|
|
AV1_CSP_VERTICAL = 1, // -> AVCHROMA_LOC_LEFT.
|
|
|
|
AV1_CSP_COLOCATED = 2, // -> AVCHROMA_LOC_TOPLEFT.
|
|
|
|
};
|
|
|
|
|
|
|
|
// Scalability modes (section 6.7.5)
|
|
|
|
enum {
|
|
|
|
AV1_SCALABILITY_L1T2 = 0,
|
|
|
|
AV1_SCALABILITY_L1T3 = 1,
|
|
|
|
AV1_SCALABILITY_L2T1 = 2,
|
|
|
|
AV1_SCALABILITY_L2T2 = 3,
|
|
|
|
AV1_SCALABILITY_L2T3 = 4,
|
|
|
|
AV1_SCALABILITY_S2T1 = 5,
|
|
|
|
AV1_SCALABILITY_S2T2 = 6,
|
|
|
|
AV1_SCALABILITY_S2T3 = 7,
|
|
|
|
AV1_SCALABILITY_L2T1h = 8,
|
|
|
|
AV1_SCALABILITY_L2T2h = 9,
|
|
|
|
AV1_SCALABILITY_L2T3h = 10,
|
|
|
|
AV1_SCALABILITY_S2T1h = 11,
|
|
|
|
AV1_SCALABILITY_S2T2h = 12,
|
|
|
|
AV1_SCALABILITY_S2T3h = 13,
|
|
|
|
AV1_SCALABILITY_SS = 14,
|
|
|
|
AV1_SCALABILITY_L3T1 = 15,
|
|
|
|
AV1_SCALABILITY_L3T2 = 16,
|
|
|
|
AV1_SCALABILITY_L3T3 = 17,
|
|
|
|
AV1_SCALABILITY_S3T1 = 18,
|
|
|
|
AV1_SCALABILITY_S3T2 = 19,
|
|
|
|
AV1_SCALABILITY_S3T3 = 20,
|
|
|
|
AV1_SCALABILITY_L3T2_KEY = 21,
|
|
|
|
AV1_SCALABILITY_L3T3_KEY = 22,
|
|
|
|
AV1_SCALABILITY_L4T5_KEY = 23,
|
|
|
|
AV1_SCALABILITY_L4T7_KEY = 24,
|
|
|
|
AV1_SCALABILITY_L3T2_KEY_SHIFT = 25,
|
|
|
|
AV1_SCALABILITY_L3T3_KEY_SHIFT = 26,
|
|
|
|
AV1_SCALABILITY_L4T5_KEY_SHIFT = 27,
|
|
|
|
AV1_SCALABILITY_L4T7_KEY_SHIFT = 28,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Frame Restoration types (section 6.10.15)
|
|
|
|
enum {
|
|
|
|
AV1_RESTORE_NONE = 0,
|
|
|
|
AV1_RESTORE_WIENER = 1,
|
|
|
|
AV1_RESTORE_SGRPROJ = 2,
|
|
|
|
AV1_RESTORE_SWITCHABLE = 3,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Sequence Headers are actually unbounded because one can use
|
|
|
|
// an arbitrary number of leading zeroes when encoding via uvlc.
|
|
|
|
// The following estimate is based around using the lowest number
|
|
|
|
// of bits for uvlc encoding.
|
|
|
|
#define AV1_SANE_SEQUENCE_HEADER_MAX_BITS 3138
|
|
|
|
|
|
|
|
#endif /* AVCODEC_AV1_H */
|