chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

ZYNQ7000系列 PS、PL、AXI 、啟動流程基本概念

電子工程師 ? 來源:FPGA技術(shù)江湖 ? 作者:FPGA技術(shù)江湖 ? 2021-05-12 10:25 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、ZYNQ基本結(jié)構(gòu)

ZYNQ7000系列分為Artix-7 Kintex-7 Virtex-7,各個型號區(qū)別參考下面的博文

https://www.jianshu.com/p/005899fe6815

二、ZYNQ7020 分為PS端、PL端

PS: 處理系統(tǒng) (Processing System) , 就是與 FPGA 無關(guān)的 ARM 的 SOC 的部分。

PL: 可編程邏輯 (Progarmmable Logic), 就是 FPGA 部分。

ZYNQ7020的整體架構(gòu)如下圖所示

510502ca-b2a1-11eb-bf61-12bb97331649.png

Zynq 就是兩大功能塊,PS 部分和 PL 部分, 說白了,就是 ARM 的 SOC 部分,和 FPGA部分。其中,PS 集成了兩個 ARM Cortex-A9 處理器,AMBA互連,內(nèi)部存儲器,外部儲器接口和外設(shè)。這些外設(shè)主要包括 USB 總線接口,以太網(wǎng)接口,SD/SDIO 接口,I2C 總線接口,CAN 總線接口,UART 接口,GPIO 等。

三、PS和PL互聯(lián)技術(shù)

3.1、ZYNQ作為首款將高性能ARM Cortex-A9系列處理器與高性能FPGA在單芯片內(nèi)緊密結(jié)合的產(chǎn)品,為了實現(xiàn)ARM處理器和FPGA之間的高速通信和數(shù)據(jù)交互

3.2、發(fā)揮 ARM 處理器和 FPGA的性能優(yōu)勢,需要設(shè)計高效的片內(nèi)高性能處理器與 FPGA 之間的互聯(lián)通路。本節(jié),我們就將主要介紹 PS 和 PL 的連接,讓用戶了解 PS 和 PL 之間連接的技術(shù)。

3.3、在具體設(shè)計中我們往往不需要在連接這個地方做太多工作,我們加入 IP 核以后,系統(tǒng)會自動使用 AXI 接口將我們的 IP 核與處理器連接起來,我們只需要再做一點補充就可以了。

AXI 全稱 Advanced eXtensible Interface,是 Xilinx 從 6 系列的 FPGA 開始引入的一個接口協(xié)議,主要描述了主設(shè)備和從設(shè)備之間的數(shù)據(jù)傳輸方式。在 ZYNQ 中繼續(xù)使用,版本是 AXI4,所以我們經(jīng)常會看到 AXI4.0,ZYNQ 內(nèi)部設(shè)備都有 AXI 接口。

3.4、其實 AXI 就是 ARM 公司提出的AMBA(Advanced Microcontroller Bus Architecture)的一個部分,是一種高性能、高帶寬、低延遲的片內(nèi)總線,也用來替代以前的 AHB 和 APB 總線。

AXI 協(xié)議主要描述了主設(shè)備和從設(shè)備之間的數(shù)據(jù)傳輸方式,主設(shè)備和從設(shè)備之間通過握手信號建立連接。當從設(shè)備準備好接收數(shù)據(jù)時,會發(fā)出 READY 信號。當主設(shè)備的數(shù)據(jù)準備好時,會發(fā)出和維持 VALID 信號,表示數(shù)據(jù)有效。數(shù)據(jù)只有在 VALID 和 READY 信號都有效的時候才開始傳輸。當這兩個信號持續(xù)保持有效,主設(shè)備會繼續(xù)傳輸下一個數(shù)據(jù)。

3.5、主設(shè)備可以撤銷VALID 信號,或者從設(shè)備撤銷 READY 信號終止傳輸。AXI 的協(xié)議如圖,T2 時,從設(shè)備的 READY信號有效,T3 時主設(shè)備的 VILID 信號有效,數(shù)據(jù)傳輸開始。

信號有效,T3 時主設(shè)備的 VILID 信號有效,數(shù)據(jù)傳輸開始。

52cd4324-b2a1-11eb-bf61-12bb97331649.png

53162b7a-b2a1-11eb-bf61-12bb97331649.png

