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

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

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

對ZYNQ芯片架構(gòu)的理解談?wù)剛€人體會

FPGA之家 ? 來源:嵌入式大雜燴 ? 作者:嵌入式大雜燴 ? 2021-04-02 17:13 ? 次閱讀

[導(dǎo)讀] 基于ZYNQ實現(xiàn)復(fù)雜嵌入式系統(tǒng)非常便利,其應(yīng)用領(lǐng)域也越來越廣泛,本文來從對ZYNQ芯片架構(gòu)的理解來談?wù)剛€人體會。

俯瞰zynq

575ae1b0-92eb-11eb-8b86-12bb97331649.png

ZYNQ主要由兩大部分組成:

處理系統(tǒng)PS(Processing System):上圖左上部分即是PS部分,包括:

同構(gòu)雙核ARM Cortex A9的對稱多處理器 (Symmetric Multi-Processing,SMP)

豐富的外設(shè),2×SPI,2×I2C,2×CAN,2×UART,2×SDIO,2×USB,2×GigE,GPIO

靜態(tài)存儲控制器:Quad-SPI,NAND,NOR

動態(tài)存儲控制器:DDR3,DDR2,LPDDR2

編程邏輯PL(Programmable logic):兼容賽靈思7系列FPGA

基于Artix的芯片:Z-7010以及Z-7020

基于Kintex的芯片:Z-7030以及Z-7045

ZYNQ處理系統(tǒng)端PS所有的外設(shè)都連接在AMBA(Advanced Microcontroller Bus Architecture)總線,而基于FPGA設(shè)計的IP則可以通過AXI接口掛載在AMBA總線上,從而實現(xiàn)內(nèi)部各組件的互聯(lián)互通。這里涉及到兩個概念:

AMBA總線,熟悉ARM架構(gòu)的朋友應(yīng)該都大致了解, AMBA是ARM公司的注冊商標(biāo)。是一種用于片上系統(tǒng)(SoC)設(shè)計中功能塊的連接和管理的開放標(biāo)準(zhǔn)片上互連規(guī)范。它促進了具有總線結(jié)構(gòu)及多控制器或組件的多核處理器設(shè)計開發(fā)。自成立以來,AMBA已廣為應(yīng)用,遠遠超出了微控制器設(shè)備領(lǐng)域。如今,AMBA已廣泛用于各種ASIC和SoC部件,包括在現(xiàn)代便攜式移動設(shè)備中使用的應(yīng)用處理器。

高級可擴展接口AXI(Advanced eXtensible Interface):是ARM公司AMBA 3.0 和AMBA 4.0規(guī)范的一部分,是并行高性能,同步,高頻,多主機,多從機通訊接口,主要設(shè)計用于片上通訊。為啥說AXI是AMBA的一部分,看看下面兩個圖就可以比較清晰的了解。

5799121e-92eb-11eb-8b86-12bb97331649.png

57d108ae-92eb-11eb-8b86-12bb97331649.png

ZYNQ的高度靈活性靈活的PS端IO復(fù)用Multiplexed I/O (MIO):PS端外設(shè)IO復(fù)用,這是什么概念呢?前面介紹了ZYNQ主要分PS/PL兩大組成模塊,PS端前面介紹的外設(shè)如USB/CAN/GPIO/UART等都必要需要引腳與外界打交道,這里所謂的復(fù)用與常見的單片機、處理器里引腳復(fù)用的概念一樣。但是(這里劃重點),ZYNQ具有高達54個PS引腳支持MIO,MIO具有非常高的靈活度以達到靈活配置,這給硬件設(shè)計、PCB布板帶來了極大的便利!,MIO的配置利用vivado軟件可以實現(xiàn)靈活配置,如下圖所示。

580182a4-92eb-11eb-8b86-12bb97331649.png

硬件工程師往往發(fā)現(xiàn)對一個復(fù)雜的系統(tǒng)的布局布線,常常會很困難,也常因為不合理的布局布線而陷入EMC深坑。ZYNQ的IO引腳高度靈活性,無疑在電路設(shè)計方面提供極大的方便,可實現(xiàn)非常靈活的PCB布局布線。從而在EMC性能改善方面帶來了很大便利。

