拿过ZYNQ开发板,里面给了很多部件,果断从网上下载了手册,N多手册和原理图。

要比Spartan-6复杂多了,耐心地看了看,知道ZYNQ系列分为PS(系统)以及PL(逻辑)部分。

之前,自己一直在做MIPS处理器的实现,其实对很多概念也没什么大的认识,对于FPGA的认识其实就是数字电路+Verilog。

其实,我个人认为FPGA的学习与研究千万不能冒进,就是要肯下功夫慢慢来,只要时间够了,一切问题都可以迎刃而解。

今天,自己主要做两方面事情:利用Xilinx SDK编写HelloworldC程序,并运行在ZYNQ的操作系统下运行。

其次,使用SDK编写Helloworld工程,配置ARM环境。

(一)利用SDK编写arm-cross-compile程序

今天才发现14.1以上的SDK貌似都可以直接编写arm-cross-compile程序。果断试一下:

打开SDK,新建工程,选择C/C++ —— C Project,如下图所示

单击next,添加工程名hello,在Static Library下选择Xilinx ARM Linux Executable,如下图所示:

单击Finish,工程建立完毕。向工程添加C文件,单击File ——new —— Source File,输入文件名main.c(含后缀名)。如图:

在工程WorkSpace内单击main.c,并添加如下内容后保存:

#include <stdio.h>

int main()
{
    printf("Hello ZYNQ.\n");
    return 0;
}

在WorkSpace内右键单击工程名,选择Build Configuration—— Set Active —— 选择Release,因为文工程不需要Debug,直接Release即可。如图所示:

然后Build进入工程文件夹内,在Release文件夹下,找到Hello.elf文件,该文件即为程序执行所需文件,将该文件拷贝到U盘中。

然后需要安装驱动程序CyUSB2Serial_v3.0.11.0.zip,并将Xilinx官网ZedBoard_OOB_Design.zip内容拷贝到SD卡上。调整ZYNQ开发板跳线帽位置,如下图所示:

将JP2短接表示U盘作为从设备,一切就绪后,充电,打开超级终端(hypertrm),选择COM口,修改每秒位数115200。如图:

一段时间后,进入Linux终端界面,输入ls /dev,如图所示:

其中sda/sda1即为U盘内容,需要对U盘进行挂载,依次输入如下命令:

mount /dev/sda1 /mnt

cd /mnt

ls

如图所示,其中hello.elf即为执行文件,

输入./hello.elf执行。如图所示:

Hello ZYNQ。即为输出内容,可见该文件已经在ARM环境下运行,输入

cd ..

umount /mnt

卸载U盘,关闭电源。

(二)建立Helloworld工程。

启动PlanAhead(以前一直以为这个是鸡肋,现在才知道它才是精华),进入新建工程向导。

选择工程名和路径。单击Next,选择RTL Project,单击Next,如图所示:

一路Next,直到Default PartFamily选择zynq-7000Package选择clg484Speed选择-1,如图:

单击Next,单击Finish

生成工程文件,单击Project ManagerAdd Source,选择Add or Create Embedded Sources,如图。

单击Next,单击Create Sub-Design,添加module名称,选择module,单击Finish

等若干时间,Add Embedded Source。登录XPS时,弹出如下提示,单击Yes

登录XPS界面后,单击Import,选择配置xml文件,单击OK,提示后单击Yes,如图所示。

完成后,关闭XPS,回到PlanAhead。在Design Source下右键Module,单击Create TOP HDL,如图:

完成后生成.v文件。单击File—— Export —— Export Hardware for SDK,如图:

勾选Launch SDK,单击OK。如图:

登录SDK后,单击File —— Application Project。输入Project名,如图所示:

单击Next,选择Hello world,单击Finish,如下图所示:

完成后,生成若干文件,在src内找到Helloworld.c文件,如下图所示:

选中工程单击Build Project。Build结束后,单击Xilinx Tools —— Configure JTAG Settings,将Type类型修改为Digilent USB Cable,因为一会儿将使用USB线作为下载线,此处如果选择Auto,本人的环境是默认为Xilinx Hardware Server,所以一直不能下载,此处建议显示设置,单击OK,如图。

右键工程,选择Run As —— Run Configuration,双击Xilinx C/C++ application(GDB),如图:

一切准备就绪后,修改ZYNQ开发板跳线帽,如图:

并将prog mini-usb端连入PC用于下载程序,将uart mini-usb端连入PC,用于传输Hello world,连接好后,打开电源,打开超级终端,设置波特率115200

单击run,数秒后,在超级终端可接受字符串,如图所示:

关闭电源,实验结束。

本次学习笔记的工程及资源均可从百度网盘下载http://pan.baidu.com/share/link?shareid=696393914&uk=1092766566