四、ZYNQ 芯片內(nèi)部用硬件實現(xiàn)了 AXI 總線協(xié)議,包括 9 個物理接口,分別為 AXI-GP0~AXIGP3,AXI-HP0~AXI-HP3,AXI-ACP 接口。

1、AXI_ACP 接口,是 ARM 多核架構(gòu)下定義的一種接口,中文翻譯為加速器一致性端口,用來管理 DMA 之類的不帶緩存的 AXI 外設(shè),PS 端是 Slave 接口。2、AXI_HP 接口,是高性能/帶寬的 AXI3.0 標準的接口,總共有四個,PL 模塊作為主設(shè)備連接。主要用于 PL 訪問 PS 上的存儲器(DDR 和 On-Chip RAM)3、AXI_GP接口,是通用的AXI接口,總共有四個,包括兩個32位主設(shè)備接口和兩個32位從設(shè)備接口

533eb48c-b2a1-11eb-bf61-12bb97331649.png

可以看到,ARM只有兩個 AXI-GP 是 Master Port,即主機接口,其余 7 個口都是 Slave Port(從機接口)。主機接口具有發(fā)起讀寫的權(quán)限,ARM 可以利用兩個 AXI-GP 主機接口主動訪問 PL 邏輯,其實就是把 PL 映射到某個地址,讀寫 PL 寄存器如同在讀寫自己的存儲器。其余從機接口就屬于被動接口,接受來自 PL 的讀寫,逆來順受。

4.1、這 9 個 AXI 接口性能也是不同的。GP 接口是 32 位的低性能接口,理論帶寬600MB/s,而 HP 和 ACP 接口為 64 位高性能接口,理論帶寬 1200MB/s。

4.2、有人會問,為什么高性能接口不做成主機接口呢?這樣可以由 ARM 發(fā)起高速數(shù)據(jù)傳輸。答案是高性能接口根本不需要 ARM CPU 來負責數(shù)據(jù)搬移,真正的搬運工是位于 PL 中的 DMA 控制器。

4.3、位于 PS 端的 ARM 直接有硬件支持 AXI 接口,而 PL 則需要使用邏輯實現(xiàn)相應的 AXI 協(xié)議。Xilinx 在 Vivado 開發(fā)環(huán)境里提供現(xiàn)成 IP 如 AXI-DMA,AXI-GPIO,AXI-Dataover, AXI-Stream 都實現(xiàn)了相應的接口,使用時直接從 Vivado 的 IP 列表中添加即可實現(xiàn)相應的功能。下圖為 Vivado 下的各種 DMA IP:

53a33ad8-b2a1-11eb-bf61-12bb97331649.png

下面為幾個常用的 AXI 接口 IP 的功能介紹:

AXI-DMA:實現(xiàn)從 PS 內(nèi)存到 PL 高速傳輸高速通道 AXI-HP<---->AXI-Stream 的轉(zhuǎn)換AXI-FIFO-MM2S:實現(xiàn)從 PS 內(nèi)存到 PL 通用傳輸通道 AXI-GP<----->AXI-Stream 的轉(zhuǎn)換AXI-Datamover:實現(xiàn)從 PS 內(nèi)存到 PL 高速傳輸高速通道 AXI-HP<---->AXI-Stream 的轉(zhuǎn)換,只不過這次是完全由 PL 控制的,PS 是完全被動的。AXI-VDMA:實現(xiàn)從 PS 內(nèi)存到 PL 高速傳輸高速通道 AXI-HP<---->AXI-Stream 的轉(zhuǎn)換,只不過是專門針對視頻、圖像等二維數(shù)據(jù)的。AXI-CDMA:這個是由 PL 完成的將數(shù)據(jù)從內(nèi)存的一個位置搬移到另一個位置,無需 CPU 來插手。

4.4、AXI協(xié)議嚴格的講是一個點對點的主從接口協(xié)議,當多個外設(shè)需要互相交互數(shù)據(jù)時,我們需要加入一個AXI Interconnect模塊,也就是AXI互聯(lián)矩陣,

4.5、作用是提供將一個或多個 AXI 主設(shè)備連接到一個或多個 AXI 從設(shè)備的一種交換機制(有點類似于交換機里面的交換矩陣)。

4.6、這個 AXI Interconnect IP 核最多可以支持 16 個主設(shè)備、 16 個從設(shè)備,如果需要更多的接口,可以多加入幾個 IP 核。

