那曲檬骨新材料有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

硬件信息怎樣傳送給軟件系統

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

硬件連接MPSoC 可以接收兩組來自 PL 的中斷信號。在 Vivado 中,可以通過 PS-PL Configuration -> General -> Interrupts -> PL to PS -> IRQ0/IRQ1 打開。

對應的硬件中斷號分別是PL PS Group 0: 121-128PL PS Group 1: 136-143

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

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

軟硬件的橋梁: device tree

硬件信息怎樣傳送給軟件系統?

Linux 的答案是Device Tree。

以下是 Device Tree Generator 為上圖中的 AXI UARTLite 自動創建的 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>;};

創建 Device TreeDevice tree 是純文本文件,后綴是 .dts 或 .dtsi。當然可以手工從頭開始寫(似乎沒人這么做),Xilinx 也提供了工具來幫助自動生成。

一種方法是使用 PetaLinux,其實這也是 petalinux-build 中的一個步驟。當在一個 PetaLinux 工程中導入 HDF 后,運行 petalinux-build它會自動調用 Device Tree Generator (DTG),為你的工程產生 device tree。用戶可以在自動生成的文件的基礎上進一步修改,修改的時候注意文件都上會寫哪些文件重新生成時會被覆蓋,哪些不會。

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

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

Interrupt 屬性的定義Device tree 中和中斷相關的屬性有兩條,interrupts和interrupt-parents。

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

interrupts 后的參數指定了中斷號和中斷屬性。

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

ARM GIC 使用的是 3 個 Cell:

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

第二個 Cell 表示中斷號第三個 Cell 表示中斷觸發方式。

ARM GIC v3 中斷 Cell 說明,來自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

中斷號的確定Device tree 中 interrupts 的中斷號請填寫硬件硬件中斷號 - 32

中斷的驅動程序PetaLinux 中自帶了中斷服務程序的例子。

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

