interrupt.h 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. * Copyright (c) 2006-2024, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2021-05-20 bigmagic The first version
  9. */
  10. #ifndef INTERRUPT_H__
  11. #define INTERRUPT_H__
  12. #define MAX_HANDLERS 128
  13. #include <rthw.h>
  14. #include "stack.h"
  15. #include "regtypes.h"
  16. enum
  17. {
  18. EP_INSTRUCTION_ADDRESS_MISALIGNED = 0,
  19. EP_INSTRUCTION_ACCESS_FAULT,
  20. EP_ILLEGAL_INSTRUCTION,
  21. EP_BREAKPOINT,
  22. EP_LOAD_ADDRESS_MISALIGNED,
  23. EP_LOAD_ACCESS_FAULT,
  24. EP_STORE_ADDRESS_MISALIGNED,
  25. EP_STORE_ACCESS_FAULT,
  26. EP_ENVIRONMENT_CALL_U_MODE,
  27. EP_ENVIRONMENT_CALL_S_MODE,
  28. EP_RESERVED10,
  29. EP_ENVIRONMENT_CALL_M_MODE,
  30. EP_INSTRUCTION_PAGE_FAULT, /* page attr */
  31. EP_LOAD_PAGE_FAULT, /* read data */
  32. EP_RESERVED14,
  33. EP_STORE_PAGE_FAULT, /* write data */
  34. };
  35. int rt_hw_plic_irq_enable(int irq_number);
  36. int rt_hw_plic_irq_disable(int irq_number);
  37. void rt_hw_interrupt_init(void);
  38. void rt_hw_interrupt_mask(int vector);
  39. rt_isr_handler_t rt_hw_interrupt_install(int vector, rt_isr_handler_t handler, void *param, const char *name);
  40. void handle_trap(rt_uintreg_t xcause, rt_uintreg_t xtval, rt_uintreg_t xepc, struct rt_hw_stack_frame *sp);
  41. #endif