• P
    irqchip: irq-bcm2835: Calc. FIQ_START at boot-time · a2ea4f95
    Phil Elwell 提交于
    raspberrypi inclusion
    category: feature
    bugzilla: 50432
    
    --------------------------------
    
    ad83c7cb ("irqchip/irq-bcm2836: Add support for DT interrupt polarity")
    changed the way that the BCM2836/7 local interrupts are mapped; instead
    of being pre-mapped they are now mapped on-demand. A side effect of this
    change is that the call to irq_of_parse_and_map from armctrl_of_init
    creates a new mapping, forming a gap between the IRQs and the FIQs. This
     gap breaks the FIQ<->IRQ mapping which up to now has been done by assuming:
    
    1) that the value of FIQ_START is the same as the number of normal IRQs
    that will be mapped (still true), and
    
    2) that this value is also the offset between an IRQ and its equivalent
    FIQ (which is no longer the case).
    
    Remove both assumptions by measuring the interval between the last IRQ
    and the last FIQ, passing it as the parameter to init_FIQ().
    
    Fixes: https://github.com/raspberrypi/linux/issues/2432Signed-off-by: NPhil Elwell <phil@raspberrypi.org>
    Signed-off-by: NFang Yafen <yafen@iscas.ac.cn>
    Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
    a2ea4f95
irq-bcm2835.c 9.4 KB