AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / user-574454

SMAero22's questions

Martin Hope
SMAero22
Asked: 2023-06-02 12:16:45 +0800 CST

为什么 linux 在尝试访问连接到轻量级 hps-to-fpga 桥接器(或任何桥接器)的外围设备时会冻结?

  • 6

我已经在 Altera DE1-SoC 开发板上工作了 8 个月。我正在处理的系统包括一个 Cyclone V FPGA 芯片,尤其是 5CSEMA5F31C6N。它在芯片上运行嵌入式 Linux 操作系统。

一切都很好,开发正在进行中。两周前,公司的一名硬件工程师组装了一块新的定制板。设计和组件与开发板的大部分相似。所有与 HPS 相关的引脚都以相同的方式连接,一个主要区别是默认控制台端口是 UART1。这个问题已经解决,我现在可以通过 UART1 接收 U-boot 和内核消息。

但是系统并没有完全启动。我已将此归因于多种原因。首先,我有一个 init.d 脚本可以导出 GPIO LED 并创建一个 sysfs 文件。导出 gpio pin 有效,但是,改变方向,或改变值,或从中读取,会导致系统冻结。我在 init.d 脚本上禁用了该功能并重新启动了设备。这次引导在另一个 init.d 脚本行上失败。该行将更改轻量级桥中寄存器的值。命令是devmem 0xFF200XXX 32 1,其中 XXX 是特定的寄存器。

我尝试在所有网桥上使用 devmem,但所有尝试都会冻结 Linux。我尝试在 HPS 的 UART 寄存器、HPS 的 SDCard 寄存器(此处引用)上使用 devmem ,但它没有冻结。

我可以通过读取每个桥的状态 sysfs 文件来验证桥是否已启用: fpga_bridge state returns enabled

我还可以通过此 dmesg 输出验证网桥是否链接到驱动程序: dmesg output

我使用 Quartus Platform Designer 在 hps 配置中启用了所有三个桥接器。我的 u-boot.scr 中也有以下几行:

fatload mmc 0:1 $fpgadata soc_system.rbf;
fpga load 0 $fpgadata $filesize;
setenv fdtimage soc_system.dtb;
run bridge_enable_handoff;
run mmcload;
run mmcboot;

我还尝试按照这些说明通过 U-boot 命令行启用网桥。

但是,我无法将任何内容写入 $l3regs: 写入 l3regs

我正在使用带有 4.4 Linux 内核的 Buildroot 2016.05 构建操作系统。要创建 .rbf、.dts、.dtb、preloader-mkpimage.bin 和 u-boot 文件,我使用的是 SoC EDS 18.1 [Build 625]。

我已经没有什么可以尝试的了。

如果我能够使用 sysfs 文件从 Linux 操作系统打开和关闭 LED,我会认为问题已解决。

假设硬件是正确的,还有什么可能是原因,我该如何解决?

embedded
  • 1 个回答
  • 23 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve