1 /* 2 * Copyright (c) 2022 Carlo Caione <ccaione@baylibre.com> 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 /** 8 * @file 9 * @brief Driver for Core-Local Interrupt Controller (CLIC) 10 */ 11 12 #ifndef ZEPHYR_INCLUDE_DRIVERS_RISCV_CLIC_H_ 13 #define ZEPHYR_INCLUDE_DRIVERS_RISCV_CLIC_H_ 14 15 /** 16 * @brief Enable interrupt 17 * 18 * @param irq interrupt ID 19 */ 20 void riscv_clic_irq_enable(uint32_t irq); 21 22 /** 23 * @brief Disable interrupt 24 * 25 * @param irq interrupt ID 26 */ 27 void riscv_clic_irq_disable(uint32_t irq); 28 29 /** 30 * @brief Check if an interrupt is enabled 31 * 32 * @param irq interrupt ID 33 * @return Returns true if interrupt is enabled, false otherwise 34 */ 35 int riscv_clic_irq_is_enabled(uint32_t irq); 36 37 /** 38 * @brief Set interrupt priority 39 * 40 * @param irq interrupt ID 41 * @param prio interrupt priority 42 * @param flags interrupt flags 43 */ 44 void riscv_clic_irq_priority_set(uint32_t irq, uint32_t prio, uint32_t flags); 45 46 /** 47 * @brief Set vector mode of interrupt 48 * 49 * @param irq interrupt ID 50 */ 51 void riscv_clic_irq_vector_set(uint32_t irq); 52 53 #endif /* ZEPHYR_INCLUDE_DRIVERS_RISCV_CLIC_H_ */ 54