gicv3.h 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2013-07-20 Bernard first version
  9. * 2014-04-03 Grissiom many enhancements
  10. * 2018-11-22 Jesven add rt_hw_ipi_send()
  11. * add rt_hw_ipi_handler_install()
  12. */
  13. #ifndef __GICV3_H__
  14. #define __GICV3_H__
  15. #include <rtdef.h>
  16. #if defined(BSP_USING_GIC) && defined(BSP_USING_GICV3)
  17. #define GICV3_ROUTED_TO_ALL 1UL
  18. #define GICV3_ROUTED_TO_SPEC 0UL
  19. int arm_gic_get_active_irq(rt_uint64_t index);
  20. void arm_gic_ack(rt_uint64_t index, int irq);
  21. void arm_gic_mask(rt_uint64_t index, int irq);
  22. void arm_gic_umask(rt_uint64_t index, int irq);
  23. rt_uint64_t arm_gic_get_pending_irq(rt_uint64_t index, int irq);
  24. void arm_gic_set_pending_irq(rt_uint64_t index, int irq);
  25. void arm_gic_clear_pending_irq(rt_uint64_t index, int irq);
  26. void arm_gic_set_configuration(rt_uint64_t index, int irq, rt_uint32_t config);
  27. rt_uint64_t arm_gic_get_configuration(rt_uint64_t index, int irq);
  28. void arm_gic_clear_active(rt_uint64_t index, int irq);
  29. void arm_gic_set_cpu(rt_uint64_t index, int irq, unsigned int cpumask);
  30. rt_uint64_t arm_gic_get_target_cpu(rt_uint64_t index, int irq);
  31. void arm_gic_set_priority(rt_uint64_t index, int irq, rt_uint64_t priority);
  32. rt_uint64_t arm_gic_get_priority(rt_uint64_t index, int irq);
  33. void arm_gic_set_interface_prior_mask(rt_uint64_t index, rt_uint64_t priority);
  34. rt_uint64_t arm_gic_get_interface_prior_mask(rt_uint64_t index);
  35. void arm_gic_set_binary_point(rt_uint64_t index, rt_uint64_t binary_point);
  36. rt_uint64_t arm_gic_get_binary_point(rt_uint64_t index);
  37. rt_uint64_t arm_gic_get_irq_status(rt_uint64_t index, int irq);
  38. #ifdef RT_USING_SMP
  39. void arm_gic_send_affinity_sgi(rt_uint64_t index, int irq, rt_uint64_t cpu_masks[], rt_uint64_t routing_mode);
  40. #endif
  41. rt_uint64_t arm_gic_get_high_pending_irq(rt_uint64_t index);
  42. rt_uint64_t arm_gic_get_interface_id(rt_uint64_t index);
  43. void arm_gic_set_group(rt_uint64_t index, int irq, rt_uint64_t group);
  44. rt_uint64_t arm_gic_get_group(rt_uint64_t index, int irq);
  45. int arm_gic_redist_address_set(rt_uint64_t index, rt_uint64_t redist_addr, int cpu_id);
  46. int arm_gic_cpu_interface_address_set(rt_uint64_t index, rt_uint64_t interface_addr, int cpu_id);
  47. int arm_gic_dist_init(rt_uint64_t index, rt_uint64_t dist_base, int irq_start);
  48. int arm_gic_redist_init(rt_uint64_t index, rt_uint64_t redist_base);
  49. int arm_gic_cpu_init(rt_uint64_t index, rt_uint64_t cpu_base);
  50. void arm_gic_dump_type(rt_uint64_t index);
  51. void arm_gic_dump(rt_uint64_t index);
  52. #endif /* defined(BSP_USING_GIC) && defined(BSP_USING_GICV3) */
  53. #endif