/* * Copyright (c) 2013-2017, ARM Limited and Contributors. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #ifndef __GIC_V2_H__ #define __GIC_V2_H__ /* The macros required here are additional to those in gic_common.h. */ #include <gic_common.h> /****************************************************************************** * THIS DRIVER IS DEPRECATED. For GICv2 systems, use the driver in gicv2.h * and for GICv3 systems, use the driver in gicv3.h. *****************************************************************************/ #if ERROR_DEPRECATED #error " The legacy ARM GIC driver is deprecated." #endif #define GIC400_NUM_SPIS U(480) #define MAX_PPIS U(14) #define MAX_SGIS U(16) #define GRP0 U(0) #define GRP1 U(1) #define GIC_TARGET_CPU_MASK U(0xff) #define ENABLE_GRP0 (U(1) << 0) #define ENABLE_GRP1 (U(1) << 1) /* Distributor interface definitions */ #define GICD_ITARGETSR U(0x800) #define GICD_SGIR U(0xF00) #define GICD_CPENDSGIR U(0xF10) #define GICD_SPENDSGIR U(0xF20) #define CPENDSGIR_SHIFT U(2) #define SPENDSGIR_SHIFT CPENDSGIR_SHIFT /* GICD_TYPER bit definitions */ #define IT_LINES_NO_MASK U(0x1f) /* Physical CPU Interface registers */ #define GICC_CTLR U(0x0) #define GICC_PMR U(0x4) #define GICC_BPR U(0x8) #define GICC_IAR U(0xC) #define GICC_EOIR U(0x10) #define GICC_RPR U(0x14) #define GICC_HPPIR U(0x18) #define GICC_AHPPIR U(0x28) #define GICC_IIDR U(0xFC) #define GICC_DIR U(0x1000) #define GICC_PRIODROP GICC_EOIR /* Common CPU Interface definitions */ #define INT_ID_MASK U(0x3ff) /* GICC_CTLR bit definitions */ #define EOI_MODE_NS (U(1) << 10) #define EOI_MODE_S (U(1) << 9) #define IRQ_BYP_DIS_GRP1 (U(1) << 8) #define FIQ_BYP_DIS_GRP1 (U(1) << 7) #define IRQ_BYP_DIS_GRP0 (U(1) << 6) #define FIQ_BYP_DIS_GRP0 (U(1) << 5) #define CBPR (U(1) << 4) #define FIQ_EN (U(1) << 3) #define ACK_CTL (U(1) << 2) /* GICC_IIDR bit masks and shifts */ #define GICC_IIDR_PID_SHIFT U(20) #define GICC_IIDR_ARCH_SHIFT U(16) #define GICC_IIDR_REV_SHIFT U(12) #define GICC_IIDR_IMP_SHIFT U(0) #define GICC_IIDR_PID_MASK U(0xfff) #define GICC_IIDR_ARCH_MASK U(0xf) #define GICC_IIDR_REV_MASK U(0xf) #define GICC_IIDR_IMP_MASK U(0xfff) /* HYP view virtual CPU Interface registers */ #define GICH_CTL U(0x0) #define GICH_VTR U(0x4) #define GICH_ELRSR0 U(0x30) #define GICH_ELRSR1 U(0x34) #define GICH_APR0 U(0xF0) #define GICH_LR_BASE U(0x100) /* Virtual CPU Interface registers */ #define GICV_CTL U(0x0) #define GICV_PRIMASK U(0x4) #define GICV_BP U(0x8) #define GICV_INTACK U(0xC) #define GICV_EOI U(0x10) #define GICV_RUNNINGPRI U(0x14) #define GICV_HIGHESTPEND U(0x18) #define GICV_DEACTIVATE U(0x1000) #ifndef __ASSEMBLY__ #include <mmio.h> #include <stdint.h> /******************************************************************************* * GIC Distributor function prototypes ******************************************************************************/ unsigned int gicd_read_igroupr(uintptr_t, unsigned int); unsigned int gicd_read_isenabler(uintptr_t, unsigned int); unsigned int gicd_read_icenabler(uintptr_t, unsigned int); unsigned int gicd_read_ispendr(uintptr_t, unsigned int); unsigned int gicd_read_icpendr(uintptr_t, unsigned int); unsigned int gicd_read_isactiver(uintptr_t, unsigned int); unsigned int gicd_read_icactiver(uintptr_t, unsigned int); unsigned int gicd_read_ipriorityr(uintptr_t, unsigned int); unsigned int gicd_read_itargetsr(uintptr_t, unsigned int); unsigned int gicd_read_icfgr(uintptr_t, unsigned int); unsigned int gicd_read_cpendsgir(uintptr_t, unsigned int); unsigned int gicd_read_spendsgir(uintptr_t, unsigned int); void gicd_write_igroupr(uintptr_t, unsigned int, unsigned int); void gicd_write_isenabler(uintptr_t, unsigned int, unsigned int); void gicd_write_icenabler(uintptr_t, unsigned int, unsigned int); void gicd_write_ispendr(uintptr_t, unsigned int, unsigned int); void gicd_write_icpendr(uintptr_t, unsigned int, unsigned int); void gicd_write_isactiver(uintptr_t, unsigned int, unsigned int); void gicd_write_icactiver(uintptr_t, unsigned int, unsigned int); void gicd_write_ipriorityr(uintptr_t, unsigned int, unsigned int); void gicd_write_itargetsr(uintptr_t, unsigned int, unsigned int); void gicd_write_icfgr(uintptr_t, unsigned int, unsigned int); void gicd_write_cpendsgir(uintptr_t, unsigned int, unsigned int); void gicd_write_spendsgir(uintptr_t, unsigned int, unsigned int); unsigned int gicd_get_igroupr(uintptr_t, unsigned int); void gicd_set_igroupr(uintptr_t, unsigned int); void gicd_clr_igroupr(uintptr_t, unsigned int); void gicd_set_isenabler(uintptr_t, unsigned int); void gicd_set_icenabler(uintptr_t, unsigned int); void gicd_set_ispendr(uintptr_t, unsigned int); void gicd_set_icpendr(uintptr_t, unsigned int); void gicd_set_isactiver(uintptr_t, unsigned int); void gicd_set_icactiver(uintptr_t, unsigned int); void gicd_set_ipriorityr(uintptr_t, unsigned int, unsigned int); void gicd_set_itargetsr(uintptr_t, unsigned int, unsigned int); /******************************************************************************* * GIC Distributor interface accessors for reading entire registers ******************************************************************************/ static inline unsigned int gicd_read_ctlr(uintptr_t base) { return mmio_read_32(base + GICD_CTLR); } static inline unsigned int gicd_read_typer(uintptr_t base) { return mmio_read_32(base + GICD_TYPER); } static inline unsigned int gicd_read_sgir(uintptr_t base) { return mmio_read_32(base + GICD_SGIR); } /******************************************************************************* * GIC Distributor interface accessors for writing entire registers ******************************************************************************/ static inline void gicd_write_ctlr(uintptr_t base, unsigned int val) { mmio_write_32(base + GICD_CTLR, val); } static inline void gicd_write_sgir(uintptr_t base, unsigned int val) { mmio_write_32(base + GICD_SGIR, val); } /******************************************************************************* * GIC CPU interface accessors for reading entire registers ******************************************************************************/ static inline unsigned int gicc_read_ctlr(uintptr_t base) { return mmio_read_32(base + GICC_CTLR); } static inline unsigned int gicc_read_pmr(uintptr_t base) { return mmio_read_32(base + GICC_PMR); } static inline unsigned int gicc_read_BPR(uintptr_t base) { return mmio_read_32(base + GICC_BPR); } static inline unsigned int gicc_read_IAR(uintptr_t base) { return mmio_read_32(base + GICC_IAR); } static inline unsigned int gicc_read_EOIR(uintptr_t base) { return mmio_read_32(base + GICC_EOIR); } static inline unsigned int gicc_read_hppir(uintptr_t base) { return mmio_read_32(base + GICC_HPPIR); } static inline unsigned int gicc_read_ahppir(uintptr_t base) { return mmio_read_32(base + GICC_AHPPIR); } static inline unsigned int gicc_read_dir(uintptr_t base) { return mmio_read_32(base + GICC_DIR); } static inline unsigned int gicc_read_iidr(uintptr_t base) { return mmio_read_32(base + GICC_IIDR); } /******************************************************************************* * GIC CPU interface accessors for writing entire registers ******************************************************************************/ static inline void gicc_write_ctlr(uintptr_t base, unsigned int val) { mmio_write_32(base + GICC_CTLR, val); } static inline void gicc_write_pmr(uintptr_t base, unsigned int val) { mmio_write_32(base + GICC_PMR, val); } static inline void gicc_write_BPR(uintptr_t base, unsigned int val) { mmio_write_32(base + GICC_BPR, val); } static inline void gicc_write_IAR(uintptr_t base, unsigned int val) { mmio_write_32(base + GICC_IAR, val); } static inline void gicc_write_EOIR(uintptr_t base, unsigned int val) { mmio_write_32(base + GICC_EOIR, val); } static inline void gicc_write_hppir(uintptr_t base, unsigned int val) { mmio_write_32(base + GICC_HPPIR, val); } static inline void gicc_write_dir(uintptr_t base, unsigned int val) { mmio_write_32(base + GICC_DIR, val); } /******************************************************************************* * Prototype of function to map an interrupt type to the interrupt line used to * signal it. ******************************************************************************/ uint32_t gicv2_interrupt_type_to_line(uint32_t cpuif_base, uint32_t type); #endif /*__ASSEMBLY__*/ #endif /* __GIC_V2_H__ */