#ifndef IRQ_H #define IRQ_H #include "compiler.h" #include "picorv32.h" typedef void (*irqhandler_t)(unsigned int vector, size_t pc); extern irqhandler_t __irq_handler_table[]; #define IRQHANDLER_DECL(x) \ void __hot __text_hot irqhandler_ ##x (unsigned int vector __unused, \ size_t pc __unused) #define IRQHANDLER(x) \ IRQHANDLER_DECL(x); \ IRQHANDLER_DECL(x) typedef unsigned int irqmask_t; static inline irqmask_t disable_irqs(void) { return p_maskirq(~0U, 0); } static inline irqmask_t restore_irqs(irqmask_t mask) { return p_maskirq(mask, 0); } static inline irqmask_t restore_irq(irqmask_t mask, unsigned int vector) { const irqmask_t bit = 1U << vector; return p_maskirq(mask & bit, ~bit); } static inline irqmask_t mask_irqs(irqmask_t mask) { return p_maskirq(mask, ~mask); } static inline irqmask_t mask_irq(unsigned int vector) { return mask_irqs(1U << vector); } static inline irqmask_t unmask_irqs(irqmask_t mask) { return p_maskirq(0, ~mask); } static inline irqmask_t unmask_irq(unsigned int vector) { return unmask_irqs(1U << vector); } static inline irqmask_t irqmask(void) { return p_maskirq(0, ~0); } static inline irqmask_t waitfor(unsigned int vector) { const irqmask_t mask = 1U << vector; return p_waitirq(mask, 0); } /* Wait for any enabled IRQ */ static inline irqmask_t wait_for_irq(void) { const irqmask_t mask = irqmask(); return p_waitirq(mask, mask); } size_t rdxreg(unsigned int reg); void wrxreg(unsigned int reg, size_t val); #endif /* IRQ_H */