2 * Support for Intel Camera Imaging ISP subsystem.
3 * Copyright (c) 2010-2016, Intel Corporation.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms and conditions of the GNU General Public License,
7 * version 2, as published by the Free Software Foundation.
9 * This program is distributed in the hope it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
15 #include <stddef.h> /* NULL */
19 #include "assert_support.h"
21 #ifndef __INLINE_DMA__
22 #include "dma_private.h"
23 #endif /* __INLINE_DMA__ */
25 void dma_get_state(const dma_ID_t ID, dma_state_t *state)
30 assert(ID < N_DMA_ID);
31 assert(state != NULL);
33 tmp = dma_reg_load(ID, DMA_COMMAND_FSM_REG_IDX);
34 //reg [3:0] : flags error [3], stall, run, idle [0]
36 //reg[14:10] : channel
38 state->fsm_command_idle = tmp & 0x1;
39 state->fsm_command_run = tmp & 0x2;
40 state->fsm_command_stalling = tmp & 0x4;
41 state->fsm_command_error = tmp & 0x8;
42 state->last_command_channel = (tmp>>10 & 0x1F);
43 state->last_command_param = (tmp>>15 & 0x0F);
44 tmp = (tmp>>4) & 0x3F;
45 /* state->last_command = (dma_commands_t)tmp; */
46 /* if the enumerator is made non-linear */
47 /* AM: the list below does not cover all the cases*/
48 /* and these are not correct */
49 /* therefore for just dumpinmg this command*/
50 state->last_command = tmp;
54 state->last_command = DMA_COMMAND_READ;
56 state->last_command = DMA_COMMAND_WRITE;
58 state->last_command = DMA_COMMAND_SET_CHANNEL;
60 state->last_command = DMA_COMMAND_SET_PARAM;
62 state->last_command = DMA_COMMAND_READ_SPECIFIC;
64 state->last_command = DMA_COMMAND_WRITE_SPECIFIC;
66 state->last_command = DMA_COMMAND_INIT;
68 state->last_command = DMA_COMMAND_INIT_SPECIFIC;
70 state->last_command = DMA_COMMAND_RST;
73 /* No sub-fields, idx = 0 */
74 state->current_command = dma_reg_load(ID,
75 DMA_CG_INFO_REG_IDX(0, _DMA_FSM_GROUP_CMD_IDX));
76 state->current_addr_a = dma_reg_load(ID,
77 DMA_CG_INFO_REG_IDX(0, _DMA_FSM_GROUP_ADDR_A_IDX));
78 state->current_addr_b = dma_reg_load(ID,
79 DMA_CG_INFO_REG_IDX(0, _DMA_FSM_GROUP_ADDR_B_IDX));
81 tmp = dma_reg_load(ID,
83 _DMA_FSM_GROUP_FSM_CTRL_STATE_IDX,
84 _DMA_FSM_GROUP_FSM_CTRL_IDX));
85 state->fsm_ctrl_idle = tmp & 0x1;
86 state->fsm_ctrl_run = tmp & 0x2;
87 state->fsm_ctrl_stalling = tmp & 0x4;
88 state->fsm_ctrl_error = tmp & 0x8;
90 /* state->fsm_ctrl_state = (dma_ctrl_states_t)tmp; */
92 state->fsm_ctrl_state = DMA_CTRL_STATE_IDLE;
94 state->fsm_ctrl_state = DMA_CTRL_STATE_REQ_RCV;
96 state->fsm_ctrl_state = DMA_CTRL_STATE_RCV;
98 state->fsm_ctrl_state = DMA_CTRL_STATE_RCV_REQ;
100 state->fsm_ctrl_state = DMA_CTRL_STATE_INIT;
101 state->fsm_ctrl_source_dev = dma_reg_load(ID,
103 _DMA_FSM_GROUP_FSM_CTRL_REQ_DEV_IDX,
104 _DMA_FSM_GROUP_FSM_CTRL_IDX));
105 state->fsm_ctrl_source_addr = dma_reg_load(ID,
107 _DMA_FSM_GROUP_FSM_CTRL_REQ_ADDR_IDX,
108 _DMA_FSM_GROUP_FSM_CTRL_IDX));
109 state->fsm_ctrl_source_stride = dma_reg_load(ID,
111 _DMA_FSM_GROUP_FSM_CTRL_REQ_STRIDE_IDX,
112 _DMA_FSM_GROUP_FSM_CTRL_IDX));
113 state->fsm_ctrl_source_width = dma_reg_load(ID,
115 _DMA_FSM_GROUP_FSM_CTRL_REQ_XB_IDX,
116 _DMA_FSM_GROUP_FSM_CTRL_IDX));
117 state->fsm_ctrl_source_height = dma_reg_load(ID,
119 _DMA_FSM_GROUP_FSM_CTRL_REQ_YB_IDX,
120 _DMA_FSM_GROUP_FSM_CTRL_IDX));
121 state->fsm_ctrl_pack_source_dev = dma_reg_load(ID,
123 _DMA_FSM_GROUP_FSM_CTRL_PACK_REQ_DEV_IDX,
124 _DMA_FSM_GROUP_FSM_CTRL_IDX));
125 state->fsm_ctrl_pack_dest_dev = dma_reg_load(ID,
127 _DMA_FSM_GROUP_FSM_CTRL_PACK_WR_DEV_IDX,
128 _DMA_FSM_GROUP_FSM_CTRL_IDX));
129 state->fsm_ctrl_dest_addr = dma_reg_load(ID,
131 _DMA_FSM_GROUP_FSM_CTRL_WR_ADDR_IDX,
132 _DMA_FSM_GROUP_FSM_CTRL_IDX));
133 state->fsm_ctrl_dest_stride = dma_reg_load(ID,
135 _DMA_FSM_GROUP_FSM_CTRL_WR_STRIDE_IDX,
136 _DMA_FSM_GROUP_FSM_CTRL_IDX));
137 state->fsm_ctrl_pack_source_width = dma_reg_load(ID,
139 _DMA_FSM_GROUP_FSM_CTRL_PACK_REQ_XB_IDX,
140 _DMA_FSM_GROUP_FSM_CTRL_IDX));
141 state->fsm_ctrl_pack_dest_height = dma_reg_load(ID,
143 _DMA_FSM_GROUP_FSM_CTRL_PACK_WR_YB_IDX,
144 _DMA_FSM_GROUP_FSM_CTRL_IDX));
145 state->fsm_ctrl_pack_dest_width = dma_reg_load(ID,
147 _DMA_FSM_GROUP_FSM_CTRL_PACK_WR_XB_IDX,
148 _DMA_FSM_GROUP_FSM_CTRL_IDX));
149 state->fsm_ctrl_pack_source_elems = dma_reg_load(ID,
151 _DMA_FSM_GROUP_FSM_CTRL_PACK_ELEM_REQ_IDX,
152 _DMA_FSM_GROUP_FSM_CTRL_IDX));
153 state->fsm_ctrl_pack_dest_elems = dma_reg_load(ID,
155 _DMA_FSM_GROUP_FSM_CTRL_PACK_ELEM_WR_IDX,
156 _DMA_FSM_GROUP_FSM_CTRL_IDX));
157 state->fsm_ctrl_pack_extension = dma_reg_load(ID,
159 _DMA_FSM_GROUP_FSM_CTRL_PACK_S_Z_IDX,
160 _DMA_FSM_GROUP_FSM_CTRL_IDX));
162 tmp = dma_reg_load(ID,
164 _DMA_FSM_GROUP_FSM_PACK_STATE_IDX,
165 _DMA_FSM_GROUP_FSM_PACK_IDX));
166 state->pack_idle = tmp & 0x1;
167 state->pack_run = tmp & 0x2;
168 state->pack_stalling = tmp & 0x4;
169 state->pack_error = tmp & 0x8;
170 state->pack_cnt_height = dma_reg_load(ID,
172 _DMA_FSM_GROUP_FSM_PACK_CNT_YB_IDX,
173 _DMA_FSM_GROUP_FSM_PACK_IDX));
174 state->pack_src_cnt_width = dma_reg_load(ID,
176 _DMA_FSM_GROUP_FSM_PACK_CNT_XB_REQ_IDX,
177 _DMA_FSM_GROUP_FSM_PACK_IDX));
178 state->pack_dest_cnt_width = dma_reg_load(ID,
180 _DMA_FSM_GROUP_FSM_PACK_CNT_XB_WR_IDX,
181 _DMA_FSM_GROUP_FSM_PACK_IDX));
183 tmp = dma_reg_load(ID,
185 _DMA_FSM_GROUP_FSM_REQ_STATE_IDX,
186 _DMA_FSM_GROUP_FSM_REQ_IDX));
187 /* state->read_state = (dma_rw_states_t)tmp; */
189 state->read_state = DMA_RW_STATE_IDLE;
191 state->read_state = DMA_RW_STATE_REQ;
193 state->read_state = DMA_RW_STATE_NEXT_LINE;
195 state->read_state = DMA_RW_STATE_UNLOCK_CHANNEL;
196 state->read_cnt_height = dma_reg_load(ID,
198 _DMA_FSM_GROUP_FSM_REQ_CNT_YB_IDX,
199 _DMA_FSM_GROUP_FSM_REQ_IDX));
200 state->read_cnt_width = dma_reg_load(ID,
202 _DMA_FSM_GROUP_FSM_REQ_CNT_XB_IDX,
203 _DMA_FSM_GROUP_FSM_REQ_IDX));
205 tmp = dma_reg_load(ID,
207 _DMA_FSM_GROUP_FSM_WR_STATE_IDX,
208 _DMA_FSM_GROUP_FSM_WR_IDX));
209 /* state->write_state = (dma_rw_states_t)tmp; */
211 state->write_state = DMA_RW_STATE_IDLE;
213 state->write_state = DMA_RW_STATE_REQ;
215 state->write_state = DMA_RW_STATE_NEXT_LINE;
217 state->write_state = DMA_RW_STATE_UNLOCK_CHANNEL;
218 state->write_height = dma_reg_load(ID,
220 _DMA_FSM_GROUP_FSM_WR_CNT_YB_IDX,
221 _DMA_FSM_GROUP_FSM_WR_IDX));
222 state->write_width = dma_reg_load(ID,
224 _DMA_FSM_GROUP_FSM_WR_CNT_XB_IDX,
225 _DMA_FSM_GROUP_FSM_WR_IDX));
227 for (i = 0; i < HIVE_ISP_NUM_DMA_CONNS; i++) {
228 dma_port_state_t *port = &(state->port_states[i]);
230 tmp = dma_reg_load(ID, DMA_DEV_INFO_REG_IDX(0, i));
231 port->req_cs = ((tmp & 0x1) != 0);
232 port->req_we_n = ((tmp & 0x2) != 0);
233 port->req_run = ((tmp & 0x4) != 0);
234 port->req_ack = ((tmp & 0x8) != 0);
236 tmp = dma_reg_load(ID, DMA_DEV_INFO_REG_IDX(1, i));
237 port->send_cs = ((tmp & 0x1) != 0);
238 port->send_we_n = ((tmp & 0x2) != 0);
239 port->send_run = ((tmp & 0x4) != 0);
240 port->send_ack = ((tmp & 0x8) != 0);
242 tmp = dma_reg_load(ID, DMA_DEV_INFO_REG_IDX(2, i));
244 port->fifo_state = DMA_FIFO_STATE_WILL_BE_FULL;
246 port->fifo_state = DMA_FIFO_STATE_FULL;
248 port->fifo_state = DMA_FIFO_STATE_EMPTY;
249 port->fifo_counter = tmp >> 3;
252 for (i = 0; i < HIVE_DMA_NUM_CHANNELS; i++) {
253 dma_channel_state_t *ch = &(state->channel_states[i]);
255 ch->connection = DMA_GET_CONNECTION(dma_reg_load(ID,
256 DMA_CHANNEL_PARAM_REG_IDX(i,
257 _DMA_PACKING_SETUP_PARAM)));
258 ch->sign_extend = DMA_GET_EXTENSION(dma_reg_load(ID,
259 DMA_CHANNEL_PARAM_REG_IDX(i,
260 _DMA_PACKING_SETUP_PARAM)));
261 ch->height = dma_reg_load(ID,
262 DMA_CHANNEL_PARAM_REG_IDX(i,
264 ch->stride_a = dma_reg_load(ID,
265 DMA_CHANNEL_PARAM_REG_IDX(i,
266 _DMA_STRIDE_A_PARAM));
267 ch->elems_a = DMA_GET_ELEMENTS(dma_reg_load(ID,
268 DMA_CHANNEL_PARAM_REG_IDX(i,
269 _DMA_ELEM_CROPPING_A_PARAM)));
270 ch->cropping_a = DMA_GET_CROPPING(dma_reg_load(ID,
271 DMA_CHANNEL_PARAM_REG_IDX(i,
272 _DMA_ELEM_CROPPING_A_PARAM)));
273 ch->width_a = dma_reg_load(ID,
274 DMA_CHANNEL_PARAM_REG_IDX(i,
275 _DMA_WIDTH_A_PARAM));
276 ch->stride_b = dma_reg_load(ID,
277 DMA_CHANNEL_PARAM_REG_IDX(i,
278 _DMA_STRIDE_B_PARAM));
279 ch->elems_b = DMA_GET_ELEMENTS(dma_reg_load(ID,
280 DMA_CHANNEL_PARAM_REG_IDX(i,
281 _DMA_ELEM_CROPPING_B_PARAM)));
282 ch->cropping_b = DMA_GET_CROPPING(dma_reg_load(ID,
283 DMA_CHANNEL_PARAM_REG_IDX(i,
284 _DMA_ELEM_CROPPING_B_PARAM)));
285 ch->width_b = dma_reg_load(ID,
286 DMA_CHANNEL_PARAM_REG_IDX(i,
287 _DMA_WIDTH_B_PARAM));
292 dma_set_max_burst_size(const dma_ID_t ID, dma_connection conn,
293 uint32_t max_burst_size)
295 assert(ID < N_DMA_ID);
296 assert(max_burst_size > 0);
297 dma_reg_store(ID, DMA_DEV_INFO_REG_IDX(_DMA_DEV_INTERF_MAX_BURST_IDX, conn),