赞
踩
种类 | 特点 | ||
---|---|---|---|
FPGA | Field Programmable Gate Array | 现场可编程逻辑门阵列 | 查找表;硬件可编程、灵活性高、功耗较低 |
CPU | Central Processing Unit | 中央处理器 | 软件可编程、灵活性高、功耗高 |
DSP | Digital Signal Processing | 数字信号处理芯片 | 存储哈佛结构,DSP作为专门的微处理器,主要用于计算,优势是软件的灵活性 |
CPLD | Complex Programmable Logic Device | 复杂可编程逻辑器件 | 乘积项 |
CPU/MCU指令执行流水线:取值、译码、执行、访存、写回
灵活性与效率之间存在矛盾,因此出现了芯片融合的方案
Zynq启动配置详解
不同于普通FPGA,zynq的启动是以ARM主导的,包括FPGA程序的加载,Zynq 的具体启动配置是分级进行的,一共可以分为3个阶段
一:Stage 0: BootROM 阶段
BootROM 在从外部存储设备读取了启动镜像后,通常会把它进行加载到 OCM 中。OCM,On Chip Memory,是Zynq 中 ARM 内核的片上存储器,也叫片上内存。自此之后,BootROM 阶段的启动任务就算是圆满结束了,接下来 BootROM 阶段就把控制权转移到了阶段1手中。
二:Stage 1: FSBL,(First Stage Boot Loader)阶段
可以分为以下4项:
完成 PS 的初始化
加载 PL 的bit流文件,完成 PL 配置
加载 SSBL 引导程序或是ARM的裸跑程序到 DDR
跳转执行 SSBL 或裸跑程序
FSBL 的任务如上所示,整个思路还是非常清晰的。第1步就是对 PS 端初始化,包括 DDR,MIO 等。第2步就是PL的配置,也就是传统的 FPGA 下载 bit 流的过程,但要注意的是,在 Zynq 的非 JTAG 模式下,PL 是无法直接自行配置的。第3步是加载 SSBL 或裸跑程序到 DDR 内存中,其中 SSBL,Second Stage Boot Loader,是在 Zynq 需要运行操作系统时才进行加载。而像我们入门学习时做的点亮 LED 灯实验,就只是属于裸跑程序。最后第4步,ARM 会跳转到 DDR 中执行所加载的程序。
三:Stage 2:SSBL阶段
SSBL 在 Zynq 的启动过程中是可选的一个阶段,就像所提到的点亮 LED 实验,包括一些其他的比较小型的程序,如果不需要用到操作系统的话,那么 Zynq 的启动流程到 FSBL 阶段就足够了。因此,SSBL 是面向于需要运行操作系统的应用场合。相信熟悉操作系统启动知识的朋友到这里应该很清楚了,SSBL 就是操作系统在启动过程中的引导程序 boot loader。对于 Linux 而言,Zynq 的 SSBL 阶段和 u-boot 的作用是相同的。具体来说,SSBL 的作用就是将 Zynq 所需要的操作系统加载到 DDR 内存之中。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。