This is for Devicetree Specification Release 0.1

Interrupt Mapping Example p19

在講解前,先帶進一些 PCI 的基礎觀念

pci device 的 其中一種 type address 由下方組成



為什麼 硬體要連成這樣子呢? 因為要 loading balance

pci device 的 INTA 是較常使用到的,

INTB,INTC,INTD 是較少使用到,

假如每個 device 的 INTA 都發出中斷,這種接線方式會讓 每個中斷 都接到一根 IRQ。

Interrupt Mapping Example p19

有兩個 PCI slots (IDSEL 0x11, 0x12)

每個 slot 有 4 個 中斷 pin, INTA,INTB,INTC,INTD

並且連接到 Open PIC interrupt controller

IDSEL(Initialization Device Select)是指"it used as a chip select during configuration read and write transactions."

這部分會連接到PCI AD[31:11],是由硬體拉線所決定的。

soc {
compatible = "simple-bus";
#address-cells = <1>;
#size-cells = <1>; open-pic {
clock-frequency = <0>;
interrupt-controller; // interrupt controller node 需要填寫 interrupt-controller property
#address-cells = <0>;
#interrupt-cells = <2>;
}; pci {
#interrupt-cells = <1>;
#size-cells = <2>;
#address-cells = <3>;
interrupt-map-mask = <0xf800 0 0 7>;
interrupt-map = <
/* IDSEL 0x11 - PCI slot 1 */
0x8800 0 0 1 &open-pic 2 1 /* INTA */
0x8800 0 0 2 &open-pic 3 1 /* INTB */
0x8800 0 0 3 &open-pic 4 1 /* INTC */
0x8800 0 0 4 &open-pic 1 1 /* INTD */
/* IDSEL 0x12 - PCI slot 2 */
0x9000 0 0 1 &open-pic 3 1 /* INTA */
0x9000 0 0 2 &open-pic 4 1 /* INTB */
0x9000 0 0 3 &open-pic 1 1 /* INTC */
0x9000 0 0 4 &open-pic 2 1 /* INTD */
>;
};
};

interrupt-map table 裡的每一列,包含5個部分,

1.child unit address

2.child interrupt specifier

3.interrupt parent

4.parent unit address

5.parent interrupt specifier

child unit address 和 child interrupt specifier 會對應到 特定的 parent unit address 及 interrupt specifier 的 interrupt parent。

interrupt-map table 裡的第一列,

0x8800 0 0 1 &open-pic 2 1

1。child unit address 是 0x8800 0 0

為什麼是由3個 32-bit cells 組成 child unit address?

因為 pci controller 裡的 address-cells property 是3,

所以 PCI bus 是使用 3 個 address cells 來表達 PCI bus。

為什麼是 0x8800?

因為 IDSEL 其中一個是 0x11,這連接到PCI AD[31:11],所以整個 pci address 編碼為 0x8800(編碼方式最上面有提到).

2。child interrupt specifier 是 1

pci controller 的 interrupt-cells 是1,

所以只用一個cell 表達 child interrupt specifier,

而 1 是表達 INTA,(不是從0)

這是指 child interrupt domain,不是 parent interrupt domain。

3。interrupt parent 是 &open-pic

這會填入interrupt parent 的 phandle 的值,來代表 要將 中斷傳給誰(parent)。

4。沒有parent unit address。

因為 parent interrupt domain (open-pic)的 address-cells property 是 0。

5。parent interrupt specifier 是 2 1

parent 的 interrupt-cells 是 2,

所以是使用 2 個 cells 表達 parent interrupt secpfier

2代表 中斷要連到 parent 的 IRQ2。

1代表 level/sense encoding,還不知道這是什麼。

interrupt-map-mask

interrupt-map-mask = <0xf800 0 0 7>

在搜尋 interrupt map table之前,child unit address 及 child interrupt specifier 會先經過

interrupt-map-mask 做 & bit 運算後,得到一個結果,再到 interrupt map talbe 裡取出對應 parent unit address 及 parent interrupt specifier。

Ex:

一個 pci device IDSEL 0x12 (slot 2),function 0x3,發出 INTB 中斷,然後要去 interrupt map talbe 找出 parent open-pic 的 interrupt source number,也就是要找出對應的 parent 中斷 IRQ

pci device 的 address (IDSEL 0x12 (slot 2),function 0x3) 編碼為 0x9300(編碼方式最上面有提到),

因為 pci controller 的 address-cells 為3,所以最後編碼為 0x9300 0 0,

pci device 的 INTB 中斷,編碼為 2,

child unit address及child interrupt specifier整個是 < 0x9300 0 0 2 >。

而<0x9300 0 0 2> 要與 interrupt-map-mask <0xf800 0 0 7> 做 & bit 運算,

得到結果為 <0x9000 0 0 2>,

<0x9000 0 0 2>再往 interrupt map table搜尋 找出,

parent unit address 為空,為什麼為空,因為 parent (open-pic) 的 #address-cells = <0>

