Kevin学ZED之(5):顺藤摸瓜.doc

上传人:白大夫 文档编号:3253446 上传时间:2019-08-06 格式:DOC 页数:3 大小:17KB
返回 下载 相关 举报
Kevin学ZED之(5):顺藤摸瓜.doc_第1页
第1页 / 共3页
亲,该文档总共3页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《Kevin学ZED之(5):顺藤摸瓜.doc》由会员分享,可在线阅读,更多相关《Kevin学ZED之(5):顺藤摸瓜.doc(3页珍藏版)》请在三一文库上搜索。

1、Kevin学ZED之(5):顺藤摸瓜当你可以修改点亮LED灯那个实验led_test.sh, 改变LED点灯的速度,以及顺序时, 一定想知道究竟发生了什么, 凭什么一个简单的脚本, 就在Linux的用户层控制板子上的某一个硬件,比如说,灯。对于习惯了在单片机环境下无操作系统裸奔C/汇编的兄弟来说, 上面的问题似乎有些多余. 直接对某个地址进行读写操作, 这个地址经过译码,对应的管脚,连到板子上LED,不就可以控制LED了吗。这就说来话长了简言之,Linux 为了给每个进程一个独立的地址空间,特意划分了用户空间和内核空间。内核空间可以对物理地址操作,用户空间只是虚地址。而内核与用户空间程序接口,

2、采用特殊文件系统。也就是看上去像文件,其实连接到系统和设备的系统。比较老的有devfs文件系统位于设备驱动/dev,或者procfs位于/proc。当然,还有比较新的sysfs文件系统。Led_test.sh, 采用的就是sysfs文件系统。这个文件系统的特点吧,主要是可以一层一层垒硬件的驱动,比如先总线驱动,再某个USB驱动,在USB挂载的设备的驱动。这比/dev一个设备驱动包括所有相关设备层次清晰很多。在linux内核2.6以后才有的。对sysfs先来点感性认识,在ZED任何一个终端窗口输入sudo echo 61 /sys/class/gpio/exportsudo echo out /

3、sys/class/gpio/gpio61/direcTIonsudo echo 1 /sys/class/gpio/gpio61/valuesudo echo 0 /sys/class/gpio/gpio61/value你可以手工点亮或灭掉LD0那盏灯输入命令的时候, 到底发生了什么, 信号是怎么传递的呢 ? 先大致了解一下,具体细节在书的后续章节还会详细说明第一步,设备驱动控制GPIO的寄存器. 这就需要交给Linux 设备驱动来完成了。相关的介绍请参考书本在13.2节找到 .第二步,那么GPIO的寄存器地址是多少,有如何控制呢? 我们可以在Xilinx ug585 找到第三步,GPIO是

4、如何在PL那边,也就是FPGA连接到芯片的管脚上的呢?需要参考这个设计的硬件部分zedboard上的linaro-ubuntu demo所使用的硬件工程。其中对于zedboard的system.ucf中我们可以找到如下约束比如,LD0那盏灯,是PS侧的processing_system7_0_GPIO7通过PL测,连到管脚T22上的。# # On-board LEDs # #net processing_system7_0_GPIO7 LOC = T22 | IOSTANDARD = LVCMOS33; # LD0net processing_system7_0_GPIO8 LOC = T21

5、 | IOSTANDARD = LVCMOS33; # LD1net processing_system7_0_GPIO9 LOC = U22 | IOSTANDARD = LVCMOS33; # LD2net processing_system7_0_GPIO10 LOC = U21 | IOSTANDARD = LVCMOS33; # LD3net processing_system7_0_GPIO11 LOC = V22 | IOSTANDARD = LVCMOS33; # LD4net processing_system7_0_GPIO12 LOC = W22 | IOSTANDARD

6、 = LVCMOS33; # LD5net processing_system7_0_GPIO13 LOC = U19 | IOSTANDARD = LVCMOS33; # LD6net processing_system7_0_GPIO14 LOC = U14 | IOSTANDARD = LVCMOS33; # LD第四步,T22那个管脚是如何连到真正的灯上的,需要参考ZED板的文档:2.7.3 User LEDsThe ZedBoard has eight user LEDs, LD0 LD7. A logic high from the Zynq-7000 AP SoC I/O cau

7、ses the LED to turn on. LEDs are sourced from 3.3V banks through 390 resistors.Signal Name SubsecTIon Zynq pinLD0 PL T22LD1 PL T21LD2 PL U22LD3 PL U21LD4 PL V22LD5 PL W22LD6 PL U19LD7 PL U14LD9 PS D5 (MIO7)我们可以看到LD0-LD7 都是PL部分的,也就是说这些都是EMIO,从PL的管脚连出。那么,EMIO是如何在设计中定义了processing_system7_0_GPIO这个端口呢?需要看xps2.我们可以在ports tag中找到这个标签。3.同时system.mhs中就会自动出现这个定义这样,从操作系统的脚本一直到点亮LED,我们顺藤摸瓜,找到了软件侧,PS侧,可扩展IO侧,PL侧所有相关文档和信号,完成了最简单的一个穿越软件,硬件,I/O, 板卡的All Programmable 之旅。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1