第3篇:Linux程序访问控制FPGA端LEDR<一>

**Q:**如何在DE1-SoC-UP Linux系统中访问控制FPGA端外设呢?

**A:**DE1-SoC-UP Linux系统启动的过程中会自动配置Cyclone V SoC FPGA,系统将SoC设备配置到DE1-SoC_Computer系统的电路,其中包含一个双核ARM Cortex-A9处理器,以及与DE1-SoC板上的外设如SW、LED、Button、VGA等IP核。

在DE1-SoC-UP-Linux操作系统里,运行在ARM A9处理器上的程序可以访问FPGA端的硬件外设如LED、HEX和开关等。ARM处理器通过HPS-to-FPGA或Lightweight HPS-to-FPGA桥接器访问FPGA,这些桥被映射到ARM内存空间中的区域。当FPGA端组件(如IP核)连接到桥接器时,ARM处理器在桥接器内存区域内读写组件的内存映射寄存器。

要从Linux程序访问物理内存地址,必须调用Linux内核函数mmap并访问系统内存设备文件/dev/mem。mmap函数代表内存映射,它将文件映射到虚拟内存中。系统内存设备文件/dev/mem代表计算机系统的物理内存,在某个偏移处访问此文件相当于在偏移地址处访问物理内存。通过使用mmap将/dev/mem文件映射到虚拟内存中,可以将物理地址映射到虚拟地址,从而允许程序访问物理地址。

相关推荐
I'm a winner18 小时前
新手入门Makefile:FPGA项目实战教程(二)
笔记·fpga开发
我爱C编程21 小时前
基于FPGA的8PSK+卷积编码Viterbi译码通信系统,包含帧同步,信道,误码统计,可设置SNR
fpga开发·通信·8psk·帧同步·snr·卷积编码·维特比译码
I'm a winner1 天前
新手入门 Makefile:FPGA 项目实战教程(三)
fpga开发
范纹杉想快点毕业1 天前
嵌入式 C 语言编程规范个人学习笔记,参考华为《C 语言编程规范》
linux·服务器·数据库·笔记·单片机·嵌入式硬件·fpga开发
lazyduck2 天前
从半年到一年的 bug 往事:TCP modbus的卡死与补救
fpga开发·modbus
范纹杉想快点毕业2 天前
《嵌入式 C 语言编码规范与工程实践个人笔记》参考华为C语言规范标准
服务器·c语言·stm32·单片机·华为·fpga开发·51单片机
Chipi Chipi3 天前
FPGA即插即用Verilog驱动系列——串口数据、命令解析
fpga开发
FPGA_ADDA3 天前
基于 AMDXCVU47P HBM2 FPGA 的 2 路 100G 光纤 PCIe 高性能计算加速卡
fpga开发·vu47p·100g光纤pcie·高性能计算加速卡
霖003 天前
高级项目——基于FPGA的串行FIR滤波器
人工智能·经验分享·matlab·fpga开发·信息与通信·信号处理
I'm a winner3 天前
FPGA+护理:跨学科发展的探索(四)
笔记·fpga开发