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

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

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

使用PCIE更新AMD ZYNQ的QSPI Flash參考設計

XILINX開發(fā)者社區(qū) ? 來源:XILINX開發(fā)者社區(qū) ? 2023-11-17 10:02 ? 次閱讀

本文作者:AMD 工程師Gao Jackie

簡介

AMD ZYNQ 7000 的 S_AXI 端口提供了外設訪問 PS 內(nèi)部外設控制器接口,這其中包括 4 個 S_AXI_HP 端口以及兩個 S_AXI_GP 端口。一般來說,可以訪問的內(nèi)部資源包括 DDR 控制器,QSPI 控制器,OCM,IIC,SPI 等。

教程提供一個最小的參考設計,使上位機可以通過 PCIE 端口,通過 S_AXI_GP0 端口訪問 ZYNQ 內(nèi)部的 QSPI 控制器,用來更新 Flash 的啟動分區(qū)。

軟件方面,移植了 Embedded SW的相關驅(qū)動代碼至 xdma 平臺,并提供了一個簡單的上位機測試程序,用來燒寫啟動鏡像至 Flash 分區(qū)。

教程中所有涉及的設計及代碼均在 Windows 和 Linux(Ubuntu20.04)平臺下作了驗證。

系統(tǒng)設計

1. 系統(tǒng)設計框圖參考如下。在設計實例化了一個 XDMA IP,通過其 M_AXI 端口連接至 ZYNQ 的 S_AXI_GP0,以訪問 PS QSPI 控制器。

036c1be4-847b-11ee-939d-92fbcf53809c.png

2. BD 中需要分配 XDMA 的 M_AXI 地址如下,可以用 AMD Vivado 的自動地址分配工具完成。

037f9f0c-847b-11ee-939d-92fbcf53809c.png

3. 如果有訪問其它外設的需求,詳細的地址可以參考 UG585 的 Table 4‐1: System-Level Address Map。

UG585:https://docs.xilinx.com/r/en-US/ug585-zynq-7000-SoC-TRM

環(huán)境需求

硬件環(huán)境:

ZC706 開發(fā)板

Windows10/11 或者 Ubuntu20.04 主機

軟件環(huán)境:

Vivado Design Suite 2022.2

Petalinux 2022.2

CMake > 2.15

Windows + Visual Studio 或者 Linux + GCC

代碼結構

硬件:

HW 文件夾里面里面包含 Vivado 工程,直接用 Vivado 2022.2 打開。

固件:

此參考設計用 petalinux 制作系統(tǒng)啟動鏡像,完整的 petalinux 工程位于 fw 目錄下。

執(zhí)行 petalinux-build 可以編譯。

執(zhí)行 petalinux-package –boot –u-boot –force –fpga XXX.bit 生成 BOOT.BIN 文件。

軟件:

qspi的驅(qū)動軟件移植自 Embedded SW,主要的改動包括修改 xil_io.c 文件,用 xdma 的驅(qū)動替換默認的 Xil_In32 和 Xil_Out32 的實現(xiàn)。

軟件支持 Windows 和 Linux 的主機,采用 cmake 環(huán)境。如果在 Windows 下,可以選擇 Visual Studio 作為編譯工具。編譯過程如下:

1.cdsw
2.mkdir build
3.cmake .. && make

測試結果

在 petalinux 下生成的 BOOT.BIN 文件放在生成的上位機軟件目錄下,執(zhí)行后可以看到更新 FLASH 的進度條在變化,說明 FLASH 被正常少燒寫。

完成后切換到 QSPI FLASH 啟動模式,上電觀察啟動過程。

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

    關注

    25

    文章

    5539

    瀏覽量

    135555
  • 控制器
    +關注

    關注

    114

    文章

    16822

    瀏覽量

    182153
  • FlaSh
    +關注

    關注

    10

    文章

    1656

    瀏覽量

    150566
  • 上位機
    +關注

    關注

    27

    文章

    952

    瀏覽量

    55433
  • Zynq
    +關注

    關注

    10

    文章

    614

    瀏覽量

    47877

原文標題:開發(fā)者分享|使用 PCIE 更新 AMD ZYNQ? 的 QSPI Flash 參考設計

文章出處:【微信號:gh_2d1c7e2d540e,微信公眾號:XILINX開發(fā)者社區(qū)】歡迎添加關注!文章轉載請注明出處。

