0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

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

YCqV_FPGA_EETre ? 來(lái)源:未知 ? 作者:佚名 ? 2017-09-28 06:39 ? 次閱讀

硬件連接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-128PL 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 TreeDevice tree 是純文本文件,后綴是 .dts 或 .dtsi。當(dāng)然可以手工從頭開(kāi)始寫(xiě)(似乎沒(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ì)寫(xiě)哪些文件重新生成時(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的情況只填寫(xiě)中斷號(hào)。2個(gè)Cell的情況填寫(xiě)中斷號(hào)和觸發(fā)條件,GPIO Controller就是這種情況。

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

第一個(gè) cell 是 0 的話表示中斷類型:0 for SPI interrupts, 1 for PPI interrupts。PL 到 PS 的中斷屬于 SPI,所以填寫(xiě) 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 PPIinterrupts. 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 therange [0-15].

The 3rd cell is the flags, encoded as follows:bits[3:0] trigger type and level flags.1 = edge triggered4 = level triggered

中斷號(hào)的確定Device tree 中 interrupts 的中斷號(hào)請(qǐng)?zhí)顚?xiě)硬件硬件中斷號(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 found\n");dev_info(dev, "mymodule at 0x%08x mapped to 0x%08x\n",(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)的方法。


聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 中斷
    +關(guān)注

    關(guān)注

    5

    文章

    895

    瀏覽量

    41349
  • MPSoC
    +關(guān)注

    關(guān)注

    0

    文章

    196

    瀏覽量

    24230

原文標(biāo)題:讓 Linux 接收來(lái)自 PL 的自定義中斷信號(hào)

文章出處:【微信號(hào):FPGA-EETrend,微信公眾號(hào):FPGA開(kāi)發(fā)圈】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    如何設(shè)計(jì)一個(gè)油耗測(cè)控系統(tǒng)硬件電路圖

    我的設(shè)計(jì)是一個(gè)油耗測(cè)控系統(tǒng),基于ZigBee,使用CC2530,但到畫(huà)硬件電路的時(shí)候不知怎么下手啊。設(shè)計(jì)框架是這樣的,先通過(guò)流量傳感器測(cè)出流量,產(chǎn)生脈沖,經(jīng)信號(hào)調(diào)理,通過(guò)ZigBee通信模塊傳送給
    發(fā)表于 05-20 19:01

    如何將一個(gè)攝像頭的視頻通過(guò)藍(lán)牙傳送給手機(jī)?

    如何將一個(gè)攝像頭的視頻通過(guò)藍(lán)牙傳送給手機(jī)?求各位大神幫忙啊 。,,謝謝了、
    發(fā)表于 09-20 09:49

    系統(tǒng)硬件系統(tǒng)軟件

    `系統(tǒng)硬件框圖: 系統(tǒng)硬件主要有以下幾部分組成:LPC1343: 主控,協(xié)調(diào)各部分的工作;SYS_LED: 指示系統(tǒng)正在工作;BEEP: 給
    發(fā)表于 08-10 12:09

    車(chē)載信息娛樂(lè)系統(tǒng)的音頻來(lái)源

    新式的車(chē)載信息娛樂(lè)系統(tǒng)包含日益多元化的內(nèi)容來(lái)源,包括專為乘客設(shè)計(jì)的前座和后座顯示器、來(lái)自便攜式設(shè)備的內(nèi)容,以及便攜式計(jì)算設(shè)備的互聯(lián)網(wǎng)接入等。乘客有時(shí)會(huì)想要共享相同的內(nèi)容,但卻并非每次都如此,因此音頻傳送
    發(fā)表于 05-16 10:44

    請(qǐng)問(wèn)怎樣去建立SOPC硬件系統(tǒng)?

    怎樣去建立SOPC硬件系統(tǒng)?怎樣去裁剪和移植uClinux操作系統(tǒng)?用戶應(yīng)用程序是如何建立并執(zhí)行的?
    發(fā)表于 04-27 06:58

    請(qǐng)問(wèn)怎樣去設(shè)計(jì)硬件加密系統(tǒng)?

    硬件加密系統(tǒng)的結(jié)構(gòu)是怎樣構(gòu)成的?怎樣去設(shè)計(jì)硬件加密系統(tǒng)?如何對(duì)
    發(fā)表于 04-30 06:05

    請(qǐng)問(wèn)怎樣設(shè)計(jì)一款車(chē)載信息采集系統(tǒng)?

    車(chē)載信息采集系統(tǒng)硬件設(shè)計(jì)車(chē)載信息采集系統(tǒng)軟件設(shè)計(jì)
    發(fā)表于 05-12 07:15

    請(qǐng)問(wèn)怎樣去設(shè)計(jì)核信息遠(yuǎn)程采集系統(tǒng)

    怎樣去設(shè)計(jì)核信息遠(yuǎn)程采集系統(tǒng)硬件部分?怎樣去設(shè)計(jì)核信息遠(yuǎn)程采集
    發(fā)表于 05-27 07:09

    如何利用GPRS業(yè)務(wù)傳送GPS定位信息

    本文討論的就是就是利用GPRS業(yè)務(wù)傳送GPS定位信息的實(shí)例模型。當(dāng)然,GPS定位信息只是整個(gè)信息傳輸管理系統(tǒng)的一個(gè)應(yīng)用,通過(guò)更換不同的數(shù)據(jù)源
    發(fā)表于 05-31 06:45

    怎樣通過(guò)DMA將數(shù)據(jù)從指定內(nèi)存傳送給DAC數(shù)據(jù)寄存器

    有人使用STM32G431芯片做DAC應(yīng)用,具體來(lái)說(shuō)就是通過(guò)DMA將數(shù)據(jù)從指定內(nèi)存傳送給DAC數(shù)據(jù)寄存器,并由定時(shí)器觸發(fā)DAC轉(zhuǎn)換。他發(fā)現(xiàn)總是沒(méi)法實(shí)現(xiàn)該功能。這里簡(jiǎn)單介紹下相關(guān)實(shí)現(xiàn)過(guò)程,并...
    發(fā)表于 02-22 07:26

    彩色電視的傳送原理

    彩色電視的傳送原理 在發(fā)送端將攝取到的一幅彩色圖像分解為三個(gè)基色圖像信號(hào),然后把三種基色信號(hào)合用一個(gè)通道傳送給接收端,
    發(fā)表于 08-02 08:14 ?1363次閱讀
    彩色電視的<b class='flag-5'>傳送</b>原理

    利用CDMA業(yè)務(wù)傳送GPS定位信息

      本文討論的就是利用CDMA業(yè)務(wù)傳送GPS定位信息的實(shí)例。當(dāng)然,GPS定位信息只是整個(gè)信息傳輸管理系統(tǒng)的一個(gè)應(yīng)用,通過(guò)更換不同的數(shù)據(jù)源模塊
    發(fā)表于 08-31 17:47 ?1277次閱讀
    利用CDMA業(yè)務(wù)<b class='flag-5'>傳送</b>GPS定位<b class='flag-5'>信息</b>

    車(chē)載信息娛樂(lè)系統(tǒng)、車(chē)載多媒體的經(jīng)典案例

    設(shè)計(jì)方面的最新技術(shù)動(dòng)向。 車(chē)載信息娛樂(lè)系統(tǒng)的無(wú)線音頻傳送技術(shù) 乘客有時(shí)會(huì)想要共享相同的內(nèi)容,但卻并非每次都如此,因此音頻傳送系統(tǒng)必須能夠
    發(fā)表于 11-21 11:06 ?8次下載

    RFID對(duì)煤礦車(chē)輛怎樣實(shí)現(xiàn)有效的管理

    RFID讀寫(xiě)器讀到該車(chē)上的RFID標(biāo)簽并將該標(biāo)簽內(nèi)信息傳送給主機(jī),同時(shí)指令電子衡傳送車(chē)輛車(chē)輛車(chē)重信息。
    發(fā)表于 01-09 15:58 ?506次閱讀

    闡述系統(tǒng)軟件定義和硬件定義

    軟件硬件,從硬件軟件硬件定義并驅(qū)動(dòng)軟件,軟件
    的頭像 發(fā)表于 09-06 09:51 ?2919次閱讀