是制动踏板调节器节点的天性

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

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

 

interrupts

叁个Computer种类中大批量设备都以通过中断要求CPU服务的,所以设备节点就需求在内定中断号。常用的天性;

 

interrupt-controller
三个空属性用来声称这几个node选择中断,即二个node是多少个暂停调整器;

 

#interrupt-cells,是行车制动器踏板调整器节点的品质,用来标志那一个调整器须要多少个单位做中断描述符,用来说述子节点”interrupts”属性使用了父节点中的interrupt属性的切实可行哪些值;平常,假若父节点的该属性的值为3,则子节点的interrupts二个cell的四个32bits的整数值分别为:<中断域
中断 触发方式>,要是父节点的该属性为2,则是<中断 触发方式>
interrupt-parent,标志此设施节点归属哪两个搁浅调节器,若无安装那几个性格,会自动依靠父节点的;

 

interrups,一个行车制动器踏板标志符列表,表示每三个搁浅输出确定性信号;

 

 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         };

先是我们来看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表示暂停类型,第一个是中断号,第1个是行车制动器踏板触发条件)。那么些事例表达假若中断发生设备的中断源和制动踏板调控器的中断源是种种对应的,那么能够没有需求interrupt
nexus节点及有关的质量来代表暂停映射。

 

再看pcie@1,0这几个节点,有#365体育网投,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节点。

 

如上例子中断树的根是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上边的暂停上。

相关文章