1#ifndef __UAPI_MSM_ISP_H__
2#define __UAPI_MSM_ISP_H__
3
4#define BIT(nr)			(1UL << (nr))
5
6/* ISP message IDs */
7#define MSG_ID_RESET_ACK                0
8#define MSG_ID_START_ACK                1
9#define MSG_ID_STOP_ACK                 2
10#define MSG_ID_UPDATE_ACK               3
11#define MSG_ID_OUTPUT_P                 4
12#define MSG_ID_OUTPUT_T                 5
13#define MSG_ID_OUTPUT_S                 6
14#define MSG_ID_OUTPUT_V                 7
15#define MSG_ID_SNAPSHOT_DONE            8
16#define MSG_ID_STATS_AEC                9
17#define MSG_ID_STATS_AF                 10
18#define MSG_ID_STATS_AWB                11
19#define MSG_ID_STATS_RS                 12
20#define MSG_ID_STATS_CS                 13
21#define MSG_ID_STATS_IHIST              14
22#define MSG_ID_STATS_SKIN               15
23#define MSG_ID_EPOCH1                   16
24#define MSG_ID_EPOCH2                   17
25#define MSG_ID_SYNC_TIMER0_DONE         18
26#define MSG_ID_SYNC_TIMER1_DONE         19
27#define MSG_ID_SYNC_TIMER2_DONE         20
28#define MSG_ID_ASYNC_TIMER0_DONE        21
29#define MSG_ID_ASYNC_TIMER1_DONE        22
30#define MSG_ID_ASYNC_TIMER2_DONE        23
31#define MSG_ID_ASYNC_TIMER3_DONE        24
32#define MSG_ID_AE_OVERFLOW              25
33#define MSG_ID_AF_OVERFLOW              26
34#define MSG_ID_AWB_OVERFLOW             27
35#define MSG_ID_RS_OVERFLOW              28
36#define MSG_ID_CS_OVERFLOW              29
37#define MSG_ID_IHIST_OVERFLOW           30
38#define MSG_ID_SKIN_OVERFLOW            31
39#define MSG_ID_AXI_ERROR                32
40#define MSG_ID_CAMIF_OVERFLOW           33
41#define MSG_ID_VIOLATION                34
42#define MSG_ID_CAMIF_ERROR              35
43#define MSG_ID_BUS_OVERFLOW             36
44#define MSG_ID_SOF_ACK                  37
45#define MSG_ID_STOP_REC_ACK             38
46#define MSG_ID_STATS_AWB_AEC            39
47#define MSG_ID_OUTPUT_PRIMARY           40
48#define MSG_ID_OUTPUT_SECONDARY         41
49#define MSG_ID_STATS_COMPOSITE          42
50#define MSG_ID_OUTPUT_TERTIARY1         43
51#define MSG_ID_STOP_LS_ACK              44
52#define MSG_ID_OUTPUT_TERTIARY2         45
53#define MSG_ID_STATS_BG                 46
54#define MSG_ID_STATS_BF                 47
55#define MSG_ID_STATS_BHIST              48
56#define MSG_ID_RDI0_UPDATE_ACK          49
57#define MSG_ID_RDI1_UPDATE_ACK          50
58#define MSG_ID_RDI2_UPDATE_ACK          51
59#define MSG_ID_PIX0_UPDATE_ACK          52
60#define MSG_ID_PREV_STOP_ACK            53
61#define MSG_ID_STATS_BE                 54
62
63
64/* ISP command IDs */
65#define VFE_CMD_DUMMY_0                                 0
66#define VFE_CMD_SET_CLK                                 1
67#define VFE_CMD_RESET                                   2
68#define VFE_CMD_START                                   3
69#define VFE_CMD_TEST_GEN_START                          4
70#define VFE_CMD_OPERATION_CFG                           5
71#define VFE_CMD_AXI_OUT_CFG                             6
72#define VFE_CMD_CAMIF_CFG                               7
73#define VFE_CMD_AXI_INPUT_CFG                           8
74#define VFE_CMD_BLACK_LEVEL_CFG                         9
75#define VFE_CMD_MESH_ROLL_OFF_CFG                       10
76#define VFE_CMD_DEMUX_CFG                               11
77#define VFE_CMD_FOV_CFG                                 12
78#define VFE_CMD_MAIN_SCALER_CFG                         13
79#define VFE_CMD_WB_CFG                                  14
80#define VFE_CMD_COLOR_COR_CFG                           15
81#define VFE_CMD_RGB_G_CFG                               16
82#define VFE_CMD_LA_CFG                                  17
83#define VFE_CMD_CHROMA_EN_CFG                           18
84#define VFE_CMD_CHROMA_SUP_CFG                          19
85#define VFE_CMD_MCE_CFG                                 20
86#define VFE_CMD_SK_ENHAN_CFG                            21
87#define VFE_CMD_ASF_CFG                                 22
88#define VFE_CMD_S2Y_CFG                                 23
89#define VFE_CMD_S2CbCr_CFG                              24
90#define VFE_CMD_CHROMA_SUBS_CFG                         25
91#define VFE_CMD_OUT_CLAMP_CFG                           26
92#define VFE_CMD_FRAME_SKIP_CFG                          27
93#define VFE_CMD_DUMMY_1                                 28
94#define VFE_CMD_DUMMY_2                                 29
95#define VFE_CMD_DUMMY_3                                 30
96#define VFE_CMD_UPDATE                                  31
97#define VFE_CMD_BL_LVL_UPDATE                           32
98#define VFE_CMD_DEMUX_UPDATE                            33
99#define VFE_CMD_FOV_UPDATE                              34
100#define VFE_CMD_MAIN_SCALER_UPDATE                      35
101#define VFE_CMD_WB_UPDATE                               36
102#define VFE_CMD_COLOR_COR_UPDATE                        37
103#define VFE_CMD_RGB_G_UPDATE                            38
104#define VFE_CMD_LA_UPDATE                               39
105#define VFE_CMD_CHROMA_EN_UPDATE                        40
106#define VFE_CMD_CHROMA_SUP_UPDATE                       41
107#define VFE_CMD_MCE_UPDATE                              42
108#define VFE_CMD_SK_ENHAN_UPDATE                         43
109#define VFE_CMD_S2CbCr_UPDATE                           44
110#define VFE_CMD_S2Y_UPDATE                              45
111#define VFE_CMD_ASF_UPDATE                              46
112#define VFE_CMD_FRAME_SKIP_UPDATE                       47
113#define VFE_CMD_CAMIF_FRAME_UPDATE                      48
114#define VFE_CMD_STATS_AF_UPDATE                         49
115#define VFE_CMD_STATS_AE_UPDATE                         50
116#define VFE_CMD_STATS_AWB_UPDATE                        51
117#define VFE_CMD_STATS_RS_UPDATE                         52
118#define VFE_CMD_STATS_CS_UPDATE                         53
119#define VFE_CMD_STATS_SKIN_UPDATE                       54
120#define VFE_CMD_STATS_IHIST_UPDATE                      55
121#define VFE_CMD_DUMMY_4                                 56
122#define VFE_CMD_EPOCH1_ACK                              57
123#define VFE_CMD_EPOCH2_ACK                              58
124#define VFE_CMD_START_RECORDING                         59
125#define VFE_CMD_STOP_RECORDING                          60
126#define VFE_CMD_DUMMY_5                                 61
127#define VFE_CMD_DUMMY_6                                 62
128#define VFE_CMD_CAPTURE                                 63
129#define VFE_CMD_DUMMY_7                                 64
130#define VFE_CMD_STOP                                    65
131#define VFE_CMD_GET_HW_VERSION                          66
132#define VFE_CMD_GET_FRAME_SKIP_COUNTS                   67
133#define VFE_CMD_OUTPUT1_BUFFER_ENQ                      68
134#define VFE_CMD_OUTPUT2_BUFFER_ENQ                      69
135#define VFE_CMD_OUTPUT3_BUFFER_ENQ                      70
136#define VFE_CMD_JPEG_OUT_BUF_ENQ                        71
137#define VFE_CMD_RAW_OUT_BUF_ENQ                         72
138#define VFE_CMD_RAW_IN_BUF_ENQ                          73
139#define VFE_CMD_STATS_AF_ENQ                            74
140#define VFE_CMD_STATS_AE_ENQ                            75
141#define VFE_CMD_STATS_AWB_ENQ                           76
142#define VFE_CMD_STATS_RS_ENQ                            77
143#define VFE_CMD_STATS_CS_ENQ                            78
144#define VFE_CMD_STATS_SKIN_ENQ                          79
145#define VFE_CMD_STATS_IHIST_ENQ                         80
146#define VFE_CMD_DUMMY_8                                 81
147#define VFE_CMD_JPEG_ENC_CFG                            82
148#define VFE_CMD_DUMMY_9                                 83
149#define VFE_CMD_STATS_AF_START                          84
150#define VFE_CMD_STATS_AF_STOP                           85
151#define VFE_CMD_STATS_AE_START                          86
152#define VFE_CMD_STATS_AE_STOP                           87
153#define VFE_CMD_STATS_AWB_START                         88
154#define VFE_CMD_STATS_AWB_STOP                          89
155#define VFE_CMD_STATS_RS_START                          90
156#define VFE_CMD_STATS_RS_STOP                           91
157#define VFE_CMD_STATS_CS_START                          92
158#define VFE_CMD_STATS_CS_STOP                           93
159#define VFE_CMD_STATS_SKIN_START                        94
160#define VFE_CMD_STATS_SKIN_STOP                         95
161#define VFE_CMD_STATS_IHIST_START                       96
162#define VFE_CMD_STATS_IHIST_STOP                        97
163#define VFE_CMD_DUMMY_10                                98
164#define VFE_CMD_SYNC_TIMER_SETTING                      99
165#define VFE_CMD_ASYNC_TIMER_SETTING                     100
166#define VFE_CMD_LIVESHOT                                101
167#define VFE_CMD_LA_SETUP                                102
168#define VFE_CMD_LINEARIZATION_CFG                       103
169#define VFE_CMD_DEMOSAICV3                              104
170#define VFE_CMD_DEMOSAICV3_ABCC_CFG                     105
171#define VFE_CMD_DEMOSAICV3_DBCC_CFG                     106
172#define VFE_CMD_DEMOSAICV3_DBPC_CFG                     107
173#define VFE_CMD_DEMOSAICV3_ABF_CFG                      108
174#define VFE_CMD_DEMOSAICV3_ABCC_UPDATE                  109
175#define VFE_CMD_DEMOSAICV3_DBCC_UPDATE                  110
176#define VFE_CMD_DEMOSAICV3_DBPC_UPDATE                  111
177#define VFE_CMD_XBAR_CFG                                112
178#define VFE_CMD_MODULE_CFG                              113
179#define VFE_CMD_ZSL                                     114
180#define VFE_CMD_LINEARIZATION_UPDATE                    115
181#define VFE_CMD_DEMOSAICV3_ABF_UPDATE                   116
182#define VFE_CMD_CLF_CFG                                 117
183#define VFE_CMD_CLF_LUMA_UPDATE                         118
184#define VFE_CMD_CLF_CHROMA_UPDATE                       119
185#define VFE_CMD_PCA_ROLL_OFF_CFG                        120
186#define VFE_CMD_PCA_ROLL_OFF_UPDATE                     121
187#define VFE_CMD_GET_REG_DUMP                            122
188#define VFE_CMD_GET_LINEARIZATON_TABLE                  123
189#define VFE_CMD_GET_MESH_ROLLOFF_TABLE                  124
190#define VFE_CMD_GET_PCA_ROLLOFF_TABLE                   125
191#define VFE_CMD_GET_RGB_G_TABLE                         126
192#define VFE_CMD_GET_LA_TABLE                            127
193#define VFE_CMD_DEMOSAICV3_UPDATE                       128
194#define VFE_CMD_ACTIVE_REGION_CFG                       129
195#define VFE_CMD_COLOR_PROCESSING_CONFIG                 130
196#define VFE_CMD_STATS_WB_AEC_CONFIG                     131
197#define VFE_CMD_STATS_WB_AEC_UPDATE                     132
198#define VFE_CMD_Y_GAMMA_CONFIG                          133
199#define VFE_CMD_SCALE_OUTPUT1_CONFIG                    134
200#define VFE_CMD_SCALE_OUTPUT2_CONFIG                    135
201#define VFE_CMD_CAPTURE_RAW                             136
202#define VFE_CMD_STOP_LIVESHOT                           137
203#define VFE_CMD_RECONFIG_VFE                            138
204#define VFE_CMD_STATS_REQBUF                            139
205#define VFE_CMD_STATS_ENQUEUEBUF                        140
206#define VFE_CMD_STATS_FLUSH_BUFQ                        141
207#define VFE_CMD_STATS_UNREGBUF                          142
208#define VFE_CMD_STATS_BG_START                          143
209#define VFE_CMD_STATS_BG_STOP                           144
210#define VFE_CMD_STATS_BF_START                          145
211#define VFE_CMD_STATS_BF_STOP                           146
212#define VFE_CMD_STATS_BHIST_START                       147
213#define VFE_CMD_STATS_BHIST_STOP                        148
214#define VFE_CMD_RESET_2                                 149
215#define VFE_CMD_FOV_ENC_CFG                             150
216#define VFE_CMD_FOV_VIEW_CFG                            151
217#define VFE_CMD_FOV_ENC_UPDATE                          152
218#define VFE_CMD_FOV_VIEW_UPDATE                         153
219#define VFE_CMD_SCALER_ENC_CFG                          154
220#define VFE_CMD_SCALER_VIEW_CFG                         155
221#define VFE_CMD_SCALER_ENC_UPDATE                       156
222#define VFE_CMD_SCALER_VIEW_UPDATE                      157
223#define VFE_CMD_COLORXFORM_ENC_CFG                      158
224#define VFE_CMD_COLORXFORM_VIEW_CFG                     159
225#define VFE_CMD_COLORXFORM_ENC_UPDATE                   160
226#define VFE_CMD_COLORXFORM_VIEW_UPDATE                  161
227#define VFE_CMD_TEST_GEN_CFG                            162
228#define VFE_CMD_STATS_BE_START                          163
229#define VFE_CMD_STATS_BE_STOP                           164
230struct msm_isp_cmd {
231	int32_t  id;
232	uint16_t length;
233	void     *value;
234};
235
236#define VPE_CMD_DUMMY_0                                 0
237#define VPE_CMD_INIT                                    1
238#define VPE_CMD_DEINIT                                  2
239#define VPE_CMD_ENABLE                                  3
240#define VPE_CMD_DISABLE                                 4
241#define VPE_CMD_RESET                                   5
242#define VPE_CMD_FLUSH                                   6
243#define VPE_CMD_OPERATION_MODE_CFG                      7
244#define VPE_CMD_INPUT_PLANE_CFG                         8
245#define VPE_CMD_OUTPUT_PLANE_CFG                        9
246#define VPE_CMD_INPUT_PLANE_UPDATE                      10
247#define VPE_CMD_SCALE_CFG_TYPE                          11
248#define VPE_CMD_ZOOM                                    13
249#define VPE_CMD_MAX                                     14
250
251#define MSM_PP_CMD_TYPE_NOT_USED        0  /* not used */
252#define MSM_PP_CMD_TYPE_VPE             1  /* VPE cmd */
253#define MSM_PP_CMD_TYPE_MCTL            2  /* MCTL cmd */
254
255#define MCTL_CMD_DUMMY_0                0  /* not used */
256#define MCTL_CMD_GET_FRAME_BUFFER       1  /* reserve a free frame buffer */
257#define MCTL_CMD_PUT_FRAME_BUFFER       2  /* return the free frame buffer */
258#define MCTL_CMD_DIVERT_FRAME_PP_PATH   3  /* divert frame for pp */
259
260/* event typese sending to MCTL PP module */
261#define MCTL_PP_EVENT_NOTUSED           0
262#define MCTL_PP_EVENT_CMD_ACK           1
263
264#define VPE_OPERATION_MODE_CFG_LEN      4
265#define VPE_INPUT_PLANE_CFG_LEN         24
266#define VPE_OUTPUT_PLANE_CFG_LEN        20
267#define VPE_INPUT_PLANE_UPDATE_LEN      12
268#define VPE_SCALER_CONFIG_LEN           260
269#define VPE_DIS_OFFSET_CFG_LEN          12
270
271
272#define CAPTURE_WIDTH          1280
273#define IMEM_Y_SIZE            (CAPTURE_WIDTH*16)
274#define IMEM_CBCR_SIZE         (CAPTURE_WIDTH*8)
275
276#define IMEM_Y_PING_OFFSET     0x2E000000
277#define IMEM_CBCR_PING_OFFSET  (IMEM_Y_PING_OFFSET + IMEM_Y_SIZE)
278
279#define IMEM_Y_PONG_OFFSET     (IMEM_CBCR_PING_OFFSET + IMEM_CBCR_SIZE)
280#define IMEM_CBCR_PONG_OFFSET  (IMEM_Y_PONG_OFFSET + IMEM_Y_SIZE)
281
282
283struct msm_vpe_op_mode_cfg {
284	uint8_t op_mode_cfg[VPE_OPERATION_MODE_CFG_LEN];
285};
286
287struct msm_vpe_input_plane_cfg {
288	uint8_t input_plane_cfg[VPE_INPUT_PLANE_CFG_LEN];
289};
290
291struct msm_vpe_output_plane_cfg {
292	uint8_t output_plane_cfg[VPE_OUTPUT_PLANE_CFG_LEN];
293};
294
295struct msm_vpe_input_plane_update_cfg {
296	uint8_t input_plane_update_cfg[VPE_INPUT_PLANE_UPDATE_LEN];
297};
298
299struct msm_vpe_scaler_cfg {
300	uint8_t scaler_cfg[VPE_SCALER_CONFIG_LEN];
301};
302
303struct msm_vpe_flush_frame_buffer {
304	uint32_t src_buf_handle;
305	uint32_t dest_buf_handle;
306	int path;
307};
308
309struct msm_mctl_pp_frame_buffer {
310	uint32_t buf_handle;
311	int path;
312};
313struct msm_mctl_pp_divert_pp {
314	int path;
315	int enable;
316};
317struct msm_vpe_clock_rate {
318	uint32_t rate;
319};
320
321#define MSM_MCTL_PP_VPE_FRAME_ACK    (1<<0)
322#define MSM_MCTL_PP_VPE_FRAME_TO_APP (1<<1)
323
324#define VFE_OUTPUTS_MAIN_AND_PREVIEW    BIT(0)
325#define VFE_OUTPUTS_MAIN_AND_VIDEO      BIT(1)
326#define VFE_OUTPUTS_MAIN_AND_THUMB      BIT(2)
327#define VFE_OUTPUTS_THUMB_AND_MAIN      BIT(3)
328#define VFE_OUTPUTS_PREVIEW_AND_VIDEO   BIT(4)
329#define VFE_OUTPUTS_VIDEO_AND_PREVIEW   BIT(5)
330#define VFE_OUTPUTS_PREVIEW             BIT(6)
331#define VFE_OUTPUTS_VIDEO               BIT(7)
332#define VFE_OUTPUTS_RAW                 BIT(8)
333#define VFE_OUTPUTS_JPEG_AND_THUMB      BIT(9)
334#define VFE_OUTPUTS_THUMB_AND_JPEG      BIT(10)
335#define VFE_OUTPUTS_RDI0                BIT(11)
336#define VFE_OUTPUTS_RDI1                BIT(12)
337
338struct msm_frame_info {
339	uint32_t inst_handle;
340	uint32_t path;
341};
342
343#endif /*__UAPI_MSM_ISP_H__*/
344
345