vivado SDK 双核运行

双核工程参考
开双核只需要建立两个分别在cpu0和cpu1上跑的工程,如果必要的话需要屏蔽cache,一般步骤是:

  1. Xil_SetTlbAttributes(0xFFFF0000,0x14de2);屏蔽cache
  2. Xil_Out32(CPU1STARTADR, MEM_BASE_ADDR_1);
    dmb();等待程序写入到OCM
    sev();这是一个汇编指令,触发事件唤醒CPU1

如果只是在线烧录代码进板子,就不需要建立FSBL工程(这个主要是生成BOOT.bin进行程序固化)
一般烧录代码进板子没反应,可能的问题是:
1.没有正确指定hardware platform,一般建立application时需要指定硬件平台(这个一般很少出现);
2.RUN as或者Debug as时Application处没有勾选cpu去执行对应的工程(这个很常见);
3.如果勾选了双核,但是没有正确运行,么很大程度上是代码的某些”初始化没通过“,这些还包括地址初始化。本人犯了一个很严重的错误,两个cpu对应的DDR地址冲突了(参考1参考2),出错了很久都不知道问题所在,最后在lscript.ld中改修改地址后程序成功执行。
在这里插入图片描述

在这里插入图片描述
CPU0对应的DDR空间
在这里插入图片描述
CPU1对应的DDR空间
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值