162306a36Sopenharmony_ciBCM2835 Top-Level ("ARMCTRL") Interrupt Controller 262306a36Sopenharmony_ci 362306a36Sopenharmony_ciThe BCM2835 contains a custom top-level interrupt controller, which supports 462306a36Sopenharmony_ci72 interrupt sources using a 2-level register scheme. The interrupt 562306a36Sopenharmony_cicontroller, or the HW block containing it, is referred to occasionally 662306a36Sopenharmony_cias "armctrl" in the SoC documentation, hence naming of this binding. 762306a36Sopenharmony_ci 862306a36Sopenharmony_ciThe BCM2836 contains the same interrupt controller with the same 962306a36Sopenharmony_ciinterrupts, but the per-CPU interrupt controller is the root, and an 1062306a36Sopenharmony_ciinterrupt there indicates that the ARMCTRL has an interrupt to handle. 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ciRequired properties: 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci- compatible : should be "brcm,bcm2835-armctrl-ic" or 1562306a36Sopenharmony_ci "brcm,bcm2836-armctrl-ic" 1662306a36Sopenharmony_ci- reg : Specifies base physical address and size of the registers. 1762306a36Sopenharmony_ci- interrupt-controller : Identifies the node as an interrupt controller 1862306a36Sopenharmony_ci- #interrupt-cells : Specifies the number of cells needed to encode an 1962306a36Sopenharmony_ci interrupt source. The value shall be 2. 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci The 1st cell is the interrupt bank; 0 for interrupts in the "IRQ basic 2262306a36Sopenharmony_ci pending" register, or 1/2 respectively for interrupts in the "IRQ pending 2362306a36Sopenharmony_ci 1/2" register. 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci The 2nd cell contains the interrupt number within the bank. Valid values 2662306a36Sopenharmony_ci are 0..7 for bank 0, and 0..31 for bank 1. 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ciAdditional required properties for brcm,bcm2836-armctrl-ic: 2962306a36Sopenharmony_ci- interrupts : Specifies the interrupt on the parent for this interrupt 3062306a36Sopenharmony_ci controller to handle. 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_ciThe interrupt sources are as follows: 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ciBank 0: 3562306a36Sopenharmony_ci0: ARM_TIMER 3662306a36Sopenharmony_ci1: ARM_MAILBOX 3762306a36Sopenharmony_ci2: ARM_DOORBELL_0 3862306a36Sopenharmony_ci3: ARM_DOORBELL_1 3962306a36Sopenharmony_ci4: VPU0_HALTED 4062306a36Sopenharmony_ci5: VPU1_HALTED 4162306a36Sopenharmony_ci6: ILLEGAL_TYPE0 4262306a36Sopenharmony_ci7: ILLEGAL_TYPE1 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ciBank 1: 4562306a36Sopenharmony_ci0: TIMER0 4662306a36Sopenharmony_ci1: TIMER1 4762306a36Sopenharmony_ci2: TIMER2 4862306a36Sopenharmony_ci3: TIMER3 4962306a36Sopenharmony_ci4: CODEC0 5062306a36Sopenharmony_ci5: CODEC1 5162306a36Sopenharmony_ci6: CODEC2 5262306a36Sopenharmony_ci7: VC_JPEG 5362306a36Sopenharmony_ci8: ISP 5462306a36Sopenharmony_ci9: VC_USB 5562306a36Sopenharmony_ci10: VC_3D 5662306a36Sopenharmony_ci11: TRANSPOSER 5762306a36Sopenharmony_ci12: MULTICORESYNC0 5862306a36Sopenharmony_ci13: MULTICORESYNC1 5962306a36Sopenharmony_ci14: MULTICORESYNC2 6062306a36Sopenharmony_ci15: MULTICORESYNC3 6162306a36Sopenharmony_ci16: DMA0 6262306a36Sopenharmony_ci17: DMA1 6362306a36Sopenharmony_ci18: VC_DMA2 6462306a36Sopenharmony_ci19: VC_DMA3 6562306a36Sopenharmony_ci20: DMA4 6662306a36Sopenharmony_ci21: DMA5 6762306a36Sopenharmony_ci22: DMA6 6862306a36Sopenharmony_ci23: DMA7 6962306a36Sopenharmony_ci24: DMA8 7062306a36Sopenharmony_ci25: DMA9 7162306a36Sopenharmony_ci26: DMA10 7262306a36Sopenharmony_ci27: DMA11-14 - shared interrupt for DMA 11 to 14 7362306a36Sopenharmony_ci28: DMAALL - triggers on all dma interrupts (including channel 15) 7462306a36Sopenharmony_ci29: AUX 7562306a36Sopenharmony_ci30: ARM 7662306a36Sopenharmony_ci31: VPUDMA 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_ciBank 2: 7962306a36Sopenharmony_ci0: HOSTPORT 8062306a36Sopenharmony_ci1: VIDEOSCALER 8162306a36Sopenharmony_ci2: CCP2TX 8262306a36Sopenharmony_ci3: SDC 8362306a36Sopenharmony_ci4: DSI0 8462306a36Sopenharmony_ci5: AVE 8562306a36Sopenharmony_ci6: CAM0 8662306a36Sopenharmony_ci7: CAM1 8762306a36Sopenharmony_ci8: HDMI0 8862306a36Sopenharmony_ci9: HDMI1 8962306a36Sopenharmony_ci10: PIXELVALVE1 9062306a36Sopenharmony_ci11: I2CSPISLV 9162306a36Sopenharmony_ci12: DSI1 9262306a36Sopenharmony_ci13: PWA0 9362306a36Sopenharmony_ci14: PWA1 9462306a36Sopenharmony_ci15: CPR 9562306a36Sopenharmony_ci16: SMI 9662306a36Sopenharmony_ci17: GPIO0 9762306a36Sopenharmony_ci18: GPIO1 9862306a36Sopenharmony_ci19: GPIO2 9962306a36Sopenharmony_ci20: GPIO3 10062306a36Sopenharmony_ci21: VC_I2C 10162306a36Sopenharmony_ci22: VC_SPI 10262306a36Sopenharmony_ci23: VC_I2SPCM 10362306a36Sopenharmony_ci24: VC_SDIO 10462306a36Sopenharmony_ci25: VC_UART 10562306a36Sopenharmony_ci26: SLIMBUS 10662306a36Sopenharmony_ci27: VEC 10762306a36Sopenharmony_ci28: CPG 10862306a36Sopenharmony_ci29: RNG 10962306a36Sopenharmony_ci30: VC_ARASANSDIO 11062306a36Sopenharmony_ci31: AVSPMON 11162306a36Sopenharmony_ci 11262306a36Sopenharmony_ciExample: 11362306a36Sopenharmony_ci 11462306a36Sopenharmony_ci/* BCM2835, first level */ 11562306a36Sopenharmony_ciintc: interrupt-controller { 11662306a36Sopenharmony_ci compatible = "brcm,bcm2835-armctrl-ic"; 11762306a36Sopenharmony_ci reg = <0x7e00b200 0x200>; 11862306a36Sopenharmony_ci interrupt-controller; 11962306a36Sopenharmony_ci #interrupt-cells = <2>; 12062306a36Sopenharmony_ci}; 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_ci/* BCM2836, second level */ 12362306a36Sopenharmony_ciintc: interrupt-controller { 12462306a36Sopenharmony_ci compatible = "brcm,bcm2836-armctrl-ic"; 12562306a36Sopenharmony_ci reg = <0x7e00b200 0x200>; 12662306a36Sopenharmony_ci interrupt-controller; 12762306a36Sopenharmony_ci #interrupt-cells = <2>; 12862306a36Sopenharmony_ci 12962306a36Sopenharmony_ci interrupt-parent = <&local_intc>; 13062306a36Sopenharmony_ci interrupts = <8>; 13162306a36Sopenharmony_ci}; 132