forked from Minki/linux
36fb494139
Firmware for MFC v6+ variants is not larger than 400 KiB, so there is no need to allocate a full 1 MiB buffer for it. Reduce it to 512 KiB to keep proper alignment of allocated buffer. Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com> Reviewed-by: Javier Martinez Canillas <javier@osg.samsung.com> Acked-by: Andrzej Hajda <a.hajda@samsung.com> Tested-by: Smitha T Murthy <smitha.t@samsung.com> Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
61 lines
2.0 KiB
C
61 lines
2.0 KiB
C
/*
|
|
* Register definition file for Samsung MFC V7.x Interface (FIMV) driver
|
|
*
|
|
* Copyright (c) 2013 Samsung Electronics Co., Ltd.
|
|
* http://www.samsung.com/
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*/
|
|
|
|
#ifndef _REGS_MFC_V7_H
|
|
#define _REGS_MFC_V7_H
|
|
|
|
#include "regs-mfc-v6.h"
|
|
|
|
/* Additional features of v7 */
|
|
#define S5P_FIMV_CODEC_VP8_ENC_V7 25
|
|
|
|
/* Additional registers for v7 */
|
|
#define S5P_FIMV_E_SOURCE_FIRST_ADDR_V7 0xf9e0
|
|
#define S5P_FIMV_E_SOURCE_SECOND_ADDR_V7 0xf9e4
|
|
#define S5P_FIMV_E_SOURCE_THIRD_ADDR_V7 0xf9e8
|
|
#define S5P_FIMV_E_SOURCE_FIRST_STRIDE_V7 0xf9ec
|
|
#define S5P_FIMV_E_SOURCE_SECOND_STRIDE_V7 0xf9f0
|
|
#define S5P_FIMV_E_SOURCE_THIRD_STRIDE_V7 0xf9f4
|
|
|
|
#define S5P_FIMV_E_ENCODED_SOURCE_FIRST_ADDR_V7 0xfa70
|
|
#define S5P_FIMV_E_ENCODED_SOURCE_SECOND_ADDR_V7 0xfa74
|
|
|
|
#define S5P_FIMV_E_VP8_OPTIONS_V7 0xfdb0
|
|
#define S5P_FIMV_E_VP8_FILTER_OPTIONS_V7 0xfdb4
|
|
#define S5P_FIMV_E_VP8_GOLDEN_FRAME_OPTION_V7 0xfdb8
|
|
#define S5P_FIMV_E_VP8_NUM_T_LAYER_V7 0xfdc4
|
|
|
|
/* MFCv7 variant defines */
|
|
#define MAX_FW_SIZE_V7 (SZ_512K) /* 512KB */
|
|
#define MAX_CPB_SIZE_V7 (3 * SZ_1M) /* 3MB */
|
|
#define MFC_VERSION_V7 0x72
|
|
#define MFC_NUM_PORTS_V7 1
|
|
|
|
#define MFC_LUMA_PAD_BYTES_V7 256
|
|
#define MFC_CHROMA_PAD_BYTES_V7 128
|
|
|
|
/* MFCv7 Context buffer sizes */
|
|
#define MFC_CTX_BUF_SIZE_V7 (30 * SZ_1K) /* 30KB */
|
|
#define MFC_H264_DEC_CTX_BUF_SIZE_V7 (2 * SZ_1M) /* 2MB */
|
|
#define MFC_OTHER_DEC_CTX_BUF_SIZE_V7 (20 * SZ_1K) /* 20KB */
|
|
#define MFC_H264_ENC_CTX_BUF_SIZE_V7 (100 * SZ_1K) /* 100KB */
|
|
#define MFC_OTHER_ENC_CTX_BUF_SIZE_V7 (10 * SZ_1K) /* 10KB */
|
|
|
|
/* Buffer size defines */
|
|
#define S5P_FIMV_SCRATCH_BUF_SIZE_MPEG4_DEC_V7(w, h) \
|
|
(SZ_1M + ((w) * 144) + (8192 * (h)) + 49216)
|
|
|
|
#define S5P_FIMV_SCRATCH_BUF_SIZE_VP8_ENC_V7(w, h) \
|
|
(((w) * 48) + 8192 + ((((w) + 1) / 2) * 128) + 144 + \
|
|
((((((w) * 16) * ((h) * 16)) * 3) / 2) * 4))
|
|
|
|
#endif /*_REGS_MFC_V7_H*/
|