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

    文章

    3745

    浏览量

    215668
  • Zynq
    +关注

    关注

    9

    文章

    600

    浏览量

    46620
  • Ubuntu系统
    +关注

    关注

    0

    文章

    84

    浏览量

    3785

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

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

收藏 人收藏

    评论

    相关推荐

    dSPACE开发流程

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

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

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

    嵌入式软件的开发流程

    电子发烧友网站提供《嵌入式软件的开发流程.doc》资料免费下载
    发表于 11-17 14:39 0次下载
    嵌入式软件的<b class='flag-5'>开发</b><b class='flag-5'>流程</b>

    嵌入式软件开发流程

    电子发烧友网站提供《嵌入式软件开发流程.ppt》资料免费下载
    发表于 11-17 14:37 1次下载
    嵌入式软件<b class='flag-5'>开发</b><b class='flag-5'>流程</b>

    电路板开发的发展趋势和流程

    在计算机化的发展进程中,电路板开发流程几乎没有重大的改变,但是开发的产品特性已经有很大的不同,电路板开发工程师必须要面对这些挑战,设计开发
    的头像 发表于 10-15 12:07 925次阅读

    ZYNQ设计的基本流程

    ZYNQ内部的总体框架如所示,PS中包含2个ARM Cortex-9的内核,一些基本的外设扩展口以及Memory接口。PS和PL的相互通信通过两个通路完成,分别是GP(General Purpose)Ports和HP(High Performance)Ports。
    的头像 发表于 09-22 09:26 551次阅读
    <b class='flag-5'>ZYNQ</b>设计的基本<b class='flag-5'>流程</b>

    Zynq UltraScale+ MPSoC:软件开发者指南

    电子发烧友网站提供《Zynq UltraScale+ MPSoC:软件开发者指南.pdf》资料免费下载
    发表于 09-14 10:03 10次下载
    <b class='flag-5'>Zynq</b> UltraScale+ MPSoC:软件<b class='flag-5'>开发</b>者指南

    嵌入式HLS 案例开发步骤分享——基于Zynq-7010/20工业开发板(4)

    产品上市时间。 HLS 基本开发流程如下:(1) HLS 工程新建/工程导入(2) 编译与仿真(3) 综合(4) IP 核封装(5) IP 核测试测试板卡是基于创龙科技Xilinx Zynq
    发表于 08-24 14:54

    xilinx ZYNQ7000系列基本开发流程之PS端

    ZYNQ 芯片分为 PL 和 PS, PS 端的 IO 分配相对是固定的,不能任意分配,虽然 PS 端的 ARM 是硬核,但是在 ZYNQ 当中也要将 ARM 硬核添加到工程当中才能使用,FPGA
    的头像 发表于 08-11 09:36 5383次阅读
    xilinx <b class='flag-5'>ZYNQ</b>7000系列基本<b class='flag-5'>开发</b><b class='flag-5'>流程</b>之PS端

    浅谈硬件电路开发流程规范

    硬件电路开发流程是指导硬件工程师按规范化方式进行开发的准则,规范了硬件电路开发的全过程。
    的头像 发表于 08-03 10:31 774次阅读
    浅谈硬件电路<b class='flag-5'>开发</b><b class='flag-5'>流程</b>规范

    X-NUCLEO-GFX01M1开发板的GUI开发流程介绍

    电子发烧友网站提供《X-NUCLEO-GFX01M1开发板的GUI开发流程介绍.pdf》资料免费下载
    发表于 08-01 15:51 0次下载
    X-NUCLEO-GFX01M1<b class='flag-5'>开发</b>板的GUI<b class='flag-5'>开发</b><b class='flag-5'>流程</b>介绍

    聊聊MBD开发流程

    作为一个小的知识拓展,这里先给出常见的开发流程(或称为开发方法,Development Methodologies)
    的头像 发表于 07-13 09:20 1277次阅读
    聊聊MBD<b class='flag-5'>开发</b><b class='flag-5'>流程</b>

    FPGA的详细开发流程

      FPGA 的详细开发流程就是利用 EDA 开发工具对 FPGA 芯片进行开发的过程,所以 FPGA 芯片开发
    的头像 发表于 07-04 14:37 2750次阅读
    FPGA的详细<b class='flag-5'>开发</b><b class='flag-5'>流程</b>

    zynq开发中的设备树

    zynq开发中经常会修改设备树,每次遇到这种情况都有点发愁,今天把设备树相关的知识点总结一下,希望以后遇到设备树时,能够自如应对。
    的头像 发表于 05-25 11:29 1262次阅读
    <b class='flag-5'>zynq</b><b class='flag-5'>开发</b>中的设备树

    单片机方案开发流程,基于单片机的开发项目

    单片机的开发流程是一个有序的过程,通常包括以下几个关键步骤。请注意,下面的描述是一个一般化的单片机开发流程,并且在实际应用中可能会有一些差异。
    的头像 发表于 05-19 13:46 1220次阅读