blob: dae4a12c1623ef4204147f687015a2a12fa2fc63 [file] [log] [blame]
Shuzhen Wangce650862011-08-17 15:27:01 -07001#ifndef __MSM_ISP_H__
2#define __MSM_ISP_H__
3
4/* ISP message IDs */
5#define MSG_ID_RESET_ACK 0
6#define MSG_ID_START_ACK 1
7#define MSG_ID_STOP_ACK 2
8#define MSG_ID_UPDATE_ACK 3
9#define MSG_ID_OUTPUT_P 4
10#define MSG_ID_OUTPUT_T 5
11#define MSG_ID_OUTPUT_S 6
12#define MSG_ID_OUTPUT_V 7
13#define MSG_ID_SNAPSHOT_DONE 8
14#define MSG_ID_STATS_AEC 9
15#define MSG_ID_STATS_AF 10
16#define MSG_ID_STATS_AWB 11
17#define MSG_ID_STATS_RS 12
18#define MSG_ID_STATS_CS 13
19#define MSG_ID_STATS_IHIST 14
20#define MSG_ID_STATS_SKIN 15
21#define MSG_ID_EPOCH1 16
22#define MSG_ID_EPOCH2 17
23#define MSG_ID_SYNC_TIMER0_DONE 18
24#define MSG_ID_SYNC_TIMER1_DONE 19
25#define MSG_ID_SYNC_TIMER2_DONE 20
26#define MSG_ID_ASYNC_TIMER0_DONE 21
27#define MSG_ID_ASYNC_TIMER1_DONE 22
28#define MSG_ID_ASYNC_TIMER2_DONE 23
29#define MSG_ID_ASYNC_TIMER3_DONE 24
30#define MSG_ID_AE_OVERFLOW 25
31#define MSG_ID_AF_OVERFLOW 26
32#define MSG_ID_AWB_OVERFLOW 27
33#define MSG_ID_RS_OVERFLOW 28
34#define MSG_ID_CS_OVERFLOW 29
35#define MSG_ID_IHIST_OVERFLOW 30
36#define MSG_ID_SKIN_OVERFLOW 31
37#define MSG_ID_AXI_ERROR 32
38#define MSG_ID_CAMIF_OVERFLOW 33
39#define MSG_ID_VIOLATION 34
40#define MSG_ID_CAMIF_ERROR 35
41#define MSG_ID_BUS_OVERFLOW 36
42#define MSG_ID_SOF_ACK 37
43#define MSG_ID_STOP_REC_ACK 38
Suresh Vankadara055cb8e2012-01-18 00:50:04 +053044#define MSG_ID_STATS_AWB_AEC 39
Shuzhen Wangce650862011-08-17 15:27:01 -070045
46/* ISP command IDs */
47#define VFE_CMD_DUMMY_0 0
48#define VFE_CMD_SET_CLK 1
49#define VFE_CMD_RESET 2
50#define VFE_CMD_START 3
51#define VFE_CMD_TEST_GEN_START 4
52#define VFE_CMD_OPERATION_CFG 5
53#define VFE_CMD_AXI_OUT_CFG 6
54#define VFE_CMD_CAMIF_CFG 7
55#define VFE_CMD_AXI_INPUT_CFG 8
56#define VFE_CMD_BLACK_LEVEL_CFG 9
Ujwal Pateledcbdcc2011-08-24 09:14:14 -070057#define VFE_CMD_MESH_ROLL_OFF_CFG 10
Shuzhen Wangce650862011-08-17 15:27:01 -070058#define VFE_CMD_DEMUX_CFG 11
59#define VFE_CMD_FOV_CFG 12
60#define VFE_CMD_MAIN_SCALER_CFG 13
61#define VFE_CMD_WB_CFG 14
62#define VFE_CMD_COLOR_COR_CFG 15
63#define VFE_CMD_RGB_G_CFG 16
64#define VFE_CMD_LA_CFG 17
65#define VFE_CMD_CHROMA_EN_CFG 18
66#define VFE_CMD_CHROMA_SUP_CFG 19
67#define VFE_CMD_MCE_CFG 20
68#define VFE_CMD_SK_ENHAN_CFG 21
69#define VFE_CMD_ASF_CFG 22
70#define VFE_CMD_S2Y_CFG 23
71#define VFE_CMD_S2CbCr_CFG 24
72#define VFE_CMD_CHROMA_SUBS_CFG 25
73#define VFE_CMD_OUT_CLAMP_CFG 26
74#define VFE_CMD_FRAME_SKIP_CFG 27
75#define VFE_CMD_DUMMY_1 28
76#define VFE_CMD_DUMMY_2 29
77#define VFE_CMD_DUMMY_3 30
78#define VFE_CMD_UPDATE 31
79#define VFE_CMD_BL_LVL_UPDATE 32
80#define VFE_CMD_DEMUX_UPDATE 33
81#define VFE_CMD_FOV_UPDATE 34
82#define VFE_CMD_MAIN_SCALER_UPDATE 35
83#define VFE_CMD_WB_UPDATE 36
84#define VFE_CMD_COLOR_COR_UPDATE 37
85#define VFE_CMD_RGB_G_UPDATE 38
86#define VFE_CMD_LA_UPDATE 39
87#define VFE_CMD_CHROMA_EN_UPDATE 40
88#define VFE_CMD_CHROMA_SUP_UPDATE 41
89#define VFE_CMD_MCE_UPDATE 42
90#define VFE_CMD_SK_ENHAN_UPDATE 43
91#define VFE_CMD_S2CbCr_UPDATE 44
92#define VFE_CMD_S2Y_UPDATE 45
93#define VFE_CMD_ASF_UPDATE 46
94#define VFE_CMD_FRAME_SKIP_UPDATE 47
95#define VFE_CMD_CAMIF_FRAME_UPDATE 48
96#define VFE_CMD_STATS_AF_UPDATE 49
97#define VFE_CMD_STATS_AE_UPDATE 50
98#define VFE_CMD_STATS_AWB_UPDATE 51
99#define VFE_CMD_STATS_RS_UPDATE 52
100#define VFE_CMD_STATS_CS_UPDATE 53
101#define VFE_CMD_STATS_SKIN_UPDATE 54
102#define VFE_CMD_STATS_IHIST_UPDATE 55
103#define VFE_CMD_DUMMY_4 56
104#define VFE_CMD_EPOCH1_ACK 57
105#define VFE_CMD_EPOCH2_ACK 58
106#define VFE_CMD_START_RECORDING 59
107#define VFE_CMD_STOP_RECORDING 60
108#define VFE_CMD_DUMMY_5 61
109#define VFE_CMD_DUMMY_6 62
110#define VFE_CMD_CAPTURE 63
111#define VFE_CMD_DUMMY_7 64
112#define VFE_CMD_STOP 65
113#define VFE_CMD_GET_HW_VERSION 66
114#define VFE_CMD_GET_FRAME_SKIP_COUNTS 67
115#define VFE_CMD_OUTPUT1_BUFFER_ENQ 68
116#define VFE_CMD_OUTPUT2_BUFFER_ENQ 69
117#define VFE_CMD_OUTPUT3_BUFFER_ENQ 70
118#define VFE_CMD_JPEG_OUT_BUF_ENQ 71
119#define VFE_CMD_RAW_OUT_BUF_ENQ 72
120#define VFE_CMD_RAW_IN_BUF_ENQ 73
121#define VFE_CMD_STATS_AF_ENQ 74
122#define VFE_CMD_STATS_AE_ENQ 75
123#define VFE_CMD_STATS_AWB_ENQ 76
124#define VFE_CMD_STATS_RS_ENQ 77
125#define VFE_CMD_STATS_CS_ENQ 78
126#define VFE_CMD_STATS_SKIN_ENQ 79
127#define VFE_CMD_STATS_IHIST_ENQ 80
128#define VFE_CMD_DUMMY_8 81
129#define VFE_CMD_JPEG_ENC_CFG 82
130#define VFE_CMD_DUMMY_9 83
131#define VFE_CMD_STATS_AF_START 84
132#define VFE_CMD_STATS_AF_STOP 85
133#define VFE_CMD_STATS_AE_START 86
134#define VFE_CMD_STATS_AE_STOP 87
135#define VFE_CMD_STATS_AWB_START 88
136#define VFE_CMD_STATS_AWB_STOP 89
137#define VFE_CMD_STATS_RS_START 90
138#define VFE_CMD_STATS_RS_STOP 91
139#define VFE_CMD_STATS_CS_START 92
140#define VFE_CMD_STATS_CS_STOP 93
141#define VFE_CMD_STATS_SKIN_START 94
142#define VFE_CMD_STATS_SKIN_STOP 95
143#define VFE_CMD_STATS_IHIST_START 96
144#define VFE_CMD_STATS_IHIST_STOP 97
145#define VFE_CMD_DUMMY_10 98
146#define VFE_CMD_SYNC_TIMER_SETTING 99
147#define VFE_CMD_ASYNC_TIMER_SETTING 100
148#define VFE_CMD_LIVESHOT 101
149#define VFE_CMD_LA_SETUP 102
150#define VFE_CMD_LINEARIZATION_CFG 103
151#define VFE_CMD_DEMOSAICV3 104
152#define VFE_CMD_DEMOSAICV3_ABCC_CFG 105
153#define VFE_CMD_DEMOSAICV3_DBCC_CFG 106
154#define VFE_CMD_DEMOSAICV3_DBPC_CFG 107
155#define VFE_CMD_DEMOSAICV3_ABF_CFG 108
156#define VFE_CMD_DEMOSAICV3_ABCC_UPDATE 109
157#define VFE_CMD_DEMOSAICV3_DBCC_UPDATE 110
158#define VFE_CMD_DEMOSAICV3_DBPC_UPDATE 111
159#define VFE_CMD_XBAR_CFG 112
Ujwal Patel1fe4c9c2011-10-07 12:19:52 -0700160#define VFE_CMD_MODULE_CFG 113
Shuzhen Wangce650862011-08-17 15:27:01 -0700161#define VFE_CMD_ZSL 114
162#define VFE_CMD_LINEARIZATION_UPDATE 115
163#define VFE_CMD_DEMOSAICV3_ABF_UPDATE 116
164#define VFE_CMD_CLF_CFG 117
165#define VFE_CMD_CLF_LUMA_UPDATE 118
166#define VFE_CMD_CLF_CHROMA_UPDATE 119
Ujwal Pateledcbdcc2011-08-24 09:14:14 -0700167#define VFE_CMD_PCA_ROLL_OFF_CFG 120
168#define VFE_CMD_PCA_ROLL_OFF_UPDATE 121
Ujwal Patel6e4308d2011-10-25 11:24:52 -0700169#define VFE_CMD_GET_REG_DUMP 122
170#define VFE_CMD_GET_LINEARIZATON_TABLE 123
171#define VFE_CMD_GET_MESH_ROLLOFF_TABLE 124
172#define VFE_CMD_GET_PCA_ROLLOFF_TABLE 125
173#define VFE_CMD_GET_RGB_G_TABLE 126
174#define VFE_CMD_GET_LA_TABLE 127
Azam Sadiq Pasha Kapatrala Syed5156dd42011-10-27 19:30:13 -0700175#define VFE_CMD_DEMOSAICV3_UPDATE 128
Suresh Vankadara055cb8e2012-01-18 00:50:04 +0530176#define VFE_CMD_ACTIVE_REGION_CFG 129
177#define VFE_CMD_COLOR_PROCESSING_CONFIG 130
178#define VFE_CMD_STATS_WB_AEC_CONFIG 131
179#define VFE_CMD_STATS_WB_AEC_UPDATE 132
180#define VFE_CMD_Y_GAMMA_CONFIG 133
181#define VFE_CMD_SCALE_OUTPUT1_CONFIG 134
182#define VFE_CMD_SCALE_OUTPUT2_CONFIG 135
Shuzhen Wangce650862011-08-17 15:27:01 -0700183
Shuzhen Wang6b0f3322011-08-26 12:14:43 -0700184struct msm_isp_cmd {
185 int32_t id;
186 uint16_t length;
187 void *value;
188};
189
Mingcheng Zhu8e9f99e2011-08-26 16:33:32 -0700190#define VPE_CMD_DUMMY_0 0
191#define VPE_CMD_INIT 1
192#define VPE_CMD_DEINIT 2
193#define VPE_CMD_ENABLE 3
194#define VPE_CMD_DISABLE 4
195#define VPE_CMD_RESET 5
196#define VPE_CMD_FLUSH 6
197#define VPE_CMD_OPERATION_MODE_CFG 7
198#define VPE_CMD_INPUT_PLANE_CFG 8
199#define VPE_CMD_OUTPUT_PLANE_CFG 9
200#define VPE_CMD_INPUT_PLANE_UPDATE 10
201#define VPE_CMD_SCALE_CFG_TYPE 11
202#define VPE_CMD_DIS_OFFSET_CFG 12
203#define VPE_CMD_ZOOM 13
204
205#define MSM_PP_CMD_TYPE_NOT_USED 0 /* not used */
206#define MSM_PP_CMD_TYPE_VPE 1 /* VPE cmd */
207#define MSM_PP_CMD_TYPE_MCTL 2 /* MCTL cmd */
208
209#define MCTL_CMD_DUMMY_0 0 /* not used */
210#define MCTL_CMD_GET_FRAME_BUFFER 1 /* reserve a free frame buffer */
211#define MCTL_CMD_PUT_FRAME_BUFFER 2 /* return the free frame buffer */
212#define MCTL_CMD_DIVERT_FRAME_PP_PATH 3 /* divert frame for pp */
Mingcheng Zhu8e9f99e2011-08-26 16:33:32 -0700213
214/* event typese sending to MCTL PP module */
215#define MCTL_PP_EVENT_NOTUSED 0
216#define MCTL_PP_EVENT_CMD_ACK 1
217
218#define VPE_OPERATION_MODE_CFG_LEN 8
219#define VPE_INPUT_PLANE_CFG_LEN 24
220#define VPE_OUTPUT_PLANE_CFG_LEN 24
221#define VPE_INPUT_PLANE_UPDATE_LEN 12
222#define VPE_SCALER_CONFIG_LEN 260
223#define VPE_DIS_OFFSET_CFG_LEN 12
224
225struct msm_vpe_op_mode_cfg {
226 uint8_t op_mode_cfg[VPE_OPERATION_MODE_CFG_LEN];
227};
228
229struct msm_vpe_input_plane_cfg {
230 uint8_t input_plane_cfg[VPE_INPUT_PLANE_CFG_LEN];
231};
232
233struct msm_vpe_output_plane_cfg {
234 uint8_t output_plane_cfg[VPE_OUTPUT_PLANE_CFG_LEN];
235};
236
237struct msm_vpe_input_plane_update_cfg {
238 uint8_t input_plane_update_cfg[VPE_INPUT_PLANE_UPDATE_LEN];
239};
240
241struct msm_vpe_scaler_cfg {
242 uint8_t scaler_cfg[VPE_SCALER_CONFIG_LEN];
243};
244
245struct msm_vpe_dis_offset_cfg {
246 uint8_t dis_offset_cfg[VPE_DIS_OFFSET_CFG_LEN];
247};
248
249struct msm_vpe_flush_frame_buffer {
250 uint32_t src_buf_handle;
251 uint32_t dest_buf_handle;
252 int path;
253};
254
255struct msm_mctl_pp_frame_buffer {
256 uint32_t buf_handle;
257 int path;
258};
259struct msm_mctl_pp_divert_pp {
260 int path;
Mingcheng Zhu8feaa3f2011-11-23 11:33:52 -0800261 int enable;
Mingcheng Zhu8e9f99e2011-08-26 16:33:32 -0700262};
263struct msm_vpe_clock_rate {
264 uint32_t rate;
265};
266struct msm_pp_crop {
267 uint32_t src_x;
268 uint32_t src_y;
269 uint32_t src_w;
270 uint32_t src_h;
271 uint32_t dst_x;
272 uint32_t dst_y;
273 uint32_t dst_w;
274 uint32_t dst_h;
275 uint8_t update_flag;
276};
277#define MSM_MCTL_PP_VPE_FRAME_ACK (1<<0)
278#define MSM_MCTL_PP_VPE_FRAME_TO_APP (1<<1)
279
280struct msm_mctl_pp_frame_cmd {
281 uint32_t cookie;
282 uint8_t vpe_output_action;
283 uint32_t src_buf_handle;
284 uint32_t dest_buf_handle;
285 struct msm_pp_crop crop;
286 int path;
287 /* TBD: 3D related */
288};
289
Mingcheng Zhu8e9f99e2011-08-26 16:33:32 -0700290#endif /*__MSM_ISP_H__*/
291