是搁浅调整器节点的习性

再看pcie@1,0以此节点,有#interrupt-cells属性,不过未有interrupt-controller属性,这阐明他是多少个interrupt
nexus节点。该节点的#interrupt-cells属性为1,表明该interrupt
nexus节点管辖下的中断源用1个u32表示就足以了。在pcie@1,0节点下边没有子节点,且也从没节点的interrupt-parent属性指向pcie@1,0节点,所以从设备树上看不到该interrupt
domain下的暂停产生设备,恐怕的原故是这几个中断发生设备软件能够动态识别所以无需配备树描述。因为interrupt-map-mask属性是由脚刹踏板爆发设备的地点和中断源(interrupt
specifier)组成,且中断源用1个u32表示,那么能够想见中断发生设备地址由3个u32组成。这里要求小心的是pcie@1,0节点的#address-cells属性为3,是说该总线上面的设备地址用3个u32表示,但并不意味着中断发生设备的装置地址也自然3个u32表示,此处无法算得巧合,然而大家要明了中断发生设备的地址由几个u32组成是由该设备所在总线决定的,对于pcie总线也真正是3,不过其余总线可能存在其余种的图景。今后大家来分析interrupt-map属性,前七个数字是脚刹踏板设备地址,第多个数字是搁浅设备的中断源。因为interrupt-map-mask是全0,那样无论与什么数字做与运算结果都以0,interrupt-map属性的前4个数字也都是0,这表明在pcie@1,0底下全体的中断映射到中断父节点的中止都以三个间断。接着是指向gic的<phandle>,因为gic节点下#address-cells属性为0,所现在面无需描述中断父设备之处了,后面3个数字都以表示暂停父设备中断源的。一句话描述正是pcie@1,0下的具备中断都映射到gic,GIC_SPI类型的第29号中断,触发类型为高电平触发。这么些事例说明在中断树的最上边能够是interrupt
nexus节点。

 

叁个计算机系列中大量器材都是通过中断央求CPU服务的,所以设备节点就要求在钦赐中断号。常用的性质;

https://www.cnblogs.com/xiaojiang1025/p/6131381.html

http://www.cnblogs.com/targethero/p/5080499.html

 

interrups,三个搁浅标记符列表,表示每多少个搁浅输出随机信号;

#interrupt-cells,是搁浅调控器节点的习性,用来标志这一个调节器供给多少个单位做中断描述符,用来陈说子节点”interrupts”属性使用了父节点中的interrupt属性的具体哪些值;一般,假诺父节点的该属性的值为3,则子节点的interrupts二个cell的四个32bits的整数值分别为:<中断域
中断 触发方式>,如若父节点的该属性为2,则是<中断 触发格局>
interrupt-parent,标记此设备节点归于哪五个搁浅调整器,若无设置那性格情,会自行依据父节点的;

 

 

先是我们看看timer@c600那些设备节点下定义了interrupts属性,那表达该装置得以生出中断,可是这些性情下描述了几当中断大家是看不出来的(尽管有经历了,大家能猜出只是多少个制动踏板,今后大家根据准则确认)。因为该节点未有interrupt-parent属性,那么以为设备树的父节点internal-regs正是搁浅父节点,在internal-regs父节点下依然不曾interrupt-parent属性,那么还是继续找设备树父节点,找到了soc,在该节点上面有interrupt-parent属性。该属性援用的价签为gic,寻找整个设施树,interrupt-controller@d000的竹签为gic。gic节点下有interrupt-controller属性,表达她是叁个脚刹踏板调节器。gic节点还或者有属性#interrupt-cells
= <3>,表明在该调节器的interrupt domain下,中断源(interrupt
specifier)用3个u32表示,我们再看timer@c600下的interrupts属性也确确实实由3个u32组成(能够参见GIC的专门的学问,第贰个u32表示暂停类型,第2个是中断号,第多少个是暂停触发条件)。那几个例子表达假诺中断发生设备的中断源和间断调控器的中断源是逐大器晚成对应的,那么能够不需求interrupt
nexus节点及连锁的性质来表示暂停映射。

如上例子中断树的根是gic,gic上边有多少个男女,三个是行车制动器踏板设备timer@c600,七个是interrupt
nexus节点pcie@1,0。gic直接管辖的interrupt
domain用3个u32表示中断源,timer@c600在此个interrupt
domain下。pcie@1,0下定义了一个新的interrupt domain,在该interrupt
domain下,中断源用1个u32表示,pcie@1,0用interrupt-map和interrupt-map-mask属性将上面全体设施的中断映射到多少个gic下面的中断上。

 

interrupts

interrupt-controller
四个空属性用来声称这一个node接纳中断,即一个node是二个制动踏板调整器;

 

 1 / {
 2     model = "Marvell Armada 375 family SoC";
 3     compatible = "marvell,armada375";
 4     soc {
 5         #address-cells = <2>;
 6         #size-cells = <1>;
 7         interrupt-parent = <&gic>;
 8 
 9         internal-regs {
10             compatible = "simple-bus";
11             #address-cells = <1>;
12             #size-cells = <1>;
13 
14             timer@c600 {
15                 compatible = "arm,cortex-a9-twd-timer";
16                 reg = <0xc600 0x20>;
17                 interrupts = <GIC_PPI 13 (IRQ_TYPE_EDGE_RISING | GIC_CPU_MASK_SIMPLE(2))>;
18                 clocks = <&coreclk 2>;
19             };
20 
21             gic: interrupt-controller@d000 {
22                 compatible = "arm,cortex-a9-gic";
23                 #interrupt-cells = <3>;
24                 #address-cells = <0>;
25                 interrupt-controller;
26                 reg = <0xd000 0x1000>,
27                       <0xc100 0x100>;
28             };
29         }
30 
31         pcie-controller {
32             compatible = "marvell,armada-370-pcie";
33             #address-cells = <3>;
34             #size-cells = <2>;
35 
36             pcie@1,0 {
37                 #address-cells = <3>;
38                 #size-cells = <2>;
39                 #interrupt-cells = <1>;
40                 interrupt-map-mask = <0 0 0 0>;
41                 interrupt-map = <0 0 0 0 &gic GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
42             };
43         };

 

相关文章