AXI Interconnect 基本連接模式有以下幾種:? N-to-1 Interconnect? to-N Interconnect? N-to-M Interconnect (Crossbar Mode)? N-to-M Interconnect (Shared Access Mode)

53d20552-b2a1-11eb-bf61-12bb97331649.png

54107490-b2a1-11eb-bf61-12bb97331649.png

5430a652-b2a1-11eb-bf61-12bb97331649.png

五、內(nèi)部鏈接

ZYNQ 內(nèi)部的 AXI 接口設(shè)備就是通過互聯(lián)矩陣的的方式互聯(lián)起來的,既保證了傳輸數(shù)據(jù)的高效性,又保證了連接的靈活性。

Xilinx 在 Vivado 里我們提供了實現(xiàn)這種互聯(lián)矩陣的 IP 核axi_interconnect,我們只要調(diào)用就可以。

545d2808-b2a1-11eb-bf61-12bb97331649.png

六、引腳分配

ZYNQ7020是400腳封裝,從官網(wǎng)的文檔,可以看出ZYNQ7020的引腳分配

PS端的引腳包括BANK500、BANK501、BANK502、

PL端引腳包括 BANK13(部分包含)BANK35、BANK34

5485f904-b2a1-11eb-bf61-12bb97331649.png

下面這張圖,更加形象

5547e55a-b2a1-11eb-bf61-12bb97331649.png

七、上面的部分,并沒有把引腳講的很清楚,這里看官方手冊,有如下描述

意思是,PS端的引腳數(shù)量是固定的,并且不能分配給PL端使用,最多有54個引腳可以連接到PS端,

他們可以軟件編程連接ps的內(nèi)部外設(shè)或者靜態(tài)內(nèi)存控制器

八、MIO概述

MIO的功能是將從PS外設(shè)和靜態(tài)內(nèi)存接口的訪問,復用到配置寄存器中定義的PS引腳。在PS端最多有54針被用以IOP(I/O Peripheral )和靜態(tài)內(nèi)存接口下表4顯示了可以映射不同外設(shè)引腳的位置。圖2顯示了MIO模塊的框圖。如果超過了54個引腳個數(shù)的其它I/O功能是設(shè)計必須的,那他可以通過PL端,路由到與這些功能相關(guān)聯(lián)的I/O引腳這個特性被稱為可擴展多路復用I/O (EMIO)。

562db4b8-b2a1-11eb-bf61-12bb97331649.png

5676e278-b2a1-11eb-bf61-12bb97331649.png

九、MIO、EMIO和AXI_GPIO的關(guān)系

ZYNQ7000中與PS相連的引腳包含MIO、EMIO和AXI_GPIO三種類型。

1、MIO直接掛在PS上,而EMIO與PL相連,PS通過PL調(diào)用EMIO。MIO共有54bit,EMIO共有64bit。

MIO管腳是固定的,而EMIO需要通過管腳約束文件進行分配。MIO、EMIO管腳號均通過實際原理圖查找。

56b74a70-b2a1-11eb-bf61-12bb97331649.png

2、AXI_GPIO是通過AXI總線掛在PS上的GPIO,一般通過調(diào)用IP核實現(xiàn),如PS通過AXI_Uartlite調(diào)用PL端資源。

而EMIO在Block Design文件上表現(xiàn)為PS上的一個引出接口。

十、PS-PL MIO-EMIO信號和接口

由于MIO引腳的數(shù)量有限,MIO是I/O外圍連接的基礎(chǔ)。可以軟件編程IO信號路由到MIO引腳。也可以通過EMIO接口將I/O外圍信號路由到PL端,

這非常有用,用來PS獲得更多的設(shè)備引腳(PL端引腳),或者允許一個PS端外設(shè)的一個引腳路由到PL的內(nèi)部IP邏輯端口,如圖2

56da45b6-b2a1-11eb-bf61-12bb97331649.png

十一、啟動流程

57162b80-b2a1-11eb-bf61-12bb97331649.png

12.1、啟動模式

Boot 模式3種啟動模式可以使用:? PS Master Non-secure Boot? PS Master Secure Boot? JTAG/PJTAG Boot

12.2、啟動階段

Zynq-7000 AP SoC 支持安全和非安全啟動處理,啟動分3個階段 ? Stage-0 Boot (BootROM) ? First Stage Bootloader ? Second Stage Bootloader (Optional)

