Software APIs
dif_edn_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/edn/data/edn.hjson -o
13// bazel-out/k8-fastbuild/bin/sw/device/lib/dif/autogen
14
15
16#include <stdint.h>
17
19#include "sw/device/lib/dif/autogen/dif_edn_autogen.h"
20
21#include "hw/top/edn_regs.h" // Generated.
22
23
25dif_result_t dif_edn_init(
26 mmio_region_t base_addr,
27 dif_edn_t *edn) {
28 if (edn == NULL) {
29 return kDifBadArg;
30 }
31
32 edn->dt = kDtEdnCount;
33 edn->base_addr = base_addr;
34
35 return kDifOk;
36}
37
39dif_result_t dif_edn_init_from_dt(
40 dt_edn_t dt,
41 dif_edn_t *edn) {
42 if (edn == NULL) {
43 return kDifBadArg;
44 }
45
46 edn->dt = dt;
47 edn->base_addr = mmio_region_from_addr(dt_edn_primary_reg_block(dt));
48
49 return kDifOk;
50}
51
52dif_result_t dif_edn_get_dt(
53 const dif_edn_t *edn,
54 dt_edn_t *dt) {
55 if ((int)edn->dt == kDtEdnCount || dt == NULL) {
56 return kDifBadArg;
57 }
58 *dt = edn->dt;
59 return kDifOk;
60}
61
62 dif_result_t dif_edn_alert_force(
63 const dif_edn_t *edn,
64 dif_edn_alert_t alert) {
65 if (edn == NULL) {
66 return kDifBadArg;
67 }
68
69 bitfield_bit32_index_t alert_idx;
70 switch (alert) {
72 alert_idx = EDN_ALERT_TEST_RECOV_ALERT_BIT;
73 break;
75 alert_idx = EDN_ALERT_TEST_FATAL_ALERT_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 edn->base_addr,
84 (ptrdiff_t)EDN_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 edn_get_irq_bit_index(
96 dif_edn_irq_t irq,
97 bitfield_bit32_index_t *index_out) {
98
99 switch (irq) {
101 *index_out = EDN_INTR_COMMON_EDN_CMD_REQ_DONE_BIT;
102 break;
104 *index_out = EDN_INTR_COMMON_EDN_FATAL_ERR_BIT;
105 break;
106 default:
107 return false;
108 }
109
110 return true;
111 }
112
113 static dif_irq_type_t irq_types[] = {
116 };
117
119 dif_result_t dif_edn_irq_get_type(
120 const dif_edn_t *edn,
121 dif_edn_irq_t irq,
122 dif_irq_type_t *type) {
123
124
125 if (edn == NULL ||
126 type == NULL ||
128 irq > kDifEdnIrqEdnFatalErr) {
129 return kDifBadArg;
130 }
131
132 *type = irq_types[irq];
133
134 return kDifOk;
135 }
136
138 dif_result_t dif_edn_irq_get_state(
139 const dif_edn_t *edn,
141
142 if (edn == NULL || snapshot == NULL) {
143 return kDifBadArg;
144 }
145
146 *snapshot = mmio_region_read32(
147 edn->base_addr,
148 (ptrdiff_t)EDN_INTR_STATE_REG_OFFSET);
149
150
151 return kDifOk;
152 }
153
155 dif_result_t dif_edn_irq_acknowledge_state(
156 const dif_edn_t *edn,
158 if (edn == NULL) {
159 return kDifBadArg;
160 }
161
162 mmio_region_write32(
163 edn->base_addr,
164 (ptrdiff_t)EDN_INTR_STATE_REG_OFFSET,
165 snapshot);
166
167
168 return kDifOk;
169 }
170
172 dif_result_t dif_edn_irq_is_pending(
173 const dif_edn_t *edn,
174 dif_edn_irq_t irq,
175 bool *is_pending) {
176
177 if (edn == NULL || is_pending == NULL) {
178 return kDifBadArg;
179 }
180
182 if (!edn_get_irq_bit_index(irq, &index)) {
183 return kDifBadArg;
184 }
185
186 uint32_t intr_state_reg = mmio_region_read32(
187 edn->base_addr,
188 (ptrdiff_t)EDN_INTR_STATE_REG_OFFSET);
189
190
191 *is_pending = bitfield_bit32_read(intr_state_reg, index);
192
193 return kDifOk;
194 }
195
197 dif_result_t dif_edn_irq_acknowledge_all(
198 const dif_edn_t *edn
199 ) {
200
201 if (edn == NULL) {
202 return kDifBadArg;
203 }
204
205 // Writing to the register clears the corresponding bits (Write-one clear).
206 mmio_region_write32(
207 edn->base_addr,
208 (ptrdiff_t)EDN_INTR_STATE_REG_OFFSET,
209 UINT32_MAX);
210
211
212 return kDifOk;
213 }
214
216 dif_result_t dif_edn_irq_acknowledge(
217 const dif_edn_t *edn,
218 dif_edn_irq_t irq) {
219
220 if (edn == NULL) {
221 return kDifBadArg;
222 }
223
225 if (!edn_get_irq_bit_index(irq, &index)) {
226 return kDifBadArg;
227 }
228
229 // Writing to the register clears the corresponding bits (Write-one clear).
230 uint32_t intr_state_reg = bitfield_bit32_write(0, index, true);
231 mmio_region_write32(
232 edn->base_addr,
233 (ptrdiff_t)EDN_INTR_STATE_REG_OFFSET,
234 intr_state_reg);
235
236
237 return kDifOk;
238 }
239
241 dif_result_t dif_edn_irq_force(
242 const dif_edn_t *edn,
243 dif_edn_irq_t irq,
244 const bool val) {
245
246 if (edn == NULL) {
247 return kDifBadArg;
248 }
249
251 if (!edn_get_irq_bit_index(irq, &index)) {
252 return kDifBadArg;
253 }
254
255 uint32_t intr_test_reg = bitfield_bit32_write(0, index, val);
256 mmio_region_write32(
257 edn->base_addr,
258 (ptrdiff_t)EDN_INTR_TEST_REG_OFFSET,
259 intr_test_reg);
260
261
262 return kDifOk;
263 }
264
266 dif_result_t dif_edn_irq_get_enabled(
267 const dif_edn_t *edn,
268 dif_edn_irq_t irq,
269 dif_toggle_t *state) {
270
271 if (edn == NULL || state == NULL) {
272 return kDifBadArg;
273 }
274
276 if (!edn_get_irq_bit_index(irq, &index)) {
277 return kDifBadArg;
278 }
279
280 uint32_t intr_enable_reg = mmio_region_read32(
281 edn->base_addr,
282 (ptrdiff_t)EDN_INTR_ENABLE_REG_OFFSET);
283
284
285 bool is_enabled = bitfield_bit32_read(intr_enable_reg, index);
286 *state = is_enabled ?
288
289 return kDifOk;
290 }
291
293 dif_result_t dif_edn_irq_set_enabled(
294 const dif_edn_t *edn,
295 dif_edn_irq_t irq,
296 dif_toggle_t state) {
297
298 if (edn == NULL) {
299 return kDifBadArg;
300 }
301
303 if (!edn_get_irq_bit_index(irq, &index)) {
304 return kDifBadArg;
305 }
306
307 uint32_t intr_enable_reg = mmio_region_read32(
308 edn->base_addr,
309 (ptrdiff_t)EDN_INTR_ENABLE_REG_OFFSET);
310
311
312 bool enable_bit = (state == kDifToggleEnabled) ? true : false;
313 intr_enable_reg = bitfield_bit32_write(intr_enable_reg, index, enable_bit);
314 mmio_region_write32(
315 edn->base_addr,
316 (ptrdiff_t)EDN_INTR_ENABLE_REG_OFFSET,
317 intr_enable_reg);
318
319
320 return kDifOk;
321 }
322
324 dif_result_t dif_edn_irq_disable_all(
325 const dif_edn_t *edn,
327
328 if (edn == NULL) {
329 return kDifBadArg;
330 }
331
332 // Pass the current interrupt state to the caller, if requested.
333 if (snapshot != NULL) {
334 *snapshot = mmio_region_read32(
335 edn->base_addr,
336 (ptrdiff_t)EDN_INTR_ENABLE_REG_OFFSET);
337
338 }
339
340 // Disable all interrupts.
341 mmio_region_write32(
342 edn->base_addr,
343 (ptrdiff_t)EDN_INTR_ENABLE_REG_OFFSET,
344 0u);
345
346
347 return kDifOk;
348 }
349
351 dif_result_t dif_edn_irq_restore_all(
352 const dif_edn_t *edn,
353 const dif_edn_irq_enable_snapshot_t *snapshot) {
354
355 if (edn == NULL || snapshot == NULL) {
356 return kDifBadArg;
357 }
358
359 mmio_region_write32(
360 edn->base_addr,
361 (ptrdiff_t)EDN_INTR_ENABLE_REG_OFFSET,
362 *snapshot);
363
364
365 return kDifOk;
366 }
367