靈活的PS-PL互連接口Extended Multiplexed I/O (EMIO) :擴展MIO,如果想通過PS來訪問PL又不想浪費AXI總線時,就可以通過EMIO接口來訪問PL。54個I/O中,其中一部分只能用于MIO,大部分可以用于MIO或EMIO,少量引腳只能通過EMIO訪問。

58243aa6-92eb-11eb-8b86-12bb97331649.png

如上圖,比如I2C0則可以通過EMIO映射到PL端的引腳輸出,這無疑又增加了更多的靈活性!

PS-PL接口HP0-HP3:如上架構(gòu)圖中AXI high-performance slave ports (HP0-HP3) 實現(xiàn)了PS-PL的接口

可配置的32位或64位數(shù)據(jù)寬度

只能訪問片上存儲器OCM(On chip memory)和DDR

AXI FIFO接口(AFI)利用1KB FIFOs來緩沖大數(shù)據(jù)傳輸

PS-PL接口GP0-GP1:如上架構(gòu)圖中AXI general-purpose ports

兩個PS主接口連接到PL的兩個從設(shè)備

32位數(shù)據(jù)寬度

一個連接到CPU內(nèi)存的64位加速器一致端口ACP)AXI從接口,ACP 是 SCU (一致性控制單元)上的一個 64 位從機接口,實現(xiàn)從 PL 到 PS 的異步 cache 一致性接入點。ACP 是可以被很多 PL 主機所訪問的,用以實現(xiàn)和 APU 處理器相同的方式訪問存儲子系統(tǒng)。這能達到提升整體性能、改善功耗和簡化軟件的效果。ACP 接口的表現(xiàn)和標(biāo)準(zhǔn)的 AXI 從機接口是一樣的,支持大多數(shù)標(biāo)準(zhǔn)讀和寫的操作而不需要在 PL 部件中加入額外的一致性操作。

DMA, 中斷, 事件信號

處理器事件總線信號事件信息到CPU

PL外設(shè)IP中斷到PS通用中斷控制器(GIC

四個DMA通道RDY/ACK信號

擴展多路復(fù)用I/O (EMIO)允許PS外設(shè)端口訪問PL邏輯和設(shè)備I/O引腳。

時鐘以及復(fù)位信號:

四個PS時鐘帶使能控制連接到PL

四個PS復(fù)位信號連接到PL

靈活的時鐘系統(tǒng)PS時鐘源:

PS端具有4個外部時鐘源引腳

PS端具有3個PLL時鐘模塊

PS端具有4個時鐘源可輸出到PL

PL端具有7個時鐘源

PL端時鐘源域相對PS端不同

PL端時鐘可靈活來自PL端外部引腳,因為FPGA的硬可編程性,完全靈活配置

也可使用PS端的4個時鐘源

注意

PL和PS之間的時鐘同步是由PS端處理

PL不能提供時鐘給PS使用

豐富的IP庫Zynq 是一種SoC,具有大量的標(biāo)準(zhǔn) IP,這些部件不再需要重新設(shè)計而直接可用。以這樣的方式提升了設(shè)計抽象層級,加上重用預(yù)先測試和驗證過的部件,開發(fā)將被加速,而成本則可以降低。就像常說的:“ 為什么要重新發(fā)明輪子呢?”。

Vivado內(nèi)置了大量的IP可供使用,比如數(shù)學(xué)計算IP,信號處理IP、圖像視頻處理IP,通信互連(以太網(wǎng)、DDS、調(diào)制、軟件無線電、錯誤校驗)、處理器IP(MicroBlaze等)、甚至人工智能算法IP。

比如信號處理IP,由于采用FPGA硬邏輯實現(xiàn)信號處理無需CPU計算,對于實現(xiàn)復(fù)雜的信號運算(比如實現(xiàn)一個非常高階的FIR濾波、多點FFT計算)具有非常大優(yōu)勢。

5845cc0c-92eb-11eb-8b86-12bb97331649.png

雙ARM硬核處理器如架構(gòu)圖,ZYNQ內(nèi)置了雙ARM Cortex-A9硬核,對軟件設(shè)計提供了極大的靈活性,在該處理器上可運行LinuxAndroid等復(fù)雜的操作系統(tǒng),相比常規(guī)FPGA嵌軟核IP的做法具有更強大的運算處理能力,你可能會說其處理器的運算能力相比時下的其他ARM芯片或稍有不足,但基本能滿足常規(guī)的醫(yī)療、工業(yè)領(lǐng)域等嵌入式系統(tǒng)應(yīng)用需求。

PL/PS的有機結(jié)合通過前面的簡要分析介紹,不難發(fā)現(xiàn)PL可編程硬件邏輯及處理器單元的結(jié)合做的非常好。

PL端:可設(shè)計出高靈活的外設(shè)系統(tǒng),同時可編程硬件邏輯電路,可實現(xiàn)真正的硬并行處理、硬實時系統(tǒng)

PS端:PL端與PS的有機結(jié)合,有可實現(xiàn)對這種高靈活、硬并行、硬實時處理系統(tǒng)實現(xiàn)集中軟件管理

試想,如果一個系統(tǒng)需要實現(xiàn)硬實時、硬并行,復(fù)雜外設(shè)互連系統(tǒng):

或許會采用多微控制器(比如單片機)+處理器方案,微處理器實現(xiàn)實時需求,處理器運行Linux實現(xiàn)上層業(yè)務(wù)邏輯的方式。

或者采用FPGA+處理器來實現(xiàn)。

這兩種方案技術(shù)復(fù)雜度都非常高,硬件電路PCB設(shè)計比較復(fù)雜,軟件開發(fā)以及維護也會增加復(fù)雜度。而ZYNQ則可以很好的解決此類系統(tǒng)設(shè)計需求,真正做到system on chip,這也是SOC的一個很好的體現(xiàn)。

總結(jié)一下ZYNQ這種高度靈活性,豐富的外設(shè),豐富的IP庫,以及vivado強大易用的開發(fā)環(huán)境,對使用ZYNQ進行嵌入式系統(tǒng)設(shè)計帶來了非常多優(yōu)勢。

原文標(biāo)題:從ZYNQ芯片架構(gòu)談?wù)勂錇楹稳绱苏T人

