AST2700 interrupt controller(INTC) provides hardware interrupt interfaces
to interrupt of processors PSP, SSP and TSP. In INTC, each interrupt of
INT 128 to INT136 combines 32 interrupts.
Introduce a new aspeed_intc class with instance_init and realize handlers.
So far, this model only supports GICINT128 to GICINT136.
It creates 9 GICINT or-gates to connect 32 interrupts sources
from GICINT128 to GICINT136 as IRQ GPIO-OUTPUT pins.
Then, this model registers IRQ handler with its IRQ GPIO-INPUT pins which
connect to GICINT or-gates. And creates 9 GICINT IRQ GPIO-OUTPUT pins which
connect to GIC device with GIC IRQ 128 to 136.
If one interrupt source from GICINT128 to GICINT136
set irq, the OR-GATE irq callback function is called and set irq to INTC by
OR-GATE GPIO-OUTPUT pins. Then, the INTC irq callback function is called and
set irq to GIC by its GICINT IRQ GPIO-OUTPUT pins. Finally, the GIC irq
callback function is called and set irq to CPUs and
CPUs execute Interrupt Service Routine (ISR).
Block diagram of GICINT132:
            GICINT132
  ETH1    +-----------+
+-------->+0         3|
  ETH2    |          4|
+-------->+1         5|
  ETH3    |          6|
+-------->+2        19|                          INTC                          GIC
  UART0   |         20|            +--------------------------+
+-------->+7        21|            |                          |            +--------------+
  UART1   |         22|            |orgate0 +----> output_pin0+----------->+GIC128        |
+-------->+8        23|            |                          |            |              |
  UART2   |         24|            |orgate1 +----> output_pin1+----------->+GIC129        |
+-------->+9        25|            |                          |            |              |
  UART3   |         26|            |orgate2 +----> output_pin2+----------->+GIC130        |
+--------->10       27|            |                          |            |              |
  UART5   |         28|            |orgate3 +----> output_pin3+----------->+GIC131        |
+-------->+11       29|            |                          |            |              |
  UART6   |           +----------->+orgate4 +----> output_pin4+----------->+GIC132        |
+-------->+12       30|            |                          |            |              |
  UART7   |         31|            |orgate5 +----> output_pin5+----------->+GIC133        |
+-------->+13         |            |                          |            |              |
  UART8   |  OR[0:31] |            |orgate6 +----> output_pin6+----------->+GIC134        |
---------->14         |            |                          |            |              |
  UART9   |           |            |orgate7 +----> output_pin7+----------->+GIC135        |
--------->+15         |            |                          |            |              |
  UART10  |           |            |orgate8 +----> output_pin8+----------->+GIC136        |
--------->+16         |            |                          |            +--------------+
  UART11  |           |            +--------------------------+
+-------->+17         |
  UART12  |           |
+--------->18         |
          |           |
          |           |
          |           |
          +-----------+
Signed-off-by: Troy Lee <troy_lee@aspeedtech.com>
Signed-off-by: Jamin Lin <jamin_lin@aspeedtech.com>
Reviewed-by: Cédric Le Goater <clg@redhat.com>
[clg: Fixed class_size in TYPE_ASPEED_INTC definition ]
		
	
		
			
				
	
	
		
			76 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Meson
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Meson
		
	
	
	
	
	
| system_ss.add(files('intc.c'))
 | |
| system_ss.add(when: 'CONFIG_ARM_GIC', if_true: files(
 | |
|   'arm_gic.c',
 | |
|   'arm_gic_common.c',
 | |
|   'arm_gicv2m.c',
 | |
|   'arm_gicv3_common.c',
 | |
|   'arm_gicv3_its_common.c',
 | |
| ))
 | |
| system_ss.add(when: 'CONFIG_ARM_GICV3_TCG', if_true: files(
 | |
|   'arm_gicv3.c',
 | |
|   'arm_gicv3_dist.c',
 | |
|   'arm_gicv3_its.c',
 | |
|   'arm_gicv3_redist.c',
 | |
| ))
 | |
| system_ss.add(when: 'CONFIG_ALLWINNER_A10_PIC', if_true: files('allwinner-a10-pic.c'))
 | |
| system_ss.add(when: 'CONFIG_ASPEED_SOC', if_true: files('aspeed_vic.c'))
 | |
| system_ss.add(when: 'CONFIG_ASPEED_SOC', if_true: files('aspeed_intc.c'))
 | |
| system_ss.add(when: 'CONFIG_ETRAXFS', if_true: files('etraxfs_pic.c'))
 | |
| system_ss.add(when: 'CONFIG_EXYNOS4', if_true: files('exynos4210_gic.c', 'exynos4210_combiner.c'))
 | |
| system_ss.add(when: 'CONFIG_GOLDFISH_PIC', if_true: files('goldfish_pic.c'))
 | |
| system_ss.add(when: 'CONFIG_HEATHROW_PIC', if_true: files('heathrow_pic.c'))
 | |
| system_ss.add(when: 'CONFIG_I8259', if_true: files('i8259_common.c', 'i8259.c'))
 | |
| system_ss.add(when: 'CONFIG_IMX', if_true: files('imx_avic.c', 'imx_gpcv2.c'))
 | |
| system_ss.add(when: 'CONFIG_IOAPIC', if_true: files('ioapic_common.c'), if_false: files('ioapic-stub.c'))
 | |
| system_ss.add(when: 'CONFIG_OMAP', if_true: files('omap_intc.c'))
 | |
| system_ss.add(when: 'CONFIG_OPENPIC', if_true: files('openpic.c'))
 | |