【原创】ZYNQ学习笔记(一) HelloWorld实现的更多相关文章

  1. Spring MVC 学习笔记一 HelloWorld

    Spring MVC 学习笔记一 HelloWorld Spring MVC 的使用可以按照以下步骤进行(使用Eclipse): 加入JAR包 在web.xml中配置DispatcherServlet ...

  2. MOOS学习笔记2——HelloWorld回调

    MOOS学习笔记2--HelloWorld回调 例程 #include "MOOS/libMOOS/Comms/MOOSAsyncCommClient.h" bool OnConn ...

  3. MOOS学习笔记1——HelloWorld

    MOOS学习笔记1--HelloWorld 例程 /* * @功能:通讯客户端的最简单程序,向MOOSDB发送名为"Greeting" * 数据"Hello", ...

  4. U3D学习笔记1: HelloWorld

    Unity 版本: 5.3.5.f1 Hello World工程 1.新建工程 HelloWorld U3D可选2D和3D游戏   2.新建C#脚本文件 在project栏的assets目录右键-&g ...

  5. Zynq学习笔记(1)——Hellow World

    Zynq是一款SOC芯片,之前只是用了PL(Programmable Logic)部分,而Zynq最突出的功能,就是内部的双核Cortex-A9,所以从现在开始我将学习ZYNQ的SOC学习(PS部分) ...

  6. cocos2d-x 2.1.4学习笔记之HelloWorld分析

    下面截图是HelloWorld项目下的文件夹结构 这是用python命令生成的项目,在创建过程中默认生成多个平台的程序文件. 1.“resource”文件夹 该文件夹主要用于存放游戏中需要的图片.音频 ...

  7. Zynq学习笔记(1)

    做硬件的第一个实例,一般当然是LED点灯啦~ 硬件:ZedBoard 软件:ISE 14.7 1.新建工程 2.选择平台 3.新建完成后,输入如下代码: `timescale 1ns / 1ps // ...

  8. [原创] hadoop学习笔记:卸载和安装jdk

    一,卸载jdk 1.确定jdk版本 #rpm -qa  | grep jak 可能的结果: java-1.7.0-openjdk-1.7.0.75-2.5.4.2.el7_0.x86_64 java- ...

  9. [原创] hadoop学习笔记:hadoopWEB监控

    笔者安装单机版本 要想实现hadoopweb页面的监控,需要解决以下几个问题 1.关闭linux的防火墙:#service iptables stop 2.将linuxSE设置为disabled:#v ...

随机推荐

  1. 条形码Code128源代码

    public class Code128 { private DataTable m_Code128 = new DataTable(); ; /// <summary> /// 高度 / ...

  2. Class<Object>与Class<?>有何区别呢

    1.? 和 Object 差不多,不过还是有差别.在这种情况下: class<? extends SomeClass> , Object就不能用了 Object是一个具体的类名,而?是一个 ...

  3. php学习日志(2)-php变量

    变量是用于存储数据的容器,与代数相似,可以给变量赋予某个确定的值(例如:$x=3)或者是赋予其它的变量(例如:$x=$y+$z).变量的定义主要有以下规则: 变量以$开始,后面跟着变量的名称: 变量名 ...

  4. 35 个必须有的Bootstrap工具和生成器

    Bootstraptor If you think that bootstrap templates are not enough for you, you should go with bootst ...

  5. VLAN和Trunk

    Vlan实验题: 如图所示 解答过程 (一)相同vlan之间的设备全连通 1. 在SW1和SW2上分别创建vlan2和vlan3, 命令如下 SW1# vlan database SW1(vlan)# ...

  6. Spark Streaming揭秘 Day31 集群模式下SparkStreaming日志分析(续)

    Spark Streaming揭秘 Day31 集群模式下SparkStreaming日志分析(续) 今天延续昨天的内容,主要对为什么一个处理会分解成多个Job执行进行解析. 让我们跟踪下Job调用过 ...

  7. C语言socket编程--每日签到

    前几天写了个python的每日签到,你运行还得借助crontab,很是不爽.....正好前几天看了个关于c编写daemon进程,加上自己那点可怜的socket知识,于是我们重操旧页,C语言版的每日签到 ...

  8. Unix/Linux中shell调用sqlplus的方式

    Unix/Linux下,shell脚本调用sqlplus的几种方式介绍: 一.最简单的shell调用sqlplus #!/bin/bash sqlplus -S /nolog > sqlplus ...

  9. 第1章 Git的版本控制之道

    版本控制系统(Version Control System,VCS)可以帮助我们记录和跟踪项目中各文件内容的修改变化. 1.1 版本库 版本库(Repository)是版本控制系统用来存储所有历史数据 ...

  10. Delphi XE5 android popumenu

    实现下拉菜单式的效果,本代码是国外的网站上下载的..,不是原创. 源码下载地址 :  http://files.cnblogs.com/nywh2008/popumenu.rar