双核处理运行机制原理实现步骤.pdfVIP

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

ZYNQ7双核处理的运行机制的原理步骤

ZYNQ7的PS系统有两个ARM处理器核,我们要发挥最大化系统性能,就

要将这两个核合理分配都用起来。我们这一集的目的是和大家一起来看看双

核运行的原理以及实现步骤。原理比较多,大家要结合资料多研究分析。

1OCM相关

1,我们首先看ZYNY结构的框图,各自内核有独立32K字节私有的ICACHE和DCACHE,两

个核有公用的512K混合CACHE(保存指令和数据)。

2,

有CACHE,详细说来就是FLUSH和INVALID。当然直接关闭掉对OCM进行的CACHE缓

存是最简单的方法。

3,OCM总共是256K,分成192K+64K,

192K放在寻址空间的最底部,从0开始编址,即0x0000_0000~0x0002_FFFF

64K放在寻址空间的最置,即0xFFFF_0000~0xFFFF_FFFF

4,OCM除了做为PS内唯一的一块高速器除了可以用做处理器的加速算法外,还有如

下两个妙用.

A,我们所知道的FSBL,其实就是被拷贝到OCM的192K位置执行(这个拷贝的过程是

ZYNQ7的BOOTROM来完成的)。

B,64K中的0XFFFF_FFF0还有特殊的意义:CPU1被CPU0唤醒后就是从这个地址

32位数据,当做程序指针PC来执行。换言之就是0XFFFF_FFF0这个地址保存的是CPU1

被唤醒后的运行地址。

2ZYNQ的启动过程

我们来从新回顾一下ZYNQ的启动过程的三个阶段。

1,BOOTROM阶段:选择从何种介质获取FSBL,拷贝OCM的192K部

分,并执行之,此代码用户不可见,也修改不了。

2,FSBL阶段:(1),根据用户不同配置,初始化硬件,(2),根据启动模式,

从不同的介质BOOT,按照跟BOOTGEN文件约定的格式进行解析,拷

贝数据到制定的DDR3器,如果存在PL配置文件完成PL配置,将执行

第一个出现的可执行。(3),FSBL阶段是SDK生产直接的模板,用户可以修改,

也可以不改一字直接使用。如果修改的话,可以完全改成自己的程序,限制仅仅

在数据和指令的总大小部超过192K。

3,SSBL或者用户程序:被FSBL搬运到DDR3空间并执行的可执行程序不在有

192K的空间限制,可以是非常大。这里可以是UBOOT之类的系统

程序,也可以是用户程序。

另外:

使用BOOT映像生成的文件是和FSBL对应使用的,我们这里使用了BOOT映像工

具BOOTGEN,生成的BOOT.BIN是拷贝到SD卡的第一个扇区,生成的BOOT.MCS

是可以烧写到NAND或者QSPIFLASH里。

BOOTGEN生成的映像本身就是小型的文件系统。在22讲我讲到使用BOOT映像

工具保存多个文件并指定让FSBL拷贝到DDR3的某个具置。这里我们也是

采样了类似的方式,保存CPU0和CPU1的可执行文件。大家注意由于ELF文件

本身含有地址信息BOOTGEN会自动

您可能关注的文档

文档评论(0)

152****8708 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档