其中與注冊 IRQ 中斷號相關的語句為:/* 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;}

注意上面的程序是通過讀取 dts 獲取中斷的信息,然后讓操作系統分配一個虛擬中斷號。以前注冊中斷號是通過手工在 C 代碼中填入中斷號,現在這種方法不可行了,請使用虛擬中斷號的方法。


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 中斷
    +關注

    關注

    5

    文章

    900

    瀏覽量

    41753
  • MPSoC
    +關注

    關注

    0

    文章

    199

    瀏覽量

    24322

原文標題:讓 Linux 接收來自 PL 的自定義中斷信號

文章出處:【微信號:FPGA-EETrend,微信公眾號:FPGA開發圈】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    如何設計一個油耗測控系統硬件電路圖

    我的設計是一個油耗測控系統,基于ZigBee,使用CC2530,但到畫硬件電路的時候不知怎么下手啊。設計框架是這樣的,先通過流量傳感器測出流量,產生脈沖,經信號調理,通過ZigBee通信模塊傳送給
    發表于 05-20 19:01

    如何將一個攝像頭的視頻通過藍牙傳送給手機?

    如何將一個攝像頭的視頻通過藍牙傳送給手機?求各位大神幫忙啊 。,,謝謝了、
    發表于 09-20 09:49

    系統硬件系統軟件

    `系統硬件框圖: 系統硬件主要有以下幾部分組成:LPC1343: 主控,協調各部分的工作;SYS_LED: 指示系統正在工作;BEEP: 給
    發表于 08-10 12:09

    車載信息娛樂系統的音頻來源

    新式的車載信息娛樂系統包含日益多元化的內容來源,包括專為乘客設計的前座和后座顯示器、來自便攜式設備的內容,以及便攜式計算設備的互聯網接入等。乘客有時會想要共享相同的內容,但卻并非每次都如此,因此音頻傳送
    發表于 05-16 10:44

    請問怎樣去設計硬件加密系統?

    硬件加密系統的結構是怎樣構成的?怎樣去設計硬件加密系統?如何對
    發表于 04-30 06:05

    請問怎樣設計一款車載信息采集系統?

    車載信息采集系統硬件設計車載信息采集系統軟件設計
    發表于 05-12 07:15

    請問怎樣去設計核信息遠程采集系統?

    怎樣去設計核信息遠程采集系統硬件部分?怎樣去設計核信息遠程采集
    發表于 05-27 07:09

    如何利用GPRS業務傳送GPS定位信息?

    本文討論的就是就是利用GPRS業務傳送GPS定位信息的實例模型。當然,GPS定位信息只是整個信息傳輸管理系統的一個應用,通過更換不同的數據源
    發表于 05-31 06:45

    怎樣通過DMA將數據從指定內存傳送給DAC數據寄存器

    有人使用STM32G431芯片做DAC應用,具體來說就是通過DMA將數據從指定內存傳送給DAC數據寄存器,并由定時器觸發DAC轉換。他發現總是沒法實現該功能。這里簡單介紹下相關實現過程,并...
    發表于 02-22 07:26

    彩色電視的傳送原理

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

    利用CDMA業務傳送GPS定位信息

      本文討論的就是利用CDMA業務傳送GPS定位信息的實例。當然,GPS定位信息只是整個信息傳輸管理系統的一個應用,通過更換不同的數據源模塊
    發表于 08-31 17:47 ?1381次閱讀
    利用CDMA業務<b class='flag-5'>傳送</b>GPS定位<b class='flag-5'>信息</b>

    車載信息娛樂系統、車載多媒體的經典案例

    設計方面的最新技術動向。 車載信息娛樂系統的無線音頻傳送技術 乘客有時會想要共享相同的內容,但卻并非每次都如此,因此音頻傳送系統必須能夠
    發表于 11-21 11:06 ?8次下載

    RFID對煤礦車輛怎樣實現有效的管理

    RFID讀寫器讀到該車上的RFID標簽并將該標簽內信息傳送給主機,同時指令電子衡傳送車輛車輛車重信息。
    發表于 01-09 15:58 ?526次閱讀

    闡述系統軟件定義和硬件定義

    軟件硬件,從硬件軟件硬件定義并驅動軟件,軟件
    的頭像 發表于 09-06 09:51 ?3158次閱讀

    ShiMetaOS | 怎樣調用ShiMeta信息發布軟件快速打造數字標牌產品

    發布軟件無縫集成于ShiMetaOS系統中,無需額外授權即可使用,極大地降低了使用成本,為用戶提供了一款高性價比的解決方案。二、怎樣調用ShiMetaOS的信息
    的頭像 發表于 02-05 17:10 ?25次閱讀
    ShiMetaOS  | <b class='flag-5'>怎樣</b>調用ShiMeta<b class='flag-5'>信息</b>發布<b class='flag-5'>軟件</b>快速打造數字標牌產品
    合肥百家乐赌博机| 网上真人娱乐场| 永利高百家乐怎样开户| 贵宾百家乐的玩法技巧和规则 | 百家乐官网赢的秘诀| 百家乐那里玩| 百家乐官网官| 新葡京娱乐城官方网站| 百家乐路单| 金银岛百家乐官网的玩法技巧和规则| 安新县| 百家乐赢一注| 网络百家乐官网的玩法技巧和规则| 广州市| 大发888游戏平台88| 百家乐电投软件| 百家乐投注必胜法| 路虎百家乐官网的玩法技巧和规则 | 百家乐游戏算牌| 百家乐官网红桌布| 百家乐官网玩牌| 百家乐官网小型抽水泵| 百家乐官网园千术大全| 沈阳娱乐棋牌网| 威尼斯人娱乐城官网| 玩百家乐凤凰娱乐城| 百家乐官网记算| 百家乐官网大西洋城v| 百家乐官网微心打法| 高邮市| 澳门足球博彩网站| 大发888网址| 二八杠网站| 大发888怎么玩才赢| 百家乐赌博千术| 百家乐tt娱乐城娱乐城| 百家乐翻天粤语快播| 百家乐分析概率原件| 百家乐导航网| 金木棉百家乐网络破解| 真人百家乐试玩游戏|