0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

ZYNQ的开发流程

工程师邓生 来源:CSDN 作者:姚家湾 2022-09-15 09:04 次阅读

买了一块ZYNQ 开发板Z7-NANO,开始了ZYNQ开发的苦难之旅。尽管按照厂商提供的开箱检查指南,将image 拷贝到sd卡上插入板上后板子工作起来了。但是如何开发应用软件呢?这一步要比平常的SOC麻烦了许多。

安装软件

网络上有许多的文章介绍应用软件的开发,但是大多数使用的是旧版本的vivado和SDK 软件。开发板提供的文档和软件也大多是基于旧版软件的,但是官网上已经使用的软件是vivado和vitis了,前者开发硬件,后者开发软件。

下载软件使用 Xilinx Unified Installer 2021.2。通过它下载vivado和vitis。安装软件需要足够的磁盘空间和耐心。vitis 软件包大约有60个G左右。vitis 中包括了vivado 软件。只需要下载vitis就可以了,不必单独地下载vivado。

vivado用来开发硬件,vitis 开发软件,相当于原来的SDK。

由于手头没有大硬盘空间的ubuntu Linux 电脑,又不想去做VM。先安装在windows10 的笔记本上了。网络上建议安装在ubuntu 上。

ZYNQ 的开发流程

ZYNQ 的开发要比其它的SOC开发复杂的多。大至的流程包括:

34995cce-348e-11ed-ba43-dac502259ad0.pngimg

ZYNQ的开发包括

1 硬件逻辑设计

硬件工程师设计逻辑并将软件开发所需的信息从Vivado导出到 XSA 存档文件。

2 构建软件平台

平台(platform)

平台是硬件组件 (XSA) 和软件组件(域/BSP、FSBL 等引导组件等)的组合。

领域(domain)

一个平台上可以建立多个领域。领域是一个板级支持包 (BSP) 或操作系统 (OS),其中包含用于构建应用程序的软件驱动程序集合。例如LinuxDomain。可以创建多个应用程序以在域上运行。领域与平台中的单个处理器或同构处理器集群。比如在一个核上运行Linux,或者在两个核的集群上运行Linux。

建立领域的基础是支持包和操作系统。Zynq 的Linux 称为PetaLinux。PetaLinux 的裁剪需要使用Petalinux 构建工具。

Petalinux是Xilinx公司推出的嵌入式Linux开发套件,包括了Linux Kernel、u-boot、device-tree、rootfs等源码、库,以及Yocto recipes,可以让客户很方便的生成、配置、编译及自定义。Petalinux支持Zynq UltraScale+ MPSoC、Zynq-7000全可编程SoC,以及MicroBlaze,可与Xilinx硬件设计工具Vivado协同工作,大大简化了Linux系统的开发工作。

在vitis 软件中,包含Xilinx开发的多个开发板的硬件xsa。并且能够建立相应的LinuxDomain。

3 应用程序开发

软件开发人员基于平台和领域创建应用程序。

在已有的平台上开发应用程序

网络上有许多ZYNQ 应用程序开发的文档和教程,但是它们大多数使用的2018 年前的vivado 和SDK 的。几乎没有使用vitis 开发。而国内的ZYNQ开发板目前还没有提供支持vitis 平台的软件包。

网络上关于ZYNQ 开发的介绍文章都比较复杂,大多数从vivado 硬件设计开始,再谈petaLinux,再谈到vitis 的使用。

其实没有那么复杂。 最方便地方法就是在vitis 软件中支持xilinx 开发板的platefrom 构建应用程序,这些开发板包括:

zc702 基于Zynq XC7Z020-1CLG484C。

zc706 基于XC7Z045,PCI插卡结构

zcu102 Zynq? UltraScale+? MPSoC ,四核 ARM? Cortex?-A53、双核 Cortex-R5F 实时处理器以及一款 Mali?-400 MP2 图像处理单元。

zcu106 基于Zynq UltraScale+MPSoC。

zedBoard 基于Zynq-7000 SoC XC7Z020-CLG484-1。由安富利公司开发的低成本开发板。

开发的过程

vitis –New->Create Application Project

34ce4f7e-348e-11ed-ba43-dac502259ad0.png

点击Next。

