Zybo GPIO Demo Run Embedded Linux
1.Environment
Ubuntu 12.04 x86_64
Vivado 2013.4
SDK 2013.4
2.Pre-requisites
2.1 CodeSourcery arm-gcc toolchain lite 32-bit compatible
git clone https://github.com/xupsh/CodeSourcery.git
echo “export PATH=~/CodeSourcery/bin:$PATH” >> ~/.bashrc
echo “export CROSS_COMPILE=arm-xilinx-linux-gnueabi-“ >> ~/.bashrc
arm-xilinx-linux-gnueabi-gcc –v
2.2 fsbl Download
http://pan.baidu.com/s/1jGj1yLK
LinaroDemo-> boot_image
2.3 u-boot Download
http://pan.baidu.com/s/1dD6D2pz
git clone https://github.com/Xilinx/u-boot-xlnx.git
Click Download ZIP right hand
2.4 devicetree Download
http://pan.baidu.com/s/1pJyR4pl
2.5 Kernel Download
http://pan.baidu.com/s/1pJqec35
https://github.com/Xilinx/linux-xlnx
branch->tags->Xilinx-v2013.4
2.6Randisk Download
wget http://www.wiki.xilinx.com/file/view/arm_ramdisk.image.gz/419243558/arm_ramdisk.image.gz
3.Hardware
Open vivado,Create a new project named zybo_gpio_demo,Click next。
In the device selection pannel,we choose xc7z010clg400-1 destdevice。
Add a new block design,named design_1。
Click Add Ip button in the view window,and add ZYNQ IP Core.
Double Click IP Core to configure it。
Choose Import XPS Settings,Add ZYBO_zynq_def.xml,click OK。
Download Link:
http://www.digilentinc.com/Data/Products/ZYBO/ZYBO_def.zip
Now ZYNQ has been configured and fit for zybo。
Click OK,go back to block design,click Add Ip button again,Insert GPIO IP core。
Double click GPIO core to config it:
The configuration is as follows:open Dual Channel,Set the bit width of each channel to 4bit。
Click Run Block Automation in the, and Run Connection Automation tips column, and Vivado will auto connection and configure。Click ok in all the pop-up dialogs。
Click refresh button at bottom left,the result is as follows。
In Source window, choose Sources tab,right click design_1, choose Generate Output Products…
Right click zynq_system_1,choose Create HDL Wrapper,Keep default,click OK, Vivado will generate a top file for IP subsystem。
Right click Constraints->constrs_1 and choose Add Source。
In the pop-up dialog,choose Create File…,rename it to system.xdc。
http://www.digilentinc.com/Data/Products/ZYBO/ZYBO_Master_xdc.zip
reference ZYBO_Master.xdc, add LED and SW constraints altogether 8 lines。
Finally,In Flow Navigator,expand Program and Debug,click Generate Bitstream.
When bitstream generated,Bitstream Generation successful completed dialog will be open, Choose Open Implementation Design,Click OK to finish.
In IP Integrator Item, click Open Block Design,choose zynq_system_1.bd,reopen the Block Design we built.
Choose File > Export > Export Hardware for SDK….,Export Hardware for SDK dialogue will be open,make sure Include bitstream and Launch SDK has been choosed.
4.Linux
4.1Compile u-boot
Enter u-boot source code folder and modify the boot file:
vi ./include/configs/zynq_zed.h
Modify line 39, insert code:
#define CONFIG_ZYNQ_PS_CLK_FREQ 50000000UL
Run the following command in u-boot source code folder.
make zynq_zed config
make
cp u-boot u-boot.elf
4.2Compile Kernel
Enter kernel source code folder, and run the following command.
cd linux-xlnx-xilinx-v2013.4
make ARCH=arm xilinx_zynq_defconfig
make ARCH=arm UIMAGE_LOADADDR=0x8000 uImage
cp arch/arm/boot/uImage .
4.3 Change Randisk
Run the following command and do the modify:
cp arm_ramdisk.image.gz ramdisk.image.gz
gunzip ramdisk.image.gz
mkdir file_tmp
mount ramdisk.image –o loop ./file_tmp/
Run the following command to repack to uramdisk:
sudo umount file_tmp/
gzip ramdisk.image
sudo apt-get install u-boot-tools
mkimage –A arm –T ramdisk –C gzip –d ramdisk.image.gz uramdisk.image.gz
5.References
5.1 My source references
http://pan.baidu.com/s/1bnq23UZ
5.2 Zybo Demo
http://www.digilentchina.com/product-more.asp?ClassId=1&Unid=367
5.3 Zybo Design Engineer Source
http://www.digilentinc.com/Products/Detail.cfm?Prod=ZYBO
6.Tips
6.1 If there are no mmcblk0p2 in the /dev/ folder?
You can connect the sdio(mmc) part to the arm processer in the ZYNQ IP configuration window
6.2 How to boot arm ubuntu with auto login?
solution: modify /etc/init/ttyPS0.conf, insert a line in the end,
exec /bin/login -f root < /dev/ttyPS0 > /dev/ttyPS0 2>&1
Zybo GPIO Demo Run Embedded Linux的更多相关文章
- 构建自己的embedded linux系统
[教程]使用buildroot完全自定义自己的embedded linux系统(nand)http://www.eeboard.com/bbs/thread-38377-1-1.html [教程] [ ...
- 【转载】关于Embedded Linux启动的经典问题
转载自:http://linux.chinaunix.net/techdoc/install/2009/04/13/1107608.shtml 发信人: armlinux (armlinux), 信区 ...
- How to build and run ARM Linux on QEMU from scratch
This blog shows how to run ARM Linux on QEMU! This can be used as a base for later projects using th ...
- Qt for Embedded Linux
1. Qt for Embedded Linux http://doc.qt.io/qt-5/embedded-linux.html 2. Installing Qt for Embedded Lin ...
- 虹软人脸识别——官方 Qt Demo 移植到 Linux
一.前言 最近需要在 Linux 平台下开发一个人脸识别相关的应用,用到了虹软的人脸识别 SDK.之前在 Windows 平台用过,感觉不错,SDK 里面还带了 Demo 可以快速看到效果.打开 Li ...
- postgresql9.5 run 文件linux安装后配置成开机服务
网上出现的比较多安装方法要么是源码安装,要么是yum安装,我发觉都要配置很多属性,比较麻烦,所以现在我在centos7长用 run文件来安装 http://get.enterprisedb.com/p ...
- Understanding Memory Technology Devices in Embedded Linux
转: NAND Chip Drivers NAND technology users such as USB pen drives, DOMs, Compact Flash memory, and S ...
- 记第一次使用NET CORE 2.2 完成的DEMO部署在LINUX并且上线
.NET CORE 这么久了一直没有成功打通过,今天花了点儿时间做了一个小DEMO,首次完成并且部署上线.记录一下. DEMO中只是测试了一下从MSSQL中获取数据,并且显示在页面上,涉及到了数据库连 ...
- Qt4.8.6 Embedded Linux 的编译与移植
最近买了个飞凌ok6410 的开发板,于是在其中搭建qt4.8.6运行环境.费了两三天时间,主要还是对Linux系统的生疏,在一些问题上徘徊很久,在这里做一些过程笔记.烧写ARM-Linux系统,根据 ...
随机推荐
- 11. KVC And KVO
1. KVC And KVO 的认识 KVC/KVO是观察者模式的一种实现 KVC全称是Key-value coding,翻译成键值编码.顾名思义,在某种程度上跟map的关系匪浅.它提供了一种使用 ...
- iOS书写高质量代码之耦合的处理
原创 2016-12-26 MrPeak MrPeak杂货铺 耦合是每个程序员都必须面对的话题,也是容易被忽视的存在,怎么处理耦合关系到我们最后的代码质量.今天Peak君和大家聊聊耦合这个基本功话题, ...
- 【转】arm 开发工具比较(ADS vs RealviewMDK vs RVDS)
ADS REALVIEW MDK RVDS 公司 ARM Keil(后被ARM收购) ARM 版本 最新1.2 ,被RVDS取代 最新4.0 是否免费 破解情况 有 有 工程管理 CodeWarr ...
- *使用while循环遍历数组创建索引和自增索引值
package com.chongrui.test;/* *使用while循环遍历数组 * * * */public class test { public static void main ...
- [Java 8] (10) 使用Lambda完成函数组合,Map-Reduce以及并行化
好文推荐!!!!! 原文见:http://blog.csdn.net/dm_vincent/article/details/40856569 Java 8中同时存在面向对象编程(OOP)和函数式编程( ...
- 【Java EE 学习 71 上】【数据采集系统第三天】【增加页面】【增加问题】【编辑页面,编辑问题】
增加页面和编辑页面.增加问题和编辑问题的页面使用的都是相同的页面,最后调用的方法是saveOrUpdate方法,所以只说一个就可以了. 一.增加页面 比较简单,略.流程如下: 单击“增加页”超链接-& ...
- ORACLE导入导出数据dmp
imp testwms3/isc@TESTGMMC FILE=C:\ZKGL_201407012334.dmp ignore=y fromuser=GMMCZKGL touser=testwms ta ...
- EF不能很好的支持DDD?估计是我们搞错了!
(此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:最近在ABP项目中尝试纯粹的DDD,然后遇到EF实现的Repository似乎不能很好 ...
- C语言语法 typedef小结
在总结typedef之前,先了解一个专业术语: 常量指针(const pointer):常量指针在定义的时候必须被初始化,而且一旦初始化完成,则它的值就不能再改变. int errNumb = 0; ...
- 百度UEditor在线编辑器的配置和图片上传
前言 最近在项目中使用了百度UEditor富文本编辑器,配置UEditor过程中遇到了几个问题,在此记录一下解决方案和使用方法,避免以后使用UEditor出现类似的错误. 基本配置 一.下载UEdit ...