日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 電源 > 功率器件
[導(dǎo)讀]硬件連接MPSoC 可以接收兩組來(lái)自 PL 的中斷信號(hào)。在 Vivado 中,可以通過(guò) PS-PL Configuration -> General -> Interrupts -> PL to PS -> IRQ0/IRQ1 打開(kāi)。 對(duì)應(yīng)的硬件中斷

硬件連接

MPSoC 可以接收兩組來(lái)自 PL 的中斷信號(hào)。在 Vivado 中,可以通過(guò) PS-PL Configuration -> General -> Interrupts -> PL to PS -> IRQ0/IRQ1 打開(kāi)。

 

 

對(duì)應(yīng)的硬件中斷號(hào)分別是

PL PS Group 0: 121-128

PL PS Group 1: 136-143

這兩組中斷信號(hào)既可以與 IPI 中的 IP 的中斷信號(hào)相連接,也可以和 Verilog 中的邏輯相連接。如果有多個(gè)中斷源要連接到一組信號(hào)中,可以使用concat將多個(gè)信號(hào)組合成一組信號(hào),然后連接到 IRQ。

 

 

如果要從 Verilog 引入中斷信號(hào),需要在 IPI 中按右鍵選擇 Create Port。Port Type 選擇為 Interrupt。

 

 

軟硬件的橋梁: device tree

硬件信息怎樣傳送給軟件系統(tǒng)?

Linux 的答案是 Device Tree。

以下是 Device Tree Generator 為上圖中的 AXI UARTLite 自動(dòng)創(chuàng)建的 device tree。

axi_uartlite_0: serial@a0000000 {

clocks = <&misc_clk_0>;

compatible = "xlnx,xps-uartlite-1.00.a";

current-speed = <115200>;

device_type = "serial";

interrupt-parent = <&gic>;

interrupts = <0 89 1>;

port-number = <1>;

reg = <0x0 0xa0000000 0x0 0x10000>;

xlnx,baudrate = <0x2580>;

xlnx,data-bits = <0x8>;

xlnx,odd-parity = <0x0>;

xlnx,s-axi-aclk-freq-hz-d = "99.999";

xlnx,use-parity = <0x0>;

};

創(chuàng)建 Device Tree

Device tree 是純文本文件,后綴是 .dts 或 .dtsi。當(dāng)然可以手工從頭開(kāi)始寫(似乎沒(méi)人這么做),Xilinx 也提供了工具來(lái)幫助自動(dòng)生成。

一種方法是使用 PetaLinux,其實(shí)這也是 petalinux-build 中的一個(gè)步驟。當(dāng)在一個(gè) PetaLinux 工程中導(dǎo)入 HDF 后,運(yùn)行 petalinux-build它會(huì)自動(dòng)調(diào)用 Device Tree Generator (DTG),為你的工程產(chǎn)生 device tree。用戶可以在自動(dòng)生成的文件的基礎(chǔ)上進(jìn)一步修改,修改的時(shí)候注意文件都上會(huì)寫哪些文件重新生成時(shí)會(huì)被覆蓋,哪些不會(huì)。

另一種生成 device tree 的方法是使用 SDK。SDK 可以把 DTG 加載為 BSP Generator,用來(lái)生成 device tree. DTG 的下載地址是 [ https://github.com/Xilinx/device-tree-xlnx ]。下載到本地后,在 SDK 的 Xilinx Tools -> Repositories 中添加解壓后的目錄。在 SDK 中新建一個(gè) BSP, BSP 類型選擇 device_tree

Note: 如果是SDx工具,加載DTG的方法是 Window -> Preference -> Xilinx SDK -> Repositories

Interrupt 屬性的定義

Device tree 中和中斷相關(guān)的屬性有兩條,interrupts和interrupt-parents。

interrupt-parents指向了中斷控制器。在 MPSoC 中有多個(gè)外設(shè)都有中斷控制器屬性,分別是 GIC, GPIO, PCIe。

interrupts 后的參數(shù)指定了中斷號(hào)和中斷屬性。

Device tree bindings interrupts.txt 中定義了 interrupts 后參數(shù)的意義。需要注意的是,在中斷控制器的屬性中有#interrupt-cells的定義,表示interrupts參數(shù)需要幾個(gè)32位的字符。常見(jiàn)的情況是1到3。1個(gè)Cell的情況只填寫中斷號(hào)。2個(gè)Cell的情況填寫中斷號(hào)和觸發(fā)條件,GPIO Controller就是這種情況。

ARM GIC 使用的是 3 個(gè) Cell:

第一個(gè) cell 是 0 的話表示中斷類型:0 for SPI interrupts, 1 for PPI interrupts。PL 到 PS 的中斷屬于 SPI,所以填寫 0。

第二個(gè) Cell 表示中斷號(hào)

第三個(gè) Cell 表示中斷觸發(fā)方式。

ARM GIC v3 中斷 Cell 說(shuō)明,來(lái)自 arm,gic-v3.txt

The 1st cell is the interrupt type; 0 for SPI interrupts, 1 for PPI

interrupts. Other values are reserved for future use.

The 2nd cell contains the interrupt number for the interrupt type.

SPI interrupts are in the range [0-987]. PPI interrupts are in the

range [0-15].

The 3rd cell is the flags, encoded as follows:

bits[3:0] trigger type and level flags.

1 = edge triggered

4 = level triggered

中斷號(hào)的確定

Device tree 中 interrupts 的中斷號(hào)請(qǐng)?zhí)顚懹布布袛嗵?hào) - 32