352676a4-348e-11ed-ba43-dac502259ad0.png

选择zc702 平台,点击Next。

填入Application Project Nam。例如LinuxApp4

356d707c-348e-11ed-ba43-dac502259ad0.png

Z7020 系列ZYNQ 是双核cortex-A9 .

领域可以建立在单核上也可以建立在双核上,也可以是一个为linux,一个为freeRTOS 上。非常灵活,在这里我们选择ps7_cortexa9_SMP。双核linux。

按Next

35978204-348e-11ed-ba43-dac502259ad0.pngimg

在这一步我以为要填入红框内的内容,下载了 common image,并且生成了Sysroot

xilinx-zynqmp-common-v2021.2

导入到项目中,结果发现编译通不过,缺少-lstdC++,等等问题。后来发现,z702 平台包中已经包含了Sysroot 的SDK内容。不需要填入任何东西就可以编译成功。

按Next

35d1fb6e-348e-11ed-ba43-dac502259ad0.png

选择Linux Hello World!

生成了一个简单的hello world c程序

#include



intmain(){



printf("Helloworld
");



}

选择 Project-> Build Project .经过很长的一段时间。终于编译成功了。但是没法形成SD image。

copy 到我的Z7_Nano 开发板的SD Card 上。插入到目标板,运行Linux。输入

$>mkdirsdcard



$>mount/dev/mmcblk0sdcard



$>cdsdcard



$>./main.elf



Helloworld!



$>

为了测试其它库的调用,编写了一个UDP Client 程序,同样编译成功了

//ClientsideimplementationofUDPclient-servermodel



#include



#include



#include



#include



#include



#include



#include



#include







#definePORT8080



#defineMAXLINE1024







//Drivercode



intmain(){



intsockfd;



charbuffer[MAXLINE];



char*hello="Hellofromclient";



structsockaddr_inservaddr;







//Creatingsocketfiledescriptor



if((sockfd=socket(AF_INET,SOCK_DGRAM,0))< 0 ) {



  perror("socket creation failed");



  exit(EXIT_FAILURE);



 }



 



 memset(&servaddr, 0, sizeof(servaddr));



 



 // Filling server information



 servaddr.sin_family = AF_INET;



 servaddr.sin_port = htons(PORT);



 servaddr.sin_addr.s_addr = INADDR_ANY;



 



 int n, len;



 



 sendto(sockfd, (const char *)hello, strlen(hello),



  MSG_CONFIRM, (const struct sockaddr *) &servaddr,



   sizeof(servaddr));



 printf("Hello message sent.
");



 



 n = recvfrom(sockfd, (char *)buffer, MAXLINE,MSG_WAITALL, (struct sockaddr *) &servaddr,(socklen_t *)&len);



 buffer[n] = '�';



 printf("Server : %s
", buffer);



 



 close(sockfd);



 return 0;



}

为了测试C++ 程序,编写了

#include



usingnamespacestd;



classhello{



public:



voidSayHello();



};



voidhello::SayHello()



{



cout<<"Hello world"<

也通过了编译。

结束语

ZYNQ 要比普通的SOC 芯片复杂很多,国产开发板的技术支持相对滞后。给初学者带来不小的困难。



审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • soc
    soc
    +关注

    关注

    38

    文章

    4165

    浏览量

    218265
  • Zynq
    +关注

    关注

    10

    文章

    609

    浏览量

    47181
  • Ubuntu系统
    +关注

    关注

    0

    文章

    91

    浏览量

    3940

原文标题:zynq /vitis 应用笔记

文章出处:【微信号:ZYNQ,微信公众号:ZYNQ】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    基于Xilinx ZYNQ7000 FPGA嵌入式开发实战指南

    电子发烧友网站提供《基于Xilinx ZYNQ7000 FPGA嵌入式开发实战指南.pdf》资料免费下载
    发表于 12-10 15:31 2次下载

    ZYNQ 7035/7045开发板原理图

    ZYNQ 7035/7045开发板原理图
    发表于 12-05 13:46 0次下载

    如何编制有源医疗器械设计开发流程

    建立医疗器械质量体系,研发需要编写《设计开发控制程序》,参考YY/T 0287医疗器械质量管理体系用于法规的要求的标准,结合自己公司的流程,进行修改。
    发表于 11-12 15:48

    MCU开发流程中的注意事项

    微控制器单元(MCU)是现代电子系统中不可或缺的核心组件,广泛应用于各种嵌入式系统和物联网设备中。MCU开发流程涉及多个阶段,从需求分析到最终产品的测试和部署。在这个过程中,开发者需要注意许多关键点
    的头像 发表于 11-01 13:52 224次阅读

    Arm推出GitHub平台AI工具,简化开发者AI应用开发部署流程

    软件提供了无缝的开发体验。 GitHub Actions、原生 GitHub 运行器和基于 Arm 平台的 AI 框架相结合,帮助全球 2,000 万开发者简化 AI 应用开发部署流程
    的头像 发表于 10-31 18:51 2112次阅读

    ZYNQ核心板学习笔记

    此款开发板使用的是 Xilinx 公司的 Zynq7000 系列的芯片,型号为 XC7Z020-2CLG484I,484 个引脚的 FBGA 封装。
    的头像 发表于 10-24 18:08 773次阅读
    <b class='flag-5'>ZYNQ</b>核心板学习笔记

    Xilinx ZYNQ 7000系列SoC的功能特性

    本文介绍下Xilinx ZYNQ 7000系列SoC的功能特性、资源特性、封装兼容性以及如何订购器件。
    的头像 发表于 10-24 15:04 732次阅读
    Xilinx <b class='flag-5'>ZYNQ</b> 7000系列SoC的功能特性

    电机控制方案开发流程

    电机控制应用广泛,电机控制软件方案核心是MCU,功率器件、驱动器件;本文介绍电机控制方案开发流程与需要解决的问题。
    的头像 发表于 10-12 16:36 917次阅读
    电机控制方案<b class='flag-5'>开发</b><b class='flag-5'>流程</b>

    正点原子ZYNQ7015开发板!ZYNQ 7000系列、双核ARM、PCIe2.0、SFPX2,性能强悍,资料丰富!

    本帖最后由 jf_85110202 于 2024-9-14 10:33 编辑 正点原子ZYNQ7015开发板!ZYNQ 7000系列、双核ARM、PCIe2.0、SFPX2,性能强悍,资料丰富
    发表于 09-14 10:12

    [XILINX] 正点原子ZYNQ7035/7045/7100开发板发布、ZYNQ 7000系列、双核ARM、PCIe2.0、SFPX2!

    正点原子FPGA新品ZYNQ7035/7045/7100开发板,ZYNQ 7000系列、双核ARM、PCIe2.0、SFPX2! 正点原子Z100 ZYNQ
    发表于 09-02 17:18

    迪文串口屏ModBus开发流程

    这里接前一章节,继续迪文屏的开发,前章主要讲解基础开发流程,此章节开始讲解迪文ModBus协议栈的使用方法。前文指路:《迪文串口屏基础GUI开发流程
    的头像 发表于 07-19 08:21 507次阅读
    迪文串口屏ModBus<b class='flag-5'>开发</b><b class='flag-5'>流程</b>

    Xilinx ZYNQ 动手实操演练

    powerpc练手和教学,从头搭一个Snoop协议在裸的双PowerPC中,倒也不错。 开发环境 Zynq开发环境,可以在ISE或者Vivado,不过ISE在14.7之后就停止了更新,建议安装
    发表于 05-03 19:28

    没用过zynq今天在看解析是发现汽车的CID上有用这个,不知道zynq有什么优势?

    没用过zynq今天在看解析是发现汽车的CID上有用这个,不知道zynq有什么优势?
    发表于 04-23 15:01

    dSPACE开发流程

    电子发烧友网站提供《dSPACE开发流程.pdf》资料免费下载
    发表于 02-29 09:08 0次下载

    芯科科技发布新版蓝牙开发流程

    查看Silicon Labs(亦称“芯科科技”)近日发布新版的蓝牙开发流程(Bluetooth Developer Journey),了解更多关于低功耗蓝牙、蓝牙Mesh、蓝牙定位服务,以及电子货架标签(ESL)等设计方法,我们将概述相关应用
    的头像 发表于 01-25 10:09 776次阅读
    芯科科技发布新版蓝牙<b class='flag-5'>开发</b><b class='flag-5'>流程</b>