/* * COPYRIGHT (c) 2012-2015 * Cobham Gaisler * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at * http://www.rtems.org/license/LICENSE. * */ #include #include #include #if defined(RTEMS_SMP) && defined(LEON3) /* Interrupt to CPU map. Default to CPU0 since in BSS. */ const unsigned char LEON3_irq_to_cpu[32] __attribute__((weak)); /* On SMP use map table above relative to SMP Boot CPU (normally CPU0) */ static inline int bsp_irq_cpu(int irq) { /* protect from bad user configuration, default to boot cpu */ if (rtems_configuration_get_maximum_processors() <= LEON3_irq_to_cpu[irq]) return LEON3_Cpu_Index; else return LEON3_Cpu_Index + LEON3_irq_to_cpu[irq]; } #else /* when not SMP the local CPU is returned */ static inline int bsp_irq_cpu(int irq) { #ifdef LEON3 return _LEON3_Get_current_processor(); #else return 0; #endif } #endif /* Callback from bsp_interrupt_initialize() */ rtems_status_code bsp_interrupt_facility_initialize(void) { return RTEMS_SUCCESSFUL; } void bsp_interrupt_vector_enable(rtems_vector_number vector) { int irq = (int)vector; bsp_interrupt_assert(bsp_interrupt_is_valid_vector(vector)); BSP_Cpu_Unmask_interrupt(irq, bsp_irq_cpu(irq)); } void bsp_interrupt_vector_disable(rtems_vector_number vector) { int irq = (int)vector; bsp_interrupt_assert(bsp_interrupt_is_valid_vector(vector)); BSP_Cpu_Mask_interrupt(irq, bsp_irq_cpu(irq)); } void BSP_shared_interrupt_mask(int irq) { BSP_Cpu_Mask_interrupt(irq, bsp_irq_cpu(irq)); } void BSP_shared_interrupt_unmask(int irq) { BSP_Cpu_Unmask_interrupt(irq, bsp_irq_cpu(irq)); } void BSP_shared_interrupt_clear(int irq) { /* We don't have to interrupt lock here, because the register is only * written and self clearing */ BSP_Clear_interrupt(irq); }