]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blob - drivers/media/platform/s5p-mfc/regs-mfc-v7.h
[media] s5p-mfc: Move INIT_BUFFER_OPTIONS from v7 to v6
[mirror_ubuntu-artful-kernel.git] / drivers / media / platform / s5p-mfc / regs-mfc-v7.h
1 /*
2 * Register definition file for Samsung MFC V7.x Interface (FIMV) driver
3 *
4 * Copyright (c) 2013 Samsung Electronics Co., Ltd.
5 * http://www.samsung.com/
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 */
11
12 #ifndef _REGS_MFC_V7_H
13 #define _REGS_MFC_V7_H
14
15 #include "regs-mfc-v6.h"
16
17 /* Additional features of v7 */
18 #define S5P_FIMV_CODEC_VP8_ENC_V7 25
19
20 /* Additional registers for v7 */
21 #define S5P_FIMV_E_SOURCE_FIRST_ADDR_V7 0xf9e0
22 #define S5P_FIMV_E_SOURCE_SECOND_ADDR_V7 0xf9e4
23 #define S5P_FIMV_E_SOURCE_THIRD_ADDR_V7 0xf9e8
24 #define S5P_FIMV_E_SOURCE_FIRST_STRIDE_V7 0xf9ec
25 #define S5P_FIMV_E_SOURCE_SECOND_STRIDE_V7 0xf9f0
26 #define S5P_FIMV_E_SOURCE_THIRD_STRIDE_V7 0xf9f4
27
28 #define S5P_FIMV_E_ENCODED_SOURCE_FIRST_ADDR_V7 0xfa70
29 #define S5P_FIMV_E_ENCODED_SOURCE_SECOND_ADDR_V7 0xfa74
30
31 #define S5P_FIMV_E_VP8_OPTIONS_V7 0xfdb0
32 #define S5P_FIMV_E_VP8_FILTER_OPTIONS_V7 0xfdb4
33 #define S5P_FIMV_E_VP8_GOLDEN_FRAME_OPTION_V7 0xfdb8
34 #define S5P_FIMV_E_VP8_NUM_T_LAYER_V7 0xfdc4
35
36 /* MFCv7 variant defines */
37 #define MAX_FW_SIZE_V7 (SZ_1M) /* 1MB */
38 #define MAX_CPB_SIZE_V7 (3 * SZ_1M) /* 3MB */
39 #define MFC_VERSION_V7 0x72
40 #define MFC_NUM_PORTS_V7 1
41
42 #define MFC_LUMA_PAD_BYTES_V7 256
43 #define MFC_CHROMA_PAD_BYTES_V7 128
44
45 /* MFCv7 Context buffer sizes */
46 #define MFC_CTX_BUF_SIZE_V7 (30 * SZ_1K) /* 30KB */
47 #define MFC_H264_DEC_CTX_BUF_SIZE_V7 (2 * SZ_1M) /* 2MB */
48 #define MFC_OTHER_DEC_CTX_BUF_SIZE_V7 (20 * SZ_1K) /* 20KB */
49 #define MFC_H264_ENC_CTX_BUF_SIZE_V7 (100 * SZ_1K) /* 100KB */
50 #define MFC_OTHER_ENC_CTX_BUF_SIZE_V7 (10 * SZ_1K) /* 10KB */
51
52 /* Buffer size defines */
53 #define S5P_FIMV_SCRATCH_BUF_SIZE_MPEG4_DEC_V7(w, h) \
54 (SZ_1M + ((w) * 144) + (8192 * (h)) + 49216)
55
56 #define S5P_FIMV_SCRATCH_BUF_SIZE_VP8_ENC_V7(w, h) \
57 (((w) * 48) + 8192 + ((((w) + 1) / 2) * 128) + 144 + \
58 ((((((w) * 16) * ((h) * 16)) * 3) / 2) * 4))
59
60 #endif /*_REGS_MFC_V7_H*/