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

    文章

    895

    浏览量

    41419
  • MPSoC
    +关注

    关注

    0

    文章

    198

    浏览量

    24256

原文标题:让 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

    请问怎样去建立SOPC硬件系统

    怎样去建立SOPC硬件系统怎样去裁剪和移植uClinux操作系统?用户应用程序是如何建立并执行的?
    发表于 04-27 06:58

    请问怎样去设计硬件加密系统

    硬件加密系统的结构是怎样构成的?怎样去设计硬件加密系统?如何对
    发表于 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 1371次阅读
    彩色电视的<b class='flag-5'>传送</b>原理

    利用CDMA业务传送GPS定位信息

      本文讨论的就是利用CDMA业务传送GPS定位信息的实例。当然,GPS定位信息只是整个信息传输管理系统的一个应用,通过更换不同的数据源模块
    发表于 08-31 17:47 1292次阅读
    利用CDMA业务<b class='flag-5'>传送</b>GPS定位<b class='flag-5'>信息</b>

    车载信息娱乐系统、车载多媒体的经典案例

    设计方面的最新技术动向。 车载信息娱乐系统的无线音频传送技术 乘客有时会想要共享相同的内容,但却并非每次都如此,因此音频传送系统必须能够
    发表于 11-21 11:06 8次下载

    RFID对煤矿车辆怎样实现有效的管理

    RFID读写器读到该车上的RFID标签并将该标签内信息传送给主机,同时指令电子衡传送车辆车辆车重信息
    发表于 01-09 15:58 508次阅读

    阐述系统软件定义和硬件定义

    软件硬件,从硬件软件硬件定义并驱动软件软件
    的头像 发表于 09-06 09:51 2962次阅读