| system_ss.add(when: 'CONFIG_PL190', if_true: files('pl190.c'))
 | |
| system_ss.add(when: 'CONFIG_RASPI', if_true: files('bcm2835_ic.c', 'bcm2836_control.c'))
 | |
| system_ss.add(when: 'CONFIG_REALVIEW', if_true: files('realview_gic.c'))
 | |
| system_ss.add(when: 'CONFIG_SLAVIO', if_true: files('slavio_intctl.c'))
 | |
| system_ss.add(when: 'CONFIG_XILINX', if_true: files('xilinx_intc.c'))
 | |
| system_ss.add(when: 'CONFIG_XLNX_ZYNQMP', if_true: files('xlnx-zynqmp-ipi.c'))
 | |
| system_ss.add(when: 'CONFIG_XLNX_ZYNQMP_PMU', if_true: files('xlnx-pmu-iomod-intc.c'))
 | |
| 
 | |
| if config_all_devices.has_key('CONFIG_APIC') or \
 | |
|    config_all_devices.has_key('CONFIG_I8259') or \
 | |
|    config_all_devices.has_key('CONFIG_MC146818RTC')
 | |
|     system_ss.add(files('kvm_irqcount.c'))
 | |
| endif
 | |
| 
 | |
| specific_ss.add(when: 'CONFIG_APIC', if_true: files('apic.c', 'apic_common.c'))
 | |
| specific_ss.add(when: 'CONFIG_ARM_GIC', if_true: files('arm_gicv3_cpuif_common.c'))
 | |
| specific_ss.add(when: 'CONFIG_ARM_GICV3_TCG', if_true: files('arm_gicv3_cpuif.c'))
 | |
| specific_ss.add(when: 'CONFIG_ARM_GIC_KVM', if_true: files('arm_gic_kvm.c'))
 | |
| specific_ss.add(when: ['CONFIG_ARM_GIC_KVM', 'TARGET_AARCH64'], if_true: files('arm_gicv3_kvm.c', 'arm_gicv3_its_kvm.c'))
 | |
| specific_ss.add(when: 'CONFIG_ARM_V7M', if_true: files('armv7m_nvic.c'))
 | |
| specific_ss.add(when: 'CONFIG_GRLIB', if_true: files('grlib_irqmp.c'))
 | |
| specific_ss.add(when: 'CONFIG_IOAPIC', if_true: files('ioapic.c'))
 | |
| specific_ss.add(when: 'CONFIG_LOONGSON_LIOINTC', if_true: files('loongson_liointc.c'))
 | |
| specific_ss.add(when: 'CONFIG_MIPS_CPS', if_true: files('mips_gic.c'))
 | |
| specific_ss.add(when: 'CONFIG_OMPIC', if_true: files('ompic.c'))
 | |
| specific_ss.add(when: ['CONFIG_KVM', 'CONFIG_OPENPIC'],
 | |
| 		if_true: files('openpic_kvm.c'))
 | |
| specific_ss.add(when: 'CONFIG_POWERNV', if_true: files('xics_pnv.c', 'pnv_xive.c', 'pnv_xive2.c'))
 | |
| specific_ss.add(when: 'CONFIG_PPC_UIC', if_true: files('ppc-uic.c'))
 | |
| specific_ss.add(when: 'CONFIG_RX_ICU', if_true: files('rx_icu.c'))
 | |
| specific_ss.add(when: 'CONFIG_S390_FLIC', if_true: files('s390_flic.c'))
 | |
| specific_ss.add(when: 'CONFIG_S390_FLIC_KVM', if_true: files('s390_flic_kvm.c'))
 | |
| specific_ss.add(when: 'CONFIG_SH_INTC', if_true: files('sh_intc.c'))
 | |
| specific_ss.add(when: 'CONFIG_RISCV_ACLINT', if_true: files('riscv_aclint.c'))
 | |
| specific_ss.add(when: 'CONFIG_RISCV_APLIC', if_true: files('riscv_aplic.c'))
 | |
| specific_ss.add(when: 'CONFIG_RISCV_IMSIC', if_true: files('riscv_imsic.c'))
 | |
| specific_ss.add(when: 'CONFIG_SIFIVE_PLIC', if_true: files('sifive_plic.c'))
 | |
| specific_ss.add(when: 'CONFIG_XICS', if_true: files('xics.c', 'xive2.c'))
 | |
| specific_ss.add(when: ['CONFIG_KVM', 'CONFIG_XICS'],
 | |
| 		if_true: files('xics_kvm.c'))
 | |
| specific_ss.add(when: 'CONFIG_PSERIES', if_true: files('xics_spapr.c', 'spapr_xive.c'))
 | |
| specific_ss.add(when: 'CONFIG_XIVE', if_true: files('xive.c'))
 | |
| specific_ss.add(when: ['CONFIG_KVM', 'CONFIG_XIVE'],
 | |
| 		if_true: files('spapr_xive_kvm.c'))
 | |
| specific_ss.add(when: 'CONFIG_M68K_IRQC', if_true: files('m68k_irqc.c'))
 | |
| specific_ss.add(when: 'CONFIG_LOONGSON_IPI', if_true: files('loongson_ipi.c'))
 | |
| specific_ss.add(when: 'CONFIG_LOONGARCH_PCH_PIC', if_true: files('loongarch_pch_pic.c'))
 | |
| specific_ss.add(when: 'CONFIG_LOONGARCH_PCH_MSI', if_true: files('loongarch_pch_msi.c'))
 | |
| specific_ss.add(when: 'CONFIG_LOONGARCH_EXTIOI', if_true: files('loongarch_extioi.c'))
 |