12.3、階段0:Stage-0 Boot (BootROM)

575e6e36-b2a1-11eb-bf61-12bb97331649.png

12.4、階段1:FSBL(First Stage Bootloader )

FSBL(第一階段引導加載程序)在BootROM之后啟動,這個BootROM將FSBL加載到OCM(On-Chip Memory ),

FSBL負責下面的幾項工作

1、初始化PS端的配置數(shù)據(jù)(使用xilinx硬件配置工具提供的)2、用bitstream文件燒寫PL端3、加載第二階段BootLoader或者邏輯代碼到DDR內(nèi)存4、卻換到第二階段BootLoader或者邏輯代碼運行

FSBL流程圖

57845bc8-b2a1-11eb-bf61-12bb97331649.png

下圖是一個簡單的FSBL流程圖:

57a3f47e-b2a1-11eb-bf61-12bb97331649.png

12.5、第二階段啟動流程:Second Stage Bootloader

第二階段引導加載程序是可選的,并由用戶設(shè)計。

Zynq-7000 AP SoC BootROM加載程序需要引導映像頭,它加載單個分區(qū),通常是FSBL。引導映像的其余部分由FSBL加載和處理。

xilinx提供了一個名為Bootgen的實用程序(用來創(chuàng)建一個適合ROM或Fash的引導映像)。它通過構(gòu)建所需的引導頭、

附加描述以下分區(qū)的表并將輸入數(shù)據(jù)文件(ELF文件、FPGA bit流和其他二進制文件)處理到分區(qū)來創(chuàng)建映像。

12.6、Boot Image 格式

Boot鏡像格式包含下面幾個方面 ? BootROM header ? FSBL image ? One or more partition images ? Unused space, if available

57c45426-b2a1-11eb-bf61-12bb97331649.png

12.7、下圖顯示了Zynq-7000 AP SoC Linux引導映像分區(qū)的示例。

57e90636-b2a1-11eb-bf61-12bb97331649.png

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1650

    文章

    22204

    瀏覽量

    626669
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    135

    文章

    9445

    瀏覽量

    385458
  • soc
    soc
    +關(guān)注

    關(guān)注

    38

    文章

    4472

    瀏覽量

    226083
  • 可編程邏輯
    +關(guān)注

    關(guān)注

    7

    文章

    526

    瀏覽量

    45181

原文標題:學員筆記精選 | ZYNQ7000系列 PS、PL、AXI 、啟動流程基本概念篇