中斷的驅(qū)動(dòng)程序

PetaLinux 中自帶了中斷服務(wù)程序的例子。

用命令 petalinux-create -t modules -n mymodule就可以創(chuàng)建出例子程序。

其中與注冊(cè) IRQ 中斷號(hào)相關(guān)的語(yǔ)句為:

/* Get IRQ for the device */

r_irq = platform_get_resource(pdev, IORESOURCE_IRQ, 0);

if (!r_irq) {

dev_info(dev, "no IRQ foundn");

dev_info(dev, "mymodule at 0x%08x mapped to 0x%08xn",

(unsigned int __force)lp->mem_start,

(unsigned int __force)lp->base_addr);

return 0;

}

lp->irq = r_irq->start;

rc = request_irq(lp->irq, &mymodule_irq, 0, DRIVER_NAME, lp);

if (rc) {

dev_err(dev, "testmodule: Could not allocate interrupt %d.n",

lp->irq);

goto error3;

}

注意上面的程序是通過(guò)讀取 dts 獲取中斷的信息,然后讓操作系統(tǒng)分配一個(gè)虛擬中斷號(hào)。以前注冊(cè)中斷號(hào)是通過(guò)手工在 C 代碼中填入中斷號(hào),現(xiàn)在這種方法不可行了,請(qǐng)使用虛擬中斷號(hào)的方法。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀

太陽(yáng)的光線出現(xiàn)在生活中的每一個(gè)地方,人們的生活已經(jīng)離不開(kāi)太陽(yáng),太陽(yáng)能不僅為植物生長(zhǎng)提供光源,而且也能為人類提供能源,現(xiàn)在的光伏發(fā)電就是很大程度上利用了太陽(yáng)能。據(jù)最新一期《美國(guó)國(guó)家科學(xué)院院刊》報(bào)道,美國(guó)萊斯大學(xué)利用廉價(jià)塑料...

關(guān)鍵字: 氫燃料 電源技術(shù)解析 太陽(yáng)能海水 淡化系統(tǒng)

在現(xiàn)在的生活中,太陽(yáng)能產(chǎn)品處處可見(jiàn),人們用太陽(yáng)能煮飯,還有太陽(yáng)能熱水器等等,無(wú)處不見(jiàn)太陽(yáng)能產(chǎn)品,當(dāng)然,最重要的還是太陽(yáng)能發(fā)電,但是目前的技術(shù)并不能讓人們很好利用太陽(yáng)能發(fā)電。日前,科技部發(fā)布了《國(guó)家重點(diǎn)研發(fā)計(jì)劃“可再生能源...

關(guān)鍵字: 電池組件 電源技術(shù)解析 鈣鈦礦 協(xié)鑫

隨著社會(huì)的進(jìn)步,科技的發(fā)展,人們對(duì)能源的需求越來(lái)越大,而現(xiàn)有的能源有限,需要人們不斷發(fā)展新能源,而太陽(yáng)能就是一個(gè)不錯(cuò)的選擇,人們開(kāi)始大力發(fā)展太陽(yáng)能能發(fā)電。武漢大學(xué)高等研究院科研人員日前提出新的逐層刮涂技術(shù),該技術(shù)不僅使薄...

關(guān)鍵字: 光伏技術(shù) 太陽(yáng)能電池 電源技術(shù)解析 新涂膜技術(shù)

