Zynq的AMP多核处理

描述

写的是Zynq 7000系列的,arm有两个核。主要有AMP和SMP两种方式,SMP是两个核运行一个操作系统,跑LINUX的话,使能SMP,资源会自动分配给两个核运行。AMP是两个核独立运行,每个核可以运行操作系统也可以裸机运行。

两个CPU的启动方式是CPU0先运行,然后根据需要启动CPU1。

ZYNQ会先运行一个fsbl程序,再运行应用程序。因此启动CPU1的工作可以在fsbl中做,也可以在应用程序中做。

1 在FSBL中启动CPU1

FSBL程序可以在VITIS这个软件中生成。

在FSBL中添加以下程序来启动CPU1

Xil_Out32(0XFFFFFFF0, CPU1程序地址);
dmb(); 
sev(); //唤醒 CPU1

此段程序加在FSBL程序的HandoffAddress = LoadBootImage()之后,LoadBootImage()的作用的是将程序拷贝到ddr中,先将程序拷贝到ddr中,程序才能跳转运行。

1.1 CPU0运行裸机程序

Linux

fsbl启动两个CPU的应用程序

1.2 CPU0运行操作系统(Linux)

Linux

uboot就是CPU0的应用程序

2 应用程序启动CPU1

2.1 CPU0运行裸机程序

Linux

在CPU0的应用程序中唤醒CPU1,程序一样,如下:

Xil_Out32(0XFFFFFFF0, CPU1程序地址);
dmb(); 
sev(); //唤醒 CPU1

2.2 CPU0运行操作系统(Linux)

Linux

可以在UBOOT中唤醒CPU1,也可以在运行内核后唤醒CPU1。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分