文章出處:【微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

責(zé)任編輯:haq

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

    關(guān)注

    68

    文章

    19044

    瀏覽量

    228496
  • FPGA
    +關(guān)注

    關(guān)注

    1624

    文章

    21568

    瀏覽量

    600569
  • 芯片
    +關(guān)注

    關(guān)注

    452

    文章

    50005

    瀏覽量

    419699
  • 嵌入式
    +關(guān)注

    關(guān)注

    5053

    文章

    18915

    瀏覽量

    300861

原文標(biāo)題:從ZYNQ芯片架構(gòu)談?wù)勂錇楹稳绱苏T人

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    ZYNQ核心板學(xué)習(xí)筆記

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

    FPGA芯片架構(gòu)和資源有深入的理解,精通Verilog HDL、VHDL

    、計算機相關(guān)專業(yè),具有良好的專業(yè)基礎(chǔ)知識。 2.工作年限不限,有工作經(jīng)驗或優(yōu)秀應(yīng)屆畢業(yè)生亦可。 3.對FPGA芯片架構(gòu)和資源有深入的理解,精通Verilog HDL、VHDL編程語言,熟悉時序約束、時序分析
    發(fā)表于 09-15 15:23

    主流芯片架構(gòu)包括哪些類型

    主流芯片架構(gòu)芯片設(shè)計領(lǐng)域中的核心組成部分,它們決定了芯片的功能、性能、功耗等多個方面。當(dāng)前,全球范圍內(nèi)主流的芯片
    的頭像 發(fā)表于 08-22 11:08 ?566次閱讀

    人體紅外傳感器的作用是什么

    傳感器的工作原理基于人體發(fā)出的紅外輻射。人體的溫度通常在36.5℃到37.5℃之間,這個溫度遠高于周圍環(huán)境的溫度。因此,人體會不斷地向周圍環(huán)境輻射紅外能量。人體紅外傳感器就是通過檢測這
    的頭像 發(fā)表于 08-20 09:16 ?606次閱讀

    聯(lián)發(fā)科正在開發(fā)Arm架構(gòu)Windows PC芯片

    據(jù)權(quán)威媒體援引三位知情人士的消息報道,聯(lián)發(fā)科正在緊鑼密鼓地開發(fā)一款基于Arm架構(gòu)個人電腦芯片。這款芯片將成為推動Windows操作系統(tǒng)在新型電腦設(shè)備上運行的重要力量。
    的頭像 發(fā)表于 06-13 09:16 ?598次閱讀

    談?wù)?/b> 十折交叉驗證訓(xùn)練模型

    談?wù)?/b> 十折交叉驗證訓(xùn)練模型
    的頭像 發(fā)表于 05-15 09:30 ?714次閱讀

    Xilinx ZYNQ 動手實操演練

    邏輯部分基于賽靈思28nm7系列FPGA,因此該系列產(chǎn)品的名稱中添加了“7000”,以保持與7系列FPGA的一致性,同時也方便日后本系列新產(chǎn)品的命名。 除了芯片外,賽靈思Zynq-7000系列還構(gòu)成
    發(fā)表于 05-03 19:28

    談?wù)?/b>大家學(xué)習(xí)FPGA的經(jīng)歷

    談?wù)?/b>大家學(xué)習(xí)FPGA,一路以來的經(jīng)歷感受,有啥心得體會都可以暢聊分享
    發(fā)表于 03-31 12:55

    交換芯片架構(gòu)是什么意思 交換芯片架構(gòu)怎么工作

    交換芯片架構(gòu)是指交換芯片內(nèi)部的設(shè)計和組織方式,包括其硬件組件、處理單元、內(nèi)存結(jié)構(gòu)、接口以及其他關(guān)鍵部分的布局和相互作用。交換芯片架構(gòu)決定了
    的頭像 發(fā)表于 03-22 16:45 ?610次閱讀

    交換芯片架構(gòu)設(shè)計

    交換芯片架構(gòu)設(shè)計是網(wǎng)絡(luò)設(shè)備性能和功能的關(guān)鍵。一個高效的交換芯片架構(gòu)能夠處理大量的數(shù)據(jù)流量,支持高速數(shù)據(jù)傳輸,并提供先進的網(wǎng)絡(luò)功能。
    的頭像 發(fā)表于 03-21 16:28 ?452次閱讀

    fpga芯片架構(gòu)介紹

    FPGA(現(xiàn)場可編程門陣列)芯片架構(gòu)是一種高度靈活和可編程的集成電路架構(gòu),它以其獨特的結(jié)構(gòu)和功能,在現(xiàn)代電子系統(tǒng)中扮演著至關(guān)重要的角色。FPGA芯片
    的頭像 發(fā)表于 03-15 14:56 ?626次閱讀

    人體感應(yīng)器什么原理 人體感應(yīng)器用東西擋住還可以感應(yīng)嗎

    人體感應(yīng)器是一種通過感應(yīng)人體紅外輻射,實現(xiàn)對人體活動監(jiān)測的裝置。它主要包括溫度傳感器、紅外感應(yīng)模塊、信號處理電路和輸出接口等組件。當(dāng)有人體活動時,
    的頭像 發(fā)表于 01-23 13:48 ?3857次閱讀

    AD9683的引腳如何與zynq 7015芯片中的JESD204 ip核端口對應(yīng)相連?

    芯片上JESD204B協(xié)議對應(yīng)的引腳(SYSREF、SYNCINB和SERDOUT)與ZYNQ7015芯片中的JESD204 IP核的端口對應(yīng)相連。
    發(fā)表于 12-15 07:14

    人體感應(yīng)燈是如何檢測到人的存在的?

    解一下人體感應(yīng)技術(shù)的工作原理。人體感應(yīng)技術(shù)是通過感應(yīng)人體的熱量來實現(xiàn)的。人體發(fā)出的熱能主要來自于人體的表面溫度,例如皮膚和頭發(fā),這些溫度主要
    的頭像 發(fā)表于 12-07 11:09 ?1644次閱讀

    AD9681是否可被zynq-7020的pl端驅(qū)動?

    (~100M)的ADC,目前看中AD9681,但是不知道是否可以被我們的主控芯片ZYNQ-7020使用,如果不可以的話,請問是否有其他類似的能盡量滿足我們需求的ADC
    發(fā)表于 12-04 08:18