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