在科技的發(fā)展道路上,離不開(kāi)能源的助力,特別是再科技飛速發(fā)展的今天,而地球上的能源有限,就需要科研人員不斷開(kāi)發(fā)新能源,這就再當(dāng)下最需要研發(fā)太陽(yáng)能的使用。中國(guó)要實(shí)現(xiàn)在太空中建造一座兆瓦級(jí)太陽(yáng)能發(fā)電站,將面臨很多前所未有的挑戰(zhàn)...

關(guān)鍵字: 太陽(yáng)能電池 電源技術(shù)解析 石墨烯 傳統(tǒng)硅片

在科技的發(fā)展道路上,離不開(kāi)能源的助力,特別是再科技飛速發(fā)展的今天,而地球上的能源有限,就需要科研人員不斷開(kāi)發(fā)新能源,這就再當(dāng)下最需要研發(fā)太陽(yáng)能的使用。儲(chǔ)能電池技術(shù)是制約新能源儲(chǔ)能產(chǎn)業(yè)發(fā)展的關(guān)鍵技術(shù)之一。光伏電站儲(chǔ)能、風(fēng)電...

關(guān)鍵字: 儲(chǔ)能電池技術(shù) 電源技術(shù)解析 鋰離子電池 碳鉛電池

太陽(yáng)的光線出現(xiàn)在生活中的每一個(gè)地方,人們的生活已經(jīng)離不開(kāi)太陽(yáng),太陽(yáng)能不僅為植物生長(zhǎng)提供光源,而且也能為人類提供能源,現(xiàn)在的光伏發(fā)電就是很大程度上利用了太陽(yáng)能。近日,自從進(jìn)入夏季以來(lái),持續(xù)的高溫已經(jīng)“蒸烤”一段時(shí)間了。據(jù)中...

關(guān)鍵字: 光伏電站 光伏組件 光伏逆變器 電源技術(shù)解析

太陽(yáng)的光線出現(xiàn)在生活中的每一個(gè)地方,人們的生活已經(jīng)離不開(kāi)太陽(yáng),太陽(yáng)能不僅為植物生長(zhǎng)提供光源,而且也能為人類提供能源,現(xiàn)在的光伏發(fā)電就是很大程度上利用了太陽(yáng)能。在太陽(yáng)能離網(wǎng)系統(tǒng)中,光伏控制器的作用是把光伏組件發(fā)出來(lái)的電,經(jīng)...

關(guān)鍵字: 光伏控制器 太陽(yáng)能 電源技術(shù)解析 離網(wǎng)系統(tǒng)

在現(xiàn)在的生活中,太陽(yáng)能產(chǎn)品處處可見(jiàn),人們用太陽(yáng)能煮飯,還有太陽(yáng)能熱水器等等,無(wú)處不見(jiàn)太陽(yáng)能產(chǎn)品,當(dāng)然,最重要的還是太陽(yáng)能發(fā)電,但是目前的技術(shù)并不能讓人們很好利用太陽(yáng)能發(fā)電。隨著越來(lái)越多的分布式光伏電站走進(jìn)千家萬(wàn)戶,電站所...

關(guān)鍵字: 光伏電站 電源技術(shù)解析 組串逆變器 分布式光伏電站

太陽(yáng)的光線出現(xiàn)在生活中的每一個(gè)地方,人們的生活已經(jīng)離不開(kāi)太陽(yáng),太陽(yáng)能不僅為植物生長(zhǎng)提供光源,而且也能為人類提供能源,現(xiàn)在的光伏發(fā)電就是很大程度上利用了太陽(yáng)能。從目前太陽(yáng)能光伏電站的運(yùn)行管理工作實(shí)際經(jīng)驗(yàn)看,要保證光伏發(fā)電系...

關(guān)鍵字: 光伏電站 電源技術(shù)解析 光伏電站運(yùn)維管理 古瑞瓦特

隨著社會(huì)的進(jìn)步,科技的發(fā)展,人們對(duì)能源的需求越來(lái)越大,而現(xiàn)有的能源有限,需要人們不斷發(fā)展新能源,而太陽(yáng)能就是一個(gè)不錯(cuò)的選擇,人們開(kāi)始大力發(fā)展太陽(yáng)能能發(fā)電。有機(jī)-無(wú)機(jī)雜化鈣鈦礦材料由于具有吸收系數(shù)高,激子束縛能低和載流子壽...

關(guān)鍵字: 太陽(yáng)能電池 電源技術(shù)解析 西安 鈣鈦礦電池
關(guān)閉