收藏 0人收藏

    評論

    相關推薦

    編譯可在QSPI Flash上運行的程序

    在前文中已經(jīng)實現(xiàn)了一個能夠在 MDK 平臺進行下載代碼到 QSPI Flash 中的下載算法,以及一個能跳轉執(zhí)行應用程序的 2nd Bootloader,但若想將代碼下載到 QSPI Flas
    的頭像 發(fā)表于 03-31 09:50 ?3750次閱讀
    編譯可在<b class='flag-5'>QSPI</b> <b class='flag-5'>Flash</b>上運行的程序

    使用Zynq設備和Tandem配置的PCIe BOOTUP時間有什么要求?

    嗨,PCIe-Spec定義在穩(wěn)定供電后100ms,PCIe設備必須為鏈路訓練做好準備。使用7系列Zynq設備無法達到此時間。我使用了兩種方法來減少啟動時間: - 優(yōu)化FSBL以達到SPI控制器的最大
    發(fā)表于 06-09 16:42

    Zynq無法設置為從QSPI閃存啟動怎么解決?

    為了確保正確回退到金啟動,AR#67221規(guī)定QSPI閃存的D2和D3數(shù)據(jù)條應連接到4K7上拉。但是看看Zynq xc7z030fbg676,這些引腳也可用作配置模式引腳。QSPI D2 =模式引腳
    發(fā)表于 06-09 17:24

    【正點原子FPGA連載】第三十六章基于TCP協(xié)議的遠程更新QSPI Flash實驗-領航者 ZYNQ 之嵌入式開發(fā)

    原子公眾號,獲取最新資料第三十六章基于TCP協(xié)議的遠程更新QSPI Flash實驗在《程序固化實驗》中,我們了解了如何通過SDK軟件將BOOT.bin文件固化到QSPI中,這種現(xiàn)場通過
    發(fā)表于 09-08 11:08

    【正點原子FPGA連載】第三十七章基于UDP協(xié)議的遠程更新QSPI Flash實驗-領航者 ZYNQ 之嵌入式開發(fā)

    原子公眾號,獲取最新資料第三十七章基于UDP協(xié)議的遠程更新QSPI Flash實驗上一實驗我們利用TCP協(xié)議實現(xiàn)了遠程更新QSPI。為了滿足
    發(fā)表于 09-08 11:10

    什么是QSPI?如何使用QSPIQSPI Flash進行通信呢?

    吧,直接 16 根數(shù)據(jù)信號線,速度自然變得更快了,但使用 SPI FLash,不就是圖一個線少嘛。  為了方便描述,我們將使用 QSPI 接口連接的 SPI Flash 稱之為 QSPI
    發(fā)表于 03-17 15:17

    Zynq PCIe電路設計

    ZYNQ7045的PCIE電路設計,板卡使用插針式連接器,引出了PCIE信號,未使用金手指。為了插入機箱設計了擴展版,插座與插針對應,帶有PCIE金手指。目前遇到的問題是,當板卡連接擴
    發(fā)表于 05-16 11:07

    LS1046A上的QSPI Flash不可擦除怎么處理?

    在我定制的LS1046A板上,我們只使用了一個QSPI Flash S25FS512SDSMFI011,通過QSPI_A_CS0/QSPI_A_SCK/
    發(fā)表于 05-18 07:56

    使用 PCIE 更新 AMD ZYNQ? 的 QSPI Flash 參考設計

    的內(nèi)部資源包括 DDR 控制器,QSPI 控制器,OCM,IIC,SPI 等。 本教程提供一個最小的參考設計,使上位機可以通過 PCIE 端口,通過 S_AXI_GP0 端口訪問 ZYNQ 內(nèi)部
    發(fā)表于 11-30 18:49

    GD32-Colibri-F207實驗板QSPI_FLASH

    GD32-Colibri-F207實驗板QSPI_FLASH,很好的GD32資料,快來學習吧。
    發(fā)表于 04-21 16:35 ?26次下載

    AMD宣布即將推出AGESA 1.2.0.0 BIOS更新

    AMD 宣布下個月推出 AGESA 1.2.0.0 BIOS 更新:支持 PCIe Resizable BAR ,修復銳龍 5000 兼容問題 大約一周前,微星正式宣布在其主板上支持 RTX
    的頭像 發(fā)表于 01-22 16:50 ?6745次閱讀

    如何使用QSPI Flash控制器開發(fā)板上的 QSPI Flash進行寫讀操作

    學習內(nèi)容 本文首先介紹FlashQSPI Flash控制器的相關內(nèi)容,然后使用 QSPI Flash 控制器,開發(fā)板上的
    的頭像 發(fā)表于 06-10 17:08 ?1.5w次閱讀
    如何使用<b class='flag-5'>QSPI</b> <b class='flag-5'>Flash</b>控制器開發(fā)板上的 <b class='flag-5'>QSPI</b> <b class='flag-5'>Flash</b>進行寫讀操作

    通過KEIL制作QSPI接口的外部Flash下載算法

    電子發(fā)燒友網(wǎng)站提供《通過KEIL制作QSPI接口的外部Flash下載算法.pdf》資料免費下載
    發(fā)表于 09-19 16:26 ?7次下載
    通過KEIL制作<b class='flag-5'>QSPI</b>接口的外部<b class='flag-5'>Flash</b>下載算法

    Zynq中程序存儲位置和設置方法

    Zynq中存儲程序的地方有QSPI Flash,SD卡,EMMC。
    的頭像 發(fā)表于 10-17 17:00 ?2618次閱讀

    在mmWave SDK增加QSPI Flash驅(qū)動的示例

    電子發(fā)燒友網(wǎng)站提供《在mmWave SDK增加QSPI Flash驅(qū)動的示例.pdf》資料免費下載
    發(fā)表于 09-11 14:20 ?0次下載
    在mmWave SDK增加<b class='flag-5'>QSPI</b> <b class='flag-5'>Flash</b>驅(qū)動的示例

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品