当你可以修改点亮led灯那个实验led_test.sh, 改变led点灯的速度,以及顺序时, 一定想知道究竟发生了什么, 凭什么一个简单的脚本, 就在linux的用户层控制板子上的某一个硬件,比如说,灯。
对于习惯了在单片机环境下无操作系统裸奔c/汇编的兄弟来说, 上面的问题似乎有些多余. 直接对某个地址进行读写操作, 这个地址经过译码,对应的管脚,连到板子上led,不就可以控制led了吗。
这就说来话长了.简言之,linux 为了给每个进程一个独立的地址空间,特意划分了用户空间和内核空间。内核空间可以对物理地址操作,用户空间只是虚地址。 而内核与用户空间程序接口,采用特殊文件系统。也就是看上去像文件,其实连接到系统和设备的系统。比较老的有devfs文件系统位于设备驱动/dev,或者procfs位于/proc。当然,还有比较新的sysfs文件系统。
led_test.sh, 采用的就是sysfs文件系统。 这个文件系统的特点吧,主要是可以一层一层垒硬件的驱动,比如先总线驱动,再某个usb驱动,在usb挂载的设备的驱动。这比/dev一个设备驱动包括所有相关设备层次清晰很多。在linux内核2.6以后才有的。
对sysfs先来点感性认识,在zed任何一个终端窗口输入
sudo echo 61 > /sys/class/gpio/export
sudo echo out > /sys/class/gpio/gpio61/direction
sudo echo 1 >/sys/class/gpio/gpio61/value
sudo echo 0 >/sys/class/gpio/gpio61/value
你可以手工点亮或灭掉ld0那盏灯
输入命令的时候, 到底发生了什么, 信号是怎么传递的呢 ? 先大致了解一下,具体细节在书的后续章节还会详细说明
第一步,设备驱动控制gpio的寄存器. 这就需要交给linux 设备驱动来完成了。相关的介绍请参考书本在13.2节找到 .
第二步,那么gpio的寄存器地址是多少,有如何控制呢? 我们可以在xilinx ug585 找到
第三步,gpio是如何在pl那边,也就是fpga连接到芯片的管脚上的呢? 需要参考这个设计的硬件部分
zedboard上的linaro-ubuntu demo所使用的硬件工程。
其中对于zedboard的system.ucf中我们可以找到如下约束.比如,ld0那盏灯,是ps侧的processing_system7_0_gpio 通过pl测,连到管脚t22上的。
############################
# #
# on-board led's #
# #
############################
net processing_system7_0_gpio loc = t22 | iostandard = lvcmos33; # ld0
net processing_system7_0_gpio loc = t21 | iostandard = lvcmos33; # ld1
net processing_system7_0_gpio loc = u22 | iostandard = lvcmos33; # ld2
net processing_system7_0_gpio loc = u21 | iostandard = lvcmos33; # ld3
net processing_system7_0_gpio loc = v22 | iostandard = lvcmos33; # ld4
net processing_system7_0_gpio loc = w22 | iostandard = lvcmos33; # ld5
net processing_system7_0_gpio loc = u19 | iostandard = lvcmos33; # ld6
net processing_system7_0_gpio loc = u14 | iostandard = lvcmos33; # ld
第四步,t22那个管脚是如何连到真正的灯上的,需要参考zed板的文档:
2.7.3 user leds
the zedboard has eight user leds, ld0 – ld7. a logic high from the zynq-7000 ap soc i/o causes the led to turn on. led’s are sourced from 3.3v banks through 390ω resistors.
signal name subsection zynq pin
ld0 pl t22
ld1 pl t21
ld2 pl u22
ld3 pl u21
ld4 pl v22
ld5 pl w22
ld6 pl u19
ld7 pl u14
ld9 ps d5 (mio7)
我们可以看到ld0-ld7 都是pl部分的,也就是说这些都是emio,从pl的管脚连出。那么,emio是如何在设计中定义了processing_system7_0_gpio这个端口呢?需要看xps
2.我们可以在ports tag中找到这个标签。
3.同时system.mhs中就会自动出现这个定义
这样,从操作系统的脚本一直到点亮led,我们顺藤摸瓜,找到了软件侧,ps侧,可扩展io侧,pl侧所有相关文档和信号,完成了最简单的一个穿越软件,硬件,i/o, 板卡的all programmable 之旅。
百度飞桨及文心大模型赋能千行百业
连接器的发展趋势是什么?
了解一下被行业寄以广泛期待的“好望”
解决指南:将电解电容器替换为MLCC的指南修订
亚马逊和谷歌逐鹿智能家居 双雄争夺谁能成为赢家?
Kevin学ZED之(5):顺藤摸瓜
区块链在金融上的应用主要的安全问题是什么
怎样做快乐的程序员
安科瑞ABAT100系列蓄电池在线监测系统 提前对失效电池预警及电池均衡
使用超声波液位计时需要注意什么?
肉制品检测仪器设备的产品性能
手性纳米颗粒为3D显示和实时全息技术从概念跨入现实
欧司朗将与大陆集团进行拆分
英威腾光伏荣获2023“光能杯”最具影响力光伏逆变器企业
一文详解8088系统总线
WT588F02B-8S语音芯片:16位DSP技术引领个性化功能产品新时代
无缝替代GPU,让FPGA来加速你的AI推理
双11华为苹果将成为消费者最受欢迎的品牌
630kva变压器额定电流是多少
ADRF6850集成宽带正交解调器、频率合成器和可变增益放大