Software APIs
dif_mbx_autogen.c
1// Copyright lowRISC contributors (OpenTitan project).
2// Licensed under the Apache License, Version 2.0, see LICENSE for details.
3// SPDX-License-Identifier: Apache-2.0
4
5
6
7
8
9
10
11// THIS FILE HAS BEEN GENERATED, DO NOT EDIT MANUALLY. COMMAND:
12// util/autogen_dif.py -i hw/ip/mbx/data/mbx.hjson -o
13// bazel-out/k8-fastbuild-ST-24cc6a2908d2/bin/sw/device/lib/dif/autogen
14
15
16#include <stdint.h>
17
20
21#include "mbx_regs.h" // Generated.
22
23
25dif_result_t dif_mbx_init(
26 mmio_region_t base_addr,
27 dif_mbx_t *mbx) {
28 if (mbx == NULL) {
29 return kDifBadArg;
30 }
31
32 mbx->dt = kDtMbxCount;
33 mbx->base_addr = base_addr;
34
35 return kDifOk;
36}
37
39dif_result_t dif_mbx_init_from_dt(
40 dt_mbx_t dt,
41 dif_mbx_t *mbx) {
42 if (mbx == NULL) {
43 return kDifBadArg;
44 }
45
46 mbx->dt = dt;
47 mbx->base_addr = mmio_region_from_addr(dt_mbx_primary_reg_block(dt));
48
49 return kDifOk;
50}
51
52dif_result_t dif_mbx_get_dt(
53 const dif_mbx_t *mbx,
54 dt_mbx_t *dt) {
55 if (mbx->dt == kDtMbxCount || dt == NULL) {
56 return kDifBadArg;
57 }
58 *dt = mbx->dt;
59 return kDifOk;
60}
61
62 dif_result_t dif_mbx_alert_force(
63 const dif_mbx_t *mbx,
64 dif_mbx_alert_t alert) {
65 if (mbx == NULL) {
66 return kDifBadArg;
67 }
68
69 bitfield_bit32_index_t alert_idx;
70 switch (alert) {
72 alert_idx = MBX_ALERT_TEST_FATAL_FAULT_BIT;
73 break;
75 alert_idx = MBX_ALERT_TEST_RECOV_FAULT_BIT;
76 break;
77 default:
78 return kDifBadArg;
79 }
80
81 uint32_t alert_test_reg = bitfield_bit32_write(0, alert_idx, true);
82 mmio_region_write32(
83 mbx->base_addr,
84 (ptrdiff_t)MBX_ALERT_TEST_REG_OFFSET,
85 alert_test_reg);
86
87
88 return kDifOk;
89}
90
91
92 /**
93 * Get the corresponding interrupt register bit offset of the IRQ.
94 */
95 static bool mbx_get_irq_bit_index(
96 dif_mbx_irq_t irq,
97 bitfield_bit32_index_t *index_out) {
98
99 switch (irq) {
101 *index_out = MBX_INTR_COMMON_MBX_READY_BIT;
102 break;
104 *index_out = MBX_INTR_COMMON_MBX_ABORT_BIT;
105 break;
107 *index_out = MBX_INTR_COMMON_MBX_ERROR_BIT;
108 break;
109 default:
110 return false;
111 }
112
113 return true;
114 }
115
116 static dif_irq_type_t irq_types[] = {
120 };
121
123 dif_result_t dif_mbx_irq_get_type(
124 const dif_mbx_t *mbx,
125 dif_mbx_irq_t irq,
126 dif_irq_type_t *type) {
127
128
129 if (mbx == NULL ||
130 type == NULL ||
131 irq < kDifMbxIrqMbxReady ||
132 irq > kDifMbxIrqMbxError) {
133 return kDifBadArg;
134 }
135
136 *type = irq_types[irq];
137
138 return kDifOk;
139 }
140
142 dif_result_t dif_mbx_irq_get_state(
143 const dif_mbx_t *mbx,
145
146 if (mbx == NULL || snapshot == NULL) {
147 return kDifBadArg;
148 }
149
150 *snapshot = mmio_region_read32(
151 mbx->base_addr,
152 (ptrdiff_t)MBX_INTR_STATE_REG_OFFSET);
153
154
155 return kDifOk;
156 }
157
159 dif_result_t dif_mbx_irq_acknowledge_state(
160 const dif_mbx_t *mbx,
162 if (mbx == NULL) {
163 return kDifBadArg;
164 }
165
166 mmio_region_write32(
167 mbx->base_addr,
168 (ptrdiff_t)MBX_INTR_STATE_REG_OFFSET,
169 snapshot);
170
171
172 return kDifOk;
173 }
174
176 dif_result_t dif_mbx_irq_is_pending(
177 const dif_mbx_t *mbx,
178 dif_mbx_irq_t irq,
179 bool *is_pending) {
180
181 if (mbx == NULL || is_pending == NULL) {
182 return kDifBadArg;
183 }
184
186 if (!mbx_get_irq_bit_index(irq, &index)) {
187 return kDifBadArg;
188 }
189
190 uint32_t intr_state_reg = mmio_region_read32(
191 mbx->base_addr,
192 (ptrdiff_t)MBX_INTR_STATE_REG_OFFSET);
193
194
195 *is_pending = bitfield_bit32_read(intr_state_reg, index);
196
197 return kDifOk;
198 }
199
201 dif_result_t dif_mbx_irq_acknowledge_all(
202 const dif_mbx_t *mbx
203 ) {
204
205 if (mbx == NULL) {
206 return kDifBadArg;
207 }
208
209 // Writing to the register clears the corresponding bits (Write-one clear).
210 mmio_region_write32(
211 mbx->base_addr,
212 (ptrdiff_t)MBX_INTR_STATE_REG_OFFSET,
213 UINT32_MAX);
214
215
216 return kDifOk;
217 }
218
220 dif_result_t dif_mbx_irq_acknowledge(
221 const dif_mbx_t *mbx,
222 dif_mbx_irq_t irq) {
223
224 if (mbx == NULL) {
225 return kDifBadArg;
226 }
227
229 if (!mbx_get_irq_bit_index(irq, &index)) {
230 return kDifBadArg;
231 }
232
233 // Writing to the register clears the corresponding bits (Write-one clear).
234 uint32_t intr_state_reg = bitfield_bit32_write(0, index, true);
235 mmio_region_write32(
236 mbx->base_addr,
237 (ptrdiff_t)MBX_INTR_STATE_REG_OFFSET,
238 intr_state_reg);
239
240
241 return kDifOk;
242 }
243
245 dif_result_t dif_mbx_irq_force(
246 const dif_mbx_t *mbx,
247 dif_mbx_irq_t irq,
248 const bool val) {
249
250 if (mbx == NULL) {
251 return kDifBadArg;
252 }
253
255 if (!mbx_get_irq_bit_index(irq, &index)) {
256 return kDifBadArg;
257 }
258
259 uint32_t intr_test_reg = bitfield_bit32_write(0, index, val);
260 mmio_region_write32(
261 mbx->base_addr,
262 (ptrdiff_t)MBX_INTR_TEST_REG_OFFSET,
263 intr_test_reg);
264
265
266 return kDifOk;
267 }
268
270 dif_result_t dif_mbx_irq_get_enabled(
271 const dif_mbx_t *mbx,
272 dif_mbx_irq_t irq,
273 dif_toggle_t *state) {
274
275 if (mbx == NULL || state == NULL) {
276 return kDifBadArg;
277 }
278
280 if (!mbx_get_irq_bit_index(irq, &index)) {
281 return kDifBadArg;
282 }
283
284 uint32_t intr_enable_reg = mmio_region_read32(
285 mbx->base_addr,
286 (ptrdiff_t)MBX_INTR_ENABLE_REG_OFFSET);
287
288
289 bool is_enabled = bitfield_bit32_read(intr_enable_reg, index);
290 *state = is_enabled ?
292
293 return kDifOk;
294 }
295
297 dif_result_t dif_mbx_irq_set_enabled(
298 const dif_mbx_t *mbx,
299 dif_mbx_irq_t irq,
300 dif_toggle_t state) {
301
302 if (mbx == NULL) {
303 return kDifBadArg;
304 }
305
307 if (!mbx_get_irq_bit_index(irq, &index)) {
308 return kDifBadArg;
309 }
310
311 uint32_t intr_enable_reg = mmio_region_read32(
312 mbx->base_addr,
313 (ptrdiff_t)MBX_INTR_ENABLE_REG_OFFSET);
314
315
316 bool enable_bit = (state == kDifToggleEnabled) ? true : false;
317 intr_enable_reg = bitfield_bit32_write(intr_enable_reg, index, enable_bit);
318 mmio_region_write32(
319 mbx->base_addr,
320 (ptrdiff_t)MBX_INTR_ENABLE_REG_OFFSET,
321 intr_enable_reg);
322
323
324 return kDifOk;
325 }
326
328 dif_result_t dif_mbx_irq_disable_all(
329 const dif_mbx_t *mbx,
331
332 if (mbx == NULL) {
333 return kDifBadArg;
334 }
335
336 // Pass the current interrupt state to the caller, if requested.
337 if (snapshot != NULL) {
338 *snapshot = mmio_region_read32(
339 mbx->base_addr,
340 (ptrdiff_t)MBX_INTR_ENABLE_REG_OFFSET);
341
342 }
343
344 // Disable all interrupts.
345 mmio_region_write32(
346 mbx->base_addr,
347 (ptrdiff_t)MBX_INTR_ENABLE_REG_OFFSET,
348 0u);
349
350
351 return kDifOk;
352 }
353
355 dif_result_t dif_mbx_irq_restore_all(
356 const dif_mbx_t *mbx,
357 const dif_mbx_irq_enable_snapshot_t *snapshot) {
358
359 if (mbx == NULL || snapshot == NULL) {
360 return kDifBadArg;
361 }
362
363 mmio_region_write32(
364 mbx->base_addr,
365 (ptrdiff_t)MBX_INTR_ENABLE_REG_OFFSET,
366 *snapshot);
367
368
369 return kDifOk;
370 }
371