ZYNQ7000 pl330DMA vs CPU读DDR速率分析

单核freeRtos环境:

Zynq7045芯片平台,core0单核freeRtos系统。此环境不需要特殊修改,自带的两个demo均可跑过。
在freertos的bsp中的描述文件system.mss可找到如下的两个相关demo。
在这里插入图片描述
根据帧长的不同,通过CPU读和PL330MDA读两个不同方式,做了如下验证:
在这里插入图片描述

linxu+freeRtos AMP双核环境:

首先解决DMA在AMP环境下无法正常运行的问题:
问题现象:通过DMA搬运数据时,数据概率性搬运成功。
问题分析:首先排除了中断相关的配置,中断配置与单核环境一致,排除此原因;
查看DMA搬运数据的过程中发现有L2cache相关的操作,由于SCU不能保证L2cache的同步性,在DMA传输时需要软件保证数据的一致性。而在amp环境下core1 freertos BSP定义了-DUSE_AMP=1 ,此定义导致了操作L2cache的接口无效。做了如下代码中的修改,DMA终于可以成功搬运数据了。

涉及的代码及两个接口的区别:

int XDmaPs_Start(XDmaPs *InstPtr, unsigned int Channel,
		  XDmaPs_Cmd *Cmd,
		  int HoldDmaProg)
 {
 ......
    if (Cmd->ChanCtrl.SrcInc && XDmaPs_IsCacheable(Cmd->BD.SrcAddr)) {
    	//Xil_DCacheFlushRange(Cmd->BD.SrcAddr, Cmd->BD.DstLength); 替换为重新封装的接口
    	Xil_DCacheFlushRange_OpenAMP(Cmd->BD.SrcAddr, Cmd->BD.DstLength);
    }
    if (Cmd->ChanCtrl.DstInc && XDmaPs_IsCacheable(Cmd->BD.DstAddr)) {
    	//Xil_DCacheInvalidateRange(Cmd->BD.DstAddr, Cmd->BD.DstLength);
    	Xil_DCacheInvalidateRange_OpenAMP(Cmd->BD.DstAddr, Cmd->BD.DstLength);
    }
    .....
    }

在这里插入图片描述
AMP测试条件1:
Zynq7045芯片平台,Core0跑Linux,Core1跑FreeRTOS,通过OpenAMP框架来启动Core1-FreeRTOS和核间通信。L2cache LockdownbyMaster分配256K给core0,256K给core1。
在这里插入图片描述

AMP测试条件2:
Zynq7045芯片平台,Core0跑Linux,Core1跑FreeRTOS,通过OpenAMP框架来启动Core1-FreeRTOS和核间通信。L2cache LockdownbyMaster分配256K给core0,256K给core1,core0 memtester 100M 100:

在这里插入图片描述

对比以上测试数据可得出如下结论:

1.不管是单核环境还是双核环境CPU搬运数据速率远大于pl330DMA搬运数据速率
2.单核环境与双核环境速率对比,cache的大小对cpu搬运数据和对pl330DMA搬运数据影响都较明显
3.core0对内存资源的占用率影响core1的pl330DMA数据传输速率,而对core1的cpu搬运数据影响不大
4.单核128K,256K,双核128K速率异常高,应该是数据在L2cache完成交换
5.第3行拷贝速度下降,可能是Core0做memtester影响到Core1访问总线或DDR的时延了

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Zynq PL-PS DMA是指Xilinx开发的Zynq系列可编程逻辑和处理系统之间的数据传输机制。Zynq是一种集成了ARM处理系统和可编程逻辑(PL)的SoC(系统级片上系统)芯片。 在Zynq芯片中,处理系统(PS)是由ARM Cortex-A9处理器组成的,用于运行操作系统和处理高级任务,而可编程逻辑(PL)是由可配置的逻辑单元组成的,用于实现硬件加速和高性能计算。而PL-PS DMA是用于在两者之间进行高速数据传输的重要组件。 DMA(Direct Memory Access)是一种数据传输技术,允许数据在内存和外设之间直接进行传输,而不需要CPU的干预。在Zynq PL-PS DMA中,DMA控制器位于PS中,用于管理数据在PL和PS之间的传输。 Zynq PL-PS DMA具有以下特点:高性能、低延迟、高带宽。通过使用DMA,PL可以直接从内存中取数据,不需要CPU的介入,从而提高了数据传输效率和系统性能。 在使用Zynq PL-PS DMA时,首先需要在PL和PS之间建立合适的数据通道。然后,通过编程配置DMA控制器的寄存器,设置数据传输的起始地址、传输长度、传输方向等参数。最后,启动DMA传输过程,并通过中断或轮询方式检查传输状态,以确保数据正确传输。 总之,Zynq PL-PS DMA是一种用于实现Zynq系列芯片中可编程逻辑和处理系统之间高速数据传输的技术,通过提供高性能、低延迟和高带宽的数据传输通道,提高了系统的数据传输效率和整体性能。 ### 回答2: Zynq PL PS DMA是指Zynq系列中的可编程逻辑(PL),处理系统(PS)和直接内存访问(DMA)的一种配置。 Zynq系列芯片是赛灵思公司针对嵌入式系统设计开发的产品。它将传统的处理器系统和可编程逻辑(FPGA)集成到一个芯片中,为嵌入式系统设计带来更高的灵活性和性能。 PL是可编程的逻辑部分,其中包含了可编程逻辑电路,如FPGA。PL可以用于实现各种不同的功能,例如数字信号处理、图像处理、乘法器等。PL可以被重新配置和优化,以满足不同应用的需求。 PS是指处理系统,它是Zynq芯片中的ARM Cortex-A9核心。PS负责运行嵌入式操作系统(如Linux),管理系统的整体运行和资源分配。PS还可以执行一些实时任务,如控制外部设备等。 DMA是指直接内存访问。DMA可以在处理器不参与的情况下,通过直接从外部设备取或写入数据到内存中,实现高速的数据传输。DMA可以显著提高数据传输的效率,减少了处理器对数据传输的负担。 Zynq PL PS DMA的配置可以充分发挥Zynq芯片的优势。PL的灵活性可以满足各种不同的应用需求,而PS的处理能力可以支持操作系统的运行和系统管理。DMA的使用可以加快数据传输速度,提高系统的响应速度。 总之,Zynq PL PS DMA的配置充分利用了可编程逻辑、处理系统和直接内存访问的优势,为嵌入式系统设计提供了更高的灵活性、性能和效率。 ### 回答3: Zynq是赛灵思公司(Xilinx)推出的一种嵌入式平台,它将硬件逻辑(PL)与处理系统(PS)集成在一个芯片上。PL是FPGA实现的可编程逻辑部分,而PS则是ARM处理器系统。 DMA(Direct Memory Access)是一种数据传输方式,允许外部设备直接访问系统内存,无需CPU的干预。在Zynq平台中,PL和PS都可以使用DMA进行数据传输。 在PL中使用DMA,我们可以通过定制的硬件逻辑实现高速、低延迟的数据传输。DMA可以从外部设备接收数据,将其存储在PL的内存中,并通过总线接口将数据传输到PS的内存中。这种方式可以减少数据传输的CPU开销,提高系统的性能。 在PS中使用DMA,可以实现高效的数据传输与处理。例如,通过使用DMA,可以将大数据块从外部设备传输到PS的内存中,然后再由CPU进行处理。这样可以提高数据处理的效率,减少CPU的负担。 总之,Zynq平台中的PL和PS均可使用DMA进行数据传输,通过利用DMA可以提高数据传输的效率,降低系统的延迟,从而提升整体性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值