前言

本文简要介绍在vivado中创建PS工程。单纯使用zynq芯片的PS部分就像使用普通ARM芯片一样,只是多了建立Zynq硬件系统这一个步骤。vivado创建PL工程参见此处

新建工程

vivado 创建FPGA工程相同

建立Zynq硬件系统

新建块设计

添加zynq处理器IP核

自动配置

添加一个GPIO IP核,同样自动配置,然后在空白处右击选择Regenerate Layout,重新布局

可以将GPIO核改名为LED,核的端口也改为LED

配置

双击zynq核进行配置,此处不需要配置

双击GPIO核,将端口设为输出,因为vivado有ZedBoard的信息,所以不用自己配置IP configuration

新建约束文件

生成顶层文件

先右击system → Generate Output Products → Generate

再右击system → Create HDL Wrapper → OK

Vivado会为IP子系统生成一个顶层文件,以便对该系统进行综合、实现并生成比特流

生成比特流

工程配置完成,点击左下侧Generate Bitstream生成比特流,点击Yes。若没有其他错误,比特流生成完成。

外设地址

硬件工程设计好之后,可在以下窗口中看到系统分配给外设的地址

将硬件工程导出到SDK

VIVADO -> File → Export Hardware 导出硬件到SDK,打钩,包括比特流,点击OK



新建软件工程



注意点next选择empty application



新建.c源文件

录入代码

//点亮灯,需要流水灯代码请自行修改
#include "xparameters.h"
#include"xgpio.h"
#define LED_CHANNEL 1
XGpio GpioOutput;
int main()
{
XGpio_Initialize(&GpioOutput,XPAR_LED_DEVICE_ID);
XGpio_SetDataDirection(&GpioOutput,LED_CHANNEL,0x0);
while (1)
{
XGpio_DiscreteWrite(&GpioOutput,LED_CHANNEL,0xFF);//点亮全部LED灯
}
}

下载

回到Vivado,program device

再到SDK,运行

效果

说明

bsp是与硬件配置有关的板级支持包,可以方便调用bsp包内的函数实现对外设的控制,而不用关心底层驱动实现。

.elf文件是生成的可执行文件

关于处理器系统

Zynq搭载的是一颗双核ARM-Cortex-A9处理器,是一颗“硬”处理器,而Xilinx MicroBlaze是由可编程逻辑组成的“软”处理器,MicroBlaze也可以在Zynq芯片上实现



上图绿框是应用处理单元(APU),包含两个ARM核等处理资源。NEON引擎实现了单指令多数据功能来实现DSP类算法的加速,NEON指令是对ARM指令集的扩展,可以直接使用。浮点扩展(FPU)则实现了浮点运算的硬件加速

zynq的GPIO

zynq的GPIO实现方式有三种:MIO、EMIO、AXI_GPIO。PS通过这三种GPIO和外部接口通信。上面例子点亮LED灯使用的是AXI_GPIO,是一个IP核,消耗PL逻辑资源和PL管脚资源,挂载在AXI总线上,通过AXI总线地址访问。MIO直接和PS相连接,不消耗PL资源,共有54个。EMIO接口位于PS和PL之间,连接到PL的管脚时不消耗PL逻辑资源,连接到PL实现的外设时不消耗PL的逻辑资源也不消耗PL的管脚资源。

vivado 创建PS工程的更多相关文章

  1. vivado 创建PL工程

    参考来源 https://china.xilinx.com/video/hardware/i-and-o-planning-overview.html 前言 我Win10系统上的Xilinx Plat ...

  2. Vivado SDK 2014.2 创建新工程后,BSP版本不对的解决办法

    问题描述如下: 1. 使用Vivado SDK 2014.2已经创建了工程,但是此时,hdf文件增加了外设,需要重新创建工程以更新SDK中的外设描述: 2. 使用新的hdf创建工程后,发现system ...

  3. 在VS2015 RC打开CTP中创建的工程

    VS2015终于出了RC了!小伙伴们快来安装试用吧,地址在这里,还有新的Windows 10开发工具哦,要不然是开发不了Universal Windows App的,安装前记得卸载CTP版本. 新的R ...

  4. 三、使用maven创建scala工程(scala和java混一起)

    本文先叙述如何配置eclipse中maven+scala的开发环境,之后,叙述如何实现spark的本地运行.最后,成功运行scala编写的spark程序. 刚开始我的eclipse+maven环境是配 ...

  5. 什么是maven与maven的使用过程(例如在idea创建maven工程(重点讲讲idea创建使用maven管理的web工程,并且部署到tomcat上))

    什么是maven与maven的使用过程(例如在idea创建maven工程) (重点讲讲idea创建使用maven管理的web工程项目,并且部署到tomcat服务器上) 一.什么是maven? 1, M ...

  6. Eclipse创建Maven工程报错

    问题 用Eclipse创建maven工程的时候,总是会报错,例如提示: Unable to create project from archetype [org.apache.maven.archet ...

  7. MyEclipse创建Maven工程

    先要在MyEclipse中对Maven进行设置:

  8. 关于Xcode6创建的工程在Xcode5打开

    Xcode6创建的工程在Xcode5打开- 4.0只显示3.5大小的问题 只需要在工程里添加Default-568h@2x.png,即可以解决

  9. windows下无法创建django工程的问题

    环境:python2.7  django1.7 安装好django后,将C:\Python27\Lib\site-packages\Django-1.7.7-py2.7.egg\django\bin; ...

随机推荐

  1. 七牛免费SSL证书申请全流程

    购买证书 在七牛ssl 首页点击购买 购买限免证书 补全订单信息 免费证书,随意填写,问题不大 购买成功,查看订单详情,获取 TXT 值信息 添加 DNS TXT 验证 根据上一步,查看证书订单详情, ...

  2. 24、设计模式、webpack

    利用静态属性:长驻内存 (一) 单例模式 概念:单个实例,只有一个对象,多次创建,返回同一个对象. 单例模式的核心:==确保只有一个实例==,并提供全局访问. //利用了静态属性:长驻内存 funct ...

  3. Tanya and Candies

    Tanya and Candies time limit per test 1 second memory limit per test 256 megabytes input standard in ...

  4. 关于histry的pushstate 和 popstate事件的应用

    这篇文章是基础:http://www.cnblogs.com/kaituorensheng/p/3776527.html: histry的单页面应用有两个写法:哈希值和?: 哈希值例子: 实现效果:点 ...

  5. linux 远程连接ssh提示IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY解决

    @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ WARNING: REMOTE HOST IDENTIFICATION HA ...

  6. 最全的MonkeyRunner自动化测试从入门到精通(3)

    一.eclipse的下载安装与配置成安卓开发环境 步骤一:在官网上面进行下载eclipse,官网的网址:https://www.eclipse.org/downloads/ 步骤二:下载完成后可以在你 ...

  7. Java如何获取图片验证码保存

    举例网站:https://my.1hai.cn/Login/?url=http://www.1hai.cn/ 一.场景:出于安全性考虑,越来越多的Web平台登录都会增加图形验证码(图片),或者短信验证 ...

  8. 深入浅出Vue基于“依赖收集”的响应式原理(转)

    add by zhj: 文章写的很通俗易懂,明白了Object.defineProperty的用法 原文:https://zhuanlan.zhihu.com/p/29318017 每当问到VueJS ...

  9. AsyncHttpClient使用

    github地址:AsyncHttpClient, API:API 1.X和2.X差别很大,我用的1.X中的最新版 1.9.39. 这是一个异步请求的工具,越简单越好,不喜欢再结合netty使用.As ...

  10. 希尔排序(Python实现)

    目录 1.for版本--希尔排序 2. while版本--希尔排序 3. 测试用例 4. 算法时间复杂度分析 1.for版本--希尔排序 def shell_sort_for(a_list): ''' ...