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)) {
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值