MPSOC上PS和PL基于AXI-CDMA高速交互数据(linux)

2023-10-08 14:50

本文主要是介绍MPSOC上PS和PL基于AXI-CDMA高速交互数据(linux),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

                                                                       MPSOC上PS和PL基于AXI-CDMA高速交互数据(linux)

                                                                                                                                             alvin.lu@avnet.com

                                                                                                                                             2020.09.12

软件平台:
Vivado 2018.3
PetaLinux 2018.3
Ubuntu16.04.6真机

git地址 git@github.com:alvin-hao/cdma_training.git

硬件平台:
ZCU102 (ZynqMP)

 

一.MPSOC ps和pl通过cdma搬运ddr进行数据交互的核心思想比较简单,ps发指令,使能cdma,cdma把对应的数据从pl ddr搬运到ps ddr,搬运完成以中断的方式通知,其中软件设计的基础依据如下
CDMA寄存器的地址是0xA000_0000
CDMA能够操作PS的内存范围是0x0000_0000~0x7FFF_FFFF2GB
CDMA能够操作PL的内存范围是0x8000_0000~0x9FFF_FFFF512MB
1.petalinux的开发
基于附件bsp创建一个petalinux工程;
$ petalinux-create -t project -s cdma0930.bsp -n cdma
客户也可以基于xilinx官方的xilinx-v2018.2-zcu102.bsp创建一个工程然后用petalinux-config --get-hw-description=[SRC OF HDF]导入基于zcu102新的hdf工程
用命令
$ petalinux-build可以编译出ZCU102 linux启动需要的所有镜像文件
关于linux的bootargs的设置,需要设置linux能主动访问的ddr空间为0-1G,1-2G的空间用来与cdma共享,这里的range客户可以手动调节,但是一定需要留足够的空间给cdma搬运数据
我的设置如下
        chosen {
                bootargs = "earlycon console=ttyPS0,115200 clk_ignore_unused cma=128M devtmpfs.mount=1 uio_pdrv_genirq.of_id=generic-uio mem=1024M";
                stdout-path = "serial0:115200n8";
        };
编译完成后,用petalinux-packahe命令打包
$ petalinux-package --boot --fsbl zynqmp_fsbl.elf --fpga system.bit--u-boot --pmufw pmufw.elf --force
生成BOOT.BIN文件
然后把boot.bin和image.ub放到sd卡启动即可。
2.测试
第一步,把1.jpg从sd卡读取到ddr 0x4000 0000,然后用cdma把数据搬运到0x8000 0000
第二步,用cdma把0x8000 0000数据搬运到0x5000 0000,搬运的次数在第一步打印出来
第三步,用md5检验两个文件,是不是一致,一致则搬运成功

读写速度应该是超过1500MB/s了.

这篇关于MPSOC上PS和PL基于AXI-CDMA高速交互数据(linux)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/166060

相关文章

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt