搜索
查看
编辑修改
首页
UNITY
NODEJS
PYTHON
AI
GIT
PHP
GO
CEF3
JAVA
HTML
CSS
搜索
凡人多烦事01
这个屌丝很懒,什么也没留下!
关注作者
热门标签
jquery
HTML
CSS
PHP
ASP
PYTHON
GO
AI
C
C++
C#
PHOTOSHOP
UNITY
iOS
android
vue
xml
爬虫
SEO
LINUX
WINDOWS
JAVA
MFC
CEF3
CAD
NODEJS
GIT
Pyppeteer
article
热门文章
1
Unity2D教程:单例模式、SceneManager.LoadSceneAsync场景切换、Loading界面进度条
2
mysql undo表空间_MySQL UNDO表空间独立和截断
3
Chatgpt这么智能,以后会不会取代掉人类?_chatgpt是否会代替人类的大脑
4
计算机设计大赛 深度学习人体语义分割在弹幕防遮挡上的实现 - python
5
windows7装python哪个版本好,win7安装哪个版本的python_pycharm win7适配版本
6
UE4蓝图基础入门(一)变量与蓝图_ue setmenbersin
7
ChatGPT-4和ChatGPT-3.5知识库截止日期竟然一样?_gpt4数据库截止日期
8
Unity——InputSystem入门及部分问题讲解_unity inputsystem
9
python库turtle的双画笔并发绘制兔兔 表白神器_pythonturtle画小白兔
10
Rabbitmq学习之路3-cluster_rabbitmqctl join_cluster --ram
当前位置:
article
> 正文
基于ZYNQ 的多轴运动控制平台关键技术研发-总体架构设计(一)_zynq7020 的dsp 资源
作者:凡人多烦事01 | 2024-03-01 08:53:04
赞
踩
zynq7020 的dsp 资源
基于多轴运动控制平台的实时通信和同步控制需求,采用
Xilinx Zynq 7020 SoC
作为核心处理器,设计了双核
SoC
多轴运动控制平台的总体架构。结合多轴运动控
制系统与接口特征,完成了
SoC
运动控制平台的硬件设计,主要包括
SoC
最小系统
和
Ethernet
、
USB
、
UART
等主流通信接口设计。
基于运动控制的功能完整性需求,设计了
Linux+Xenomai
实时操作系统和伺服
裸机系统组成的
SOC
双核系统。在
Linux
系统下,完成了平台通信设备的驱动移植。
本章分析机器人多轴运动控制平台的使用需求,提出基于双核
SoC
的多轴运动
控制平台设计方案,并进一步完成运动控制平台的总体硬件架构设计和双核系统间
任务通信策略设计。
2.1
多轴运动控制平台设计分析
如图
2.1
所示,工业总线型运动控制系统采用分离式的系统结构。运动控制系统
由上位机、控制器、多个伺服驱动器,以及伺服电机等部件组成。分离式运动控制系
统的主要特点为:主从站间通过现场总线进行连接通信;多从站之间串联通信,通过
总线协议的同步功能保证多从站的协同控制。
本文设计一种基于多核
SoC
的集成式多轴运动控制平台,实现控制器与多个驱
动器的硬件集成,结构如图
2.2
所示。集成式运动控制平台的主要特点为:使用片内
总线实现控制系统和驱动系统的高速互联通信,保证了信息传输的高效性和稳定性;
使用统一的伺服控制系统完成多轴的伺服功能控制,多轴间信息的可快速交互,有效
保证了多轴的同步控制。其中,运动控制系统与上位机连接,完成运动轨迹规划和运
动指令生成,并与伺服系统进行数据通信;伺服驱动系统对控制系统指令进行响应,
通过三环(位置、速度和电流)控制实现多轴同步运动。
根据上述的分析,多核
SoC
运动控制平台设计需要考虑如下需求:
(
1
)如何高效利用多核
SoC
资源,分别实现平台的控制系统和高性能伺服驱动
系统;
(2)如何利用片内总线接口,实现控制系统和伺服驱动系统的高效通信;
(3)如何设计
SoC
系统通信时序,完成多轴运动数据的同步处理和同步控制;
(4)如何利用
SoC
外设资源,完成平台接口设计,实现对外通信与驱动功能;
同时,双系统集成设计还需要考虑如下需求:
(
1
)如何设计强实时操作系统,实现运动控制任务的实时处理;
(2)如何在
AMP
架构下设计伺服驱动系统,实现伺服系统的稳定运行;
(3)如何在
AMP
架构下设计双系统间通信机制,实现系统的多任务通信,包
括用于指令
/
反馈数据交互的周期性任务和用于系统参数等数据交互的非周期性任务。
2.2.1 SoC
芯片选型与说明
基于集成式运动控制平台的使用需求,需选用一款集成高性能处理器的多核
SoC
芯片。同时,芯片选取时,需要对芯片功能的完整性、市场应用范围、生命周期、使
用成本以及芯片功耗等多方面进行评估。根据综合评估,选择
Xilinx
公司的
Zynq
7020
作为多轴运动控制平台的
SoC
中央处理器。
Zynq 7020
是一款高度集成的
SoC
处理器芯片,其系统内部互联结构如图
2.3
所
示。
Zynq 7020
片内集成双核
ARM Cortex-A9 MPCore
处理系统(
Processing System
,
简称
PS
)和高达
85k
的可编程逻辑单元(
Programmable logic
,简称
PL
)。
PS
的主要
特点有:
(
1
)
PS
具有两个
Cortex-A9
处理器核,可进行双核系统设计;
(2)集成
DDR
、
SDIO
、千兆以太网、
USB 2.0
、
UART
等多种设备控制器,可
实现
SoC
最小系统功能,并进行主流的通信接口设计;
(3)片内支持
AMBA AXI4
高速总线接口,可实现系统单元间的高速通信。
(4)集成
256K
的片上
RAM
(
On Chip Memory
,简称
OCM
),可用系统共享数
据的保存;
(5)每个处理器核独自拥有
32KB
的
1
级缓存(简称
L1 Cache
),并且共享
512KB
的
2
级缓存(简称
L2 Cache
),提高了
CPU
的数据访问速度,进一步提升了
系统性能;
同时,
PL
采用
28nm
可编程逻辑单元,保证了芯片的低功耗和低成本;丰富的
逻辑单元和
DSP
资源可用于实现多种应用功能;提供
125
到
200
的
IO
引脚选择方
案,可方便实现
IO
控制;
Xilinx
提供大量的第三方
IP
核模块支持,方便用户进行
使用,可有效减少开发周期。因此,
Zynq 7020
芯片可以满足本方案的开发需求。
2.2.1
平台架构设计与功能说明
基于功能需求,本文设计了基于
Zynq 7020
双核
SoC
的多轴运动控制平台架构。
如图
2.4
所示,多轴运动控制平台主要由
SoC
最小系统和平台接口两部分组成,可
实现四轴的同步运动控制。
其中,
SoC
最小系统由处理器
0
、处理器
1
和
FPGA
组成,各部分具体功能如
下:
(
1
)处理器
0
(
CPU0
)搭载实时操作系统。具体功能为:运行机器人控制软件,
完成运动规划和指令生成;通过系统通信接口,实现与伺服系统的多任务通信,完成
数据交互;管理
SoC
外设资源,提供外设驱动支持,实现与外部设备的连接通信。
(2)处理器
1
(
CPU1
)搭载运行伺服裸机系统。具体功能为:运行伺服控制软
件,完成四轴的三环控制;通过系统通信接口,实现与操作系统的多任务通信,完成
数据交互;管理
SoC
外设,实现外部设备的连接和信号的采集。
(3)
FPGA
中实现自定义功能模块。具体功能为:设计硬件中断发生器,为处
理器
0
和处理器
1
提供固定周期的中断信号,用于实现双核系统间多任务通信。同
时,
FPGA
中还包含
PWM
生成器、电流采样、编码器解析等多轴驱动模块。
同时,多轴运动平台接口分为通信接口和系统接口。其中通信接口主要为:
RS232
串口,用于控制平台的系统开发和测试,以及系统后期维护;
USB 2.0
接口,用于连
接外部键盘、鼠标和
U
盘等设备,方便用户操作,并且可实现系统在线升级;千兆
以太网接口,用于平台连接手持盒或
PC
机,实现上位机通信;工业以太网接口,用
于连接外部伺服驱动器或工业摄像头等设备,实现平台功能扩展。系统接口用于完成
四轴的伺服驱动、系统监控和
IO
控制等功能。
根据
SoC
平台的功能需求,本文主要进行如下关键技术的开发和设计:
(
1
)
SoC
硬件系统设计,包括
SoC
最小系统设计、资源分配和通信时序设计;
(2)平台通信接口技术研发,包括
UART
、
USB
和千兆以太网接口设计;
(3)
AMP
双系统设计,包括实时操作系统和伺服裸机系统的设计与实现;
(4)双核间多任务通信技术研发,包括通信模块设计和多任务通信机制设计。
同时,本文对平台的实时性和同步性进行研究和设计,实现系统的实时通信与多
轴同步控制功能。
2.3
双核系统多任务实现策略
本文采用
AMP
双核系统设计,分别为
CPU0
操作系统和
CPU1
伺服裸机系统,
双核间采用片内共享内存
OCM
进行数据交互。
2.3.1
嵌入式操作系统的选型
CPU0
操作系统主要用于运行机器人控制软件,需要快速完成轨迹规划并将指令
及时下发,实现多轴实时运动控制。同时,操作系统需要提供通用外设的驱动支持,
方便用户开发,减少开发难度。
因此,适用于本平台设计的的操作系统应该具有实时处理能力、良好的设备驱动
支持、易开发、成本低等特点,同时进一步考虑系统的开放性、人机界面功能和可靠
性等方面问题。在选型过程中,保证所选系统能够满足设计要求,同时达到简化开发
流程,降低系统开发难度和使用成本的目标。现在流行的嵌入式实时操作系统主要有
uC/OS-II
、
Linux+Xenomai
、
Wince
和
VxWorks
,表
2.1
对四种操作系统进行比较分析。
其中,
Vxworks
和
Wince
具有很强的实时性,但是其源码不对外开放,因此开
发难度无法预测,可能产生后续跨平台系统移植问题,系统在使用时需要支付许可费
用。
µC/OS-II
系统开源免费、可以提供系统实时性功能,但是无法满足人机界面的
使用要求,不方便产品后续升级。
Linux+Xenomai
操作系统,
Linux
系统在
Xenomai
实时拓展后可以提供实时性功能,同时系统具有软件开源、可移植性强,可提供人机
界面等等优点。综合考虑,选用
Linux+Xenomai
实时操作操作系统。
2.3.2
系统多任务实现策略设计
本文采用基于共享内存
OCM
的通信方案,实现运动控制平台双核系统间的任务
通信,任务通信的实现过程如图
2.5
所示。
在
CPU0
的
Linux
实时操作系统上,运行机器人控制软件,建立
Xenomai
实时
运动任务。在多轴运动控制中,双核系统间需要进行周期通信和非周期通信的两类任
务,通过服务函数实现具体通信。其中,周期任务完成固定周期的控制指令下发和反
馈读取,非周期任务完成包括伺服参数读写与系统命令下发等操作。在服务函数中,
通过系统调用提供
OCM
访问服务,实现数据的交互
CPU1
搭建伺服裸机系统,用于伺服控制应用程序的直接加载和运行。应用程序
中提供任务通信函数,用于系统间的任务通信。在任务通信函数中,通过调用
Xilinx
官方提供的
API
接口,实现对共享内存
OCM
的数据访问。
同时,
PS
与
PL
之间通过
AXI4
高速总线进行互联通信。
Xilinx
提供
PL
外设内
存映射机制,可将
PL
的功能模块映射到
PS
系统内存空间中,进而实现
PS
系统对
PL
模块的数据访问
。
信迈提供
ZYNQ
+运动控制器的软硬件方案。
声明:
本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:
https://www.wpsshop.cn/w/凡人多烦事01/article/detail/172438
推荐阅读
article
xilinx
zynq
+
vitis
实现命令行编译输出
xsa
以及
bin
文件_
xsa
tcl
bin
区别...
6.导出
xsa
文件给软件同事,指令为:write_hw_platform -fixed -include_bit -fo...
赞
踩
article
【
ZYNQ
】
Petalinux
编译
工程
报错_
petalinux
清除
编译
工程
...
Petalinux
编译
工程
报错_
petalinux
清除
编译
工程
petalinux
清除
编译
工程
...
赞
踩
article
zynq
Starting
kernel
挂起
的
问题_
zynq
petalinux
启动卡在 sta...
项目场景:提示:这里简述项目相关背景:例如:项目场景:示例:通过蓝牙芯片(HC-05)与手机 APP 通信,每隔 5s ...
赞
踩
article
ZYNQ
-
linux
-Peta
linux
设计流程-点灯_
system
-
user
.
dtsi
...
笔记:设置 Peta
linux
环境变量在 Ubuntu 系统中需要先设置 peta
linux
工作环境,也就是对 pe...
赞
踩
article
ZYNQ
飞控的设计-基本
开发
环境
搭建_
windows
zynq
liunx
开发
环境
...
ZYNQ
-LINUX系统
开发
过程前言一、
开发
环境
搭建1.Ubuntu 和 和 Windows 文件互传1. 开启 U U...
赞
踩
article
zynq
FPGA
的
双目
视觉
毕业设计
(八)之
FPGA
最终实现_
fpga
研究生毕设...
简述经过不懈的努力,最终成功完成
双目
。在家做毕设是真的酸爽,没有在学校有动力,也没有再实验室方便,但是这样更加锻炼自己的...
赞
踩
article
基于
Xilinx
FPGA
Zynq7020
(
XA7Z020
-
1CLG484Q
)的
ADAS
深度
学习...
主芯片型号:
XA7Z020
-
1CLG484Q
计算性能:峰值计算性能2.6GOPS (
FPGA
) + 3335DMIPS...
赞
踩
article
ZYNQ
飞
控系统
设计-
PX
的
MAalefile
解读_
nuttx
zynq
...
下面展示一些 内联代码片。###############################################...
赞
踩
相关标签
fpga开发
FPGA/SoC
linux
ubuntu
运维
毕业设计
双目视觉
XA7Z020
XILINX
ZYNQ7020
无人驾驶
深度学习