Merge git://git.kernel.org/pub/scm/linux/kernel/git/nab/target-pending
[firefly-linux-kernel-4.4.55.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_D_INIT_BUFFER_OPTIONS_V7               0xf47c
22
23 #define S5P_FIMV_E_SOURCE_FIRST_ADDR_V7                 0xf9e0
24 #define S5P_FIMV_E_SOURCE_SECOND_ADDR_V7                0xf9e4
25 #define S5P_FIMV_E_SOURCE_THIRD_ADDR_V7                 0xf9e8
26 #define S5P_FIMV_E_SOURCE_FIRST_STRIDE_V7               0xf9ec
27 #define S5P_FIMV_E_SOURCE_SECOND_STRIDE_V7              0xf9f0
28 #define S5P_FIMV_E_SOURCE_THIRD_STRIDE_V7               0xf9f4
29
30 #define S5P_FIMV_E_ENCODED_SOURCE_FIRST_ADDR_V7         0xfa70
31 #define S5P_FIMV_E_ENCODED_SOURCE_SECOND_ADDR_V7        0xfa74
32
33 #define S5P_FIMV_E_VP8_OPTIONS_V7                       0xfdb0
34 #define S5P_FIMV_E_VP8_FILTER_OPTIONS_V7                0xfdb4
35 #define S5P_FIMV_E_VP8_GOLDEN_FRAME_OPTION_V7           0xfdb8
36 #define S5P_FIMV_E_VP8_NUM_T_LAYER_V7                   0xfdc4
37
38 /* MFCv7 variant defines */
39 #define MAX_FW_SIZE_V7                  (SZ_1M)         /* 1MB */
40 #define MAX_CPB_SIZE_V7                 (3 * SZ_1M)     /* 3MB */
41 #define MFC_VERSION_V7                  0x72
42 #define MFC_NUM_PORTS_V7                1
43
44 #define MFC_LUMA_PAD_BYTES_V7           256
45 #define MFC_CHROMA_PAD_BYTES_V7         128
46
47 /* MFCv7 Context buffer sizes */
48 #define MFC_CTX_BUF_SIZE_V7             (30 * SZ_1K)    /*  30KB */
49 #define MFC_H264_DEC_CTX_BUF_SIZE_V7    (2 * SZ_1M)     /*  2MB */
50 #define MFC_OTHER_DEC_CTX_BUF_SIZE_V7   (20 * SZ_1K)    /*  20KB */
51 #define MFC_H264_ENC_CTX_BUF_SIZE_V7    (100 * SZ_1K)   /* 100KB */
52 #define MFC_OTHER_ENC_CTX_BUF_SIZE_V7   (10 * SZ_1K)    /*  10KB */
53
54 /* Buffer size defines */
55 #define S5P_FIMV_SCRATCH_BUF_SIZE_MPEG4_DEC_V7(w, h) \
56                         (SZ_1M + ((w) * 144) + (8192 * (h)) + 49216)
57
58 #define S5P_FIMV_SCRATCH_BUF_SIZE_VP8_ENC_V7(w, h) \
59                         (((w) * 48) + (((w) + 1) / 2 * 128) + 144 + 8192)
60
61 #endif /*_REGS_MFC_V7_H*/