forked from Minki/linux
3ce7f6aaf1
Add HEVC encoder support and necessary registers, V4L2 CIDs, and hevc encoder parameters Signed-off-by: Smitha T Murthy <smitha.t@samsung.com> Acked-by: Hans Verkuil <hans.verkuil@cisco.com> Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
88 lines
2.9 KiB
C
88 lines
2.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
*
|
|
* Copyright (c) 2017 Samsung Electronics Co., Ltd.
|
|
* http://www.samsung.com/
|
|
*
|
|
* Register definition file for Samsung MFC V10.x Interface (FIMV) driver
|
|
*
|
|
*/
|
|
|
|
#ifndef _REGS_MFC_V10_H
|
|
#define _REGS_MFC_V10_H
|
|
|
|
#include <linux/sizes.h>
|
|
#include "regs-mfc-v8.h"
|
|
|
|
/* MFCv10 register definitions*/
|
|
#define S5P_FIMV_MFC_CLOCK_OFF_V10 0x7120
|
|
#define S5P_FIMV_MFC_STATE_V10 0x7124
|
|
#define S5P_FIMV_D_STATIC_BUFFER_ADDR_V10 0xF570
|
|
#define S5P_FIMV_D_STATIC_BUFFER_SIZE_V10 0xF574
|
|
#define S5P_FIMV_E_NUM_T_LAYER_V10 0xFBAC
|
|
#define S5P_FIMV_E_HIERARCHICAL_QP_LAYER0_V10 0xFBB0
|
|
#define S5P_FIMV_E_HIERARCHICAL_QP_LAYER1_V10 0xFBB4
|
|
#define S5P_FIMV_E_HIERARCHICAL_QP_LAYER2_V10 0xFBB8
|
|
#define S5P_FIMV_E_HIERARCHICAL_QP_LAYER3_V10 0xFBBC
|
|
#define S5P_FIMV_E_HIERARCHICAL_QP_LAYER4_V10 0xFBC0
|
|
#define S5P_FIMV_E_HIERARCHICAL_QP_LAYER5_V10 0xFBC4
|
|
#define S5P_FIMV_E_HIERARCHICAL_QP_LAYER6_V10 0xFBC8
|
|
#define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER0_V10 0xFD18
|
|
#define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER1_V10 0xFD1C
|
|
#define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER2_V10 0xFD20
|
|
#define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER3_V10 0xFD24
|
|
#define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER4_V10 0xFD28
|
|
#define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER5_V10 0xFD2C
|
|
#define S5P_FIMV_E_HIERARCHICAL_BIT_RATE_LAYER6_V10 0xFD30
|
|
#define S5P_FIMV_E_HEVC_OPTIONS_V10 0xFDD4
|
|
#define S5P_FIMV_E_HEVC_REFRESH_PERIOD_V10 0xFDD8
|
|
#define S5P_FIMV_E_HEVC_CHROMA_QP_OFFSET_V10 0xFDDC
|
|
#define S5P_FIMV_E_HEVC_LF_BETA_OFFSET_DIV2_V10 0xFDE0
|
|
#define S5P_FIMV_E_HEVC_LF_TC_OFFSET_DIV2_V10 0xFDE4
|
|
#define S5P_FIMV_E_HEVC_NAL_CONTROL_V10 0xFDE8
|
|
|
|
/* MFCv10 Context buffer sizes */
|
|
#define MFC_CTX_BUF_SIZE_V10 (30 * SZ_1K)
|
|
#define MFC_H264_DEC_CTX_BUF_SIZE_V10 (2 * SZ_1M)
|
|
#define MFC_OTHER_DEC_CTX_BUF_SIZE_V10 (20 * SZ_1K)
|
|
#define MFC_H264_ENC_CTX_BUF_SIZE_V10 (100 * SZ_1K)
|
|
#define MFC_HEVC_ENC_CTX_BUF_SIZE_V10 (30 * SZ_1K)
|
|
#define MFC_OTHER_ENC_CTX_BUF_SIZE_V10 (15 * SZ_1K)
|
|
|
|
/* MFCv10 variant defines */
|
|
#define MAX_FW_SIZE_V10 (SZ_1M)
|
|
#define MAX_CPB_SIZE_V10 (3 * SZ_1M)
|
|
#define MFC_VERSION_V10 0xA0
|
|
#define MFC_NUM_PORTS_V10 1
|
|
|
|
/* MFCv10 codec defines*/
|
|
#define S5P_FIMV_CODEC_HEVC_DEC 17
|
|
#define S5P_FIMV_CODEC_VP9_DEC 18
|
|
#define S5P_FIMV_CODEC_HEVC_ENC 26
|
|
|
|
/* Decoder buffer size for MFC v10 */
|
|
#define DEC_VP9_STATIC_BUFFER_SIZE 20480
|
|
|
|
/* Encoder buffer size for MFC v10.0 */
|
|
#define ENC_V100_BASE_SIZE(x, y) \
|
|
(((x + 3) * (y + 3) * 8) \
|
|
+ ((y * 64) + 1280) * DIV_ROUND_UP(x, 8))
|
|
|
|
#define ENC_V100_H264_ME_SIZE(x, y) \
|
|
(ENC_V100_BASE_SIZE(x, y) \
|
|
+ (DIV_ROUND_UP(x * y, 64) * 32))
|
|
|
|
#define ENC_V100_MPEG4_ME_SIZE(x, y) \
|
|
(ENC_V100_BASE_SIZE(x, y) \
|
|
+ (DIV_ROUND_UP(x * y, 128) * 16))
|
|
|
|
#define ENC_V100_VP8_ME_SIZE(x, y) \
|
|
ENC_V100_BASE_SIZE(x, y)
|
|
|
|
#define ENC_V100_HEVC_ME_SIZE(x, y) \
|
|
(((x + 3) * (y + 3) * 32) \
|
|
+ ((y * 128) + 1280) * DIV_ROUND_UP(x, 4))
|
|
|
|
#endif /*_REGS_MFC_V10_H*/
|
|
|