文章出處:【微信號:HXSLH1010101010,微信公眾號:FPGA技術(shù)江湖】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    ZYNQ PSPL數(shù)據(jù)交互方式

    ZYNQ SoC 的 PS (Processing System) 和 PL (Programmable Logic) 之間的數(shù)據(jù)交互是系統(tǒng)設(shè)計的核心。
    的頭像 發(fā)表于 10-15 10:33 ?86次閱讀
    <b class='flag-5'>ZYNQ</b> <b class='flag-5'>PS</b>與<b class='flag-5'>PL</b>數(shù)據(jù)交互方式

    Zynq7100 BSP移植,MSH終端不能正確顯示是為什么?

    由于新版本的RT Thread的BSP不再提供Zynq7000的支持。所以同事從RT Thread(4.0.3)中的Zynq7000移植了一份Zynq 7100的BSP。但是MSH終端和串口輸出
    發(fā)表于 09-19 06:26

    CoWoP封裝的概念流程與優(yōu)勢

    本文介紹了CoWoP(Chip?on?Wafer?on?Substrate)封裝的概念、流程與優(yōu)勢。
    的頭像 發(fā)表于 08-12 10:49 ?1523次閱讀
    CoWoP封裝的<b class='flag-5'>概念</b>、<b class='flag-5'>流程</b>與優(yōu)勢

    AMD Versal自適應SoC上的級聯(lián)模式示例

    本篇博文主要講解在 PL 中如何使用 AXI Interrupt Controller (INTC) 的級聯(lián)模式,將 IP 核超過 32 個的中斷連接到 PS 上。
    的頭像 發(fā)表于 07-22 17:41 ?1212次閱讀
    AMD Versal自適應SoC上的級聯(lián)模式示例

    第十三章 通訊的基本概念

    本章介紹通訊基本概念,包括串行/并行、全雙工/半雙工/單工、同步/異步通訊,還提及通訊速率中比特率與波特率的概念。
    的頭像 發(fā)表于 05-22 17:29 ?1524次閱讀
    第十三章 通訊的<b class='flag-5'>基本概念</b>

    ZYNQ FPGA的PS端IIC設(shè)備接口使用

    zynq系列中的FPGA,都會自帶兩個iic設(shè)備,我們直接調(diào)用其接口函數(shù)即可運用。使用xilinx官方提供的庫函數(shù),開發(fā)起來方便快捷。
    的頭像 發(fā)表于 04-17 11:26 ?1514次閱讀
    <b class='flag-5'>ZYNQ</b> FPGA的<b class='flag-5'>PS</b>端IIC設(shè)備接口使用

    Zynq7000處理器的配置詳解

    添加好ZYNQ7 Processing System IP核后,需要對其進行配置,雙擊彈出如下窗口。綠色部分表示ZYNQ PS部分中可配置的項目,可以雙擊轉(zhuǎn)向相應的設(shè)置界面,也可以直接在左邊的導航列表中選擇。
    的頭像 發(fā)表于 03-27 09:37 ?1808次閱讀
    <b class='flag-5'>Zynq7000</b>處理器的配置詳解

    從零開始馴服Linux(一):ZYNQ-Linux啟動文件構(gòu)建全解析

    本帖最后由 jf_85110202 于 2025-3-20 17:42 編輯 從零開始馴服Linux(一):ZYNQ-Linux啟動文件構(gòu)建全解析 ZYNQ系列芯片集成了ARM
    發(fā)表于 03-20 16:48

    ZYNQ基礎(chǔ)---AXI DMA使用

    前言 在ZYNQ中進行PL-PS數(shù)據(jù)交互的時候,經(jīng)常會使用到DMA,其實在前面的ZYNQ學習當中,也有學習過DMA的使用,那就是通過使用自定義的IP,完成HP接口向內(nèi)存寫入和讀取數(shù)據(jù)的方式。同樣
    的頭像 發(fā)表于 01-06 11:13 ?3124次閱讀
    <b class='flag-5'>ZYNQ</b>基礎(chǔ)---<b class='flag-5'>AXI</b> DMA使用

    基于Xilinx ZYNQ7000 FPGA嵌入式開發(fā)實戰(zhàn)指南

    電子發(fā)燒友網(wǎng)站提供《基于Xilinx ZYNQ7000 FPGA嵌入式開發(fā)實戰(zhàn)指南.pdf》資料免費下載
    發(fā)表于 12-10 15:31 ?38次下載

    dac3174與xilinx zynq7000系列連接,fpga的案例參考代碼有沒有?

    dac3174與xilinx zynq7000系列連接,fpga的案例參考代碼有沒有? tsw1400_lvds_dac_sample_wise_restored的代碼寫的實在太難度了,一句注釋都沒有
    發(fā)表于 11-25 06:04

    當ADC3663的LVDS輸出給到ZYNQ-7000的LVDS接收這兩者之間可以直連嗎?

    ADC3663的LVDS差分輸出與xilinx的ZYNQ-7000的LVDS輸入的電平匹配問題 ADC3663的供電是1.8V,ADC3663的LVDS輸出給到ZYNQ-7000的BANK12
    發(fā)表于 11-14 07:43

    ZYNQ核心板學習筆記

    此款開發(fā)板使用的是 Xilinx 公司的 Zynq7000 系列的芯片,型號為 XC7Z020-2CLG484I,484 個引腳的 FBGA 封裝。
    的頭像 發(fā)表于 10-24 18:08 ?3440次閱讀
    <b class='flag-5'>ZYNQ</b>核心板學習筆記

    Linux應用編程的基本概念

    Linux應用編程涉及到在Linux環(huán)境下開發(fā)和運行應用程序的一系列概念。以下是一些涵蓋Linux應用編程的基本概念。
    的頭像 發(fā)表于 10-24 17:19 ?862次閱讀

    Xilinx ZYNQ 7000系列SoC的功能特性

    本文介紹下Xilinx ZYNQ 7000系列SoC的功能特性、資源特性、封裝兼容性以及如何訂購器件。
    的頭像 發(fā)表于 10-24 15:04 ?3506次閱讀
    Xilinx <b class='flag-5'>ZYNQ</b> <b class='flag-5'>7000</b><b class='flag-5'>系列</b>SoC的功能特性