cregit-Linux how code gets into the kernel

Release 4.17 drivers/media/platform/s5p-mfc/regs-mfc-v10.h

/* 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*/


Overall Contributors

PersonTokensPropCommitsCommitProp
Smitha T Murthy229100.00%5100.00%
Total229100.00%5100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.