parent interrupt specifier 為 <4 1>,對應到 parent (open-pic) 的 IRQ4,1尚未知道其意義,

這樣就完成了 child interrupt domain 到 parent interrupt domain 的轉換

那為什麼要做 interrupt-map-mask 運算呢?

依稀記得網上有篇文章提到,做interrupt-map-mask 運算是要找出那一個 device 發出那一個中斷,所以只保留 bus 及 device bits及 INTx,其它bits 歸零。

reference

http://www.devicetree.org/specifications/

PCI Local Bus Specification Revision 2.2

PCI Read/Write

[device tree] interrupt mapping example的更多相关文章

  1. [device tree] interrupt

    Specifying interrupt information for devices ============================================ 1) Interru ...

  2. Device Tree Usage( DTS文件语法)

    http://elinux.org/Device_Tree_Usage Device Tree Usage     Top Device Tree page This page walks throu ...

  3. Device Tree Usage(理解DTS文件语法)

    Basic Data Format The device tree is a simple tree structure of nodes and properties. Properties are ...

  4. Device Tree Usage 【转】

    转自:http://blog.chinaunix.net/uid-20522771-id-3457184.html 原文链接:http://devicetree.org/Device_Tree_Usa ...

  5. 學習 DT device tree 以 ST 的開發板 STM32F429i-disc1 為例

    目標 因為對 device tree 不是很熟悉, 所以就將 device tree, 設為學習目標. 啟動 注意, 這篇隨筆的解說都放在最下面,會標 Explanation_XX,只要搜尋 Expl ...

  6. Device Tree(二):基本概念

    转自:http://www.wowotech.net/linux_kenrel/dt_basic_concept.html 一.前言 一些背景知识(例如:为何要引入Device Tree,这个机制是用 ...

  7. Linux and the Device Tree

    来之\kernel\Documentation\devicetree\usage-model.txt Linux and the Device Tree ----------------------- ...

  8. Device Tree(三):代码分析【转】

    转自:http://www.wowotech.net/linux_kenrel/dt-code-analysis.html Device Tree(三):代码分析 作者:linuxer 发布于:201 ...

  9. ARM Linux 3.x的设备树(Device Tree)

    http://blog.csdn.net/21cnbao/article/details/8457546 宋宝华 Barry Song <21cnbao@gmail.com> 1.     ...

随机推荐

  1. apiDoc 入门

    网站 http://apidocjs.com/#demo Install npm install apidoc -g Run apidoc -i myapp/ -o apidoc/ -t mytemp ...

  2. BZOJ 1179 Atm(强连通分量缩点+DP)

    题目说可以通过一条边多次,且点权是非负的,所以如果走到图中的一个强连通分量,那么一定可以拿完这个强连通分量上的money. 所以缩点已经很明显了.缩完点之后图就是一个DAG,对于DAG可以用DP来求出 ...

  3. Python 源码剖析(六)【内存管理机制】

    六.内存管理机制 1.内存管理架构 2.小块空间的内存池 3.循环引用的垃圾收集 4.python中的垃圾收集 1.内存管理架构 Python内存管理机制有两套实现,由编译符号PYMALLOC_DEB ...

  4. BZOJ5289 & 洛谷4437:[HNOI/AHOI2018]排列——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=5289 https://www.luogu.org/problemnew/show/P4437 考虑 ...

  5. LOJ6276:果树——题解

    https://loj.ac/problem/6276#submit_code NiroBC 姐姐是个活泼的少女,她十分喜欢爬树,而她家门口正好有一棵果树,正好满足了她爬树的需求.这颗果树有N 个节点 ...

  6. [Leetcode] Maximum depth of binary tree二叉树的最大深度

    Given a binary tree, find its maximum depth. The maximum depth is the number of nodes along the long ...

  7. sass的颜色函数

    sass中有些非常实用的颜色处理函数,总结如下 1.颜色加深或变浅 lighten($color,$amount) //颜色变浅 darken($color,$amount) //颜色加深 例如: l ...

  8. bzoj1014: [JSOI2008]火星人prefix(splay+hash+二分)

    题目大意:一个字符串三个操作:①求两个后缀的LCP②插入一个字符③修改一个字符. 前几天刚学了hash+二分求lcp,就看到这题. 原来splay还能这么用?!原来splay模板这么好写?我以前写的s ...

  9. 【数位DP】【SCOI2009】windy数

    传送门 Description \(windy\)定义了一种\(windy\)数.不含前导零且相邻两个数字之差至少为\(2\)的正整数被称为\(windy\)数.\(windy\)想知道, 在\(A\ ...

  10. JavaScript倒计时脚本

    JavaScript倒计时在Web中用得非常广泛,比如常见的团购啊.还有什么值得期待的事情,都可以用到倒计时.现在举了四个例子,比如时间长的倒计时,小时倒计时,最简的倒计时,还有秒表等等,应该可以满足 ...