[導讀]?前?言?本文主要介紹i.MX8MMini基于FlexSPI、PCIe與FPGA的高速通信案例。本文檔適用開發(fā)環(huán)境:Windows開發(fā)環(huán)境:Windows764bit、Windows1064bit虛擬機:VMware15.1.0Linux開發(fā)環(huán)境:Ubuntu18.04.464b...
前 言
本文主要介紹i.MX 8M Mini基于FlexSPI、PCIe與FPGA的高速通信案例。
本文檔適用開發(fā)環(huán)境:
Windows開發(fā)環(huán)境:Windows 7 64bit、Windows 10 64bit
虛擬機:VMware15.1.0
Linux開發(fā)環(huán)境:Ubuntu18.04.4 64bit
U-Boot:U-Boot-2020.04
Kernel:Linux-5.4.70
Linux SDK:5.4.70_2.3.0
*測試硬件平臺:TLIMX8-EVM評估板(NXP i.MX 8M Mini)
點擊圖片/圖注即可查看產(chǎn)品詳細介紹↓↓↓
圖 1 TLIMX8-EVM評估板
案例一:主要演示ARM Cortex-A53通過FlexSPI接口讀取FPGA(Spartan-6采集卡TL-HSAD-LX)發(fā)送的模擬數(shù)據(jù),并進行校驗,通過串口打印相關信息。實測速率為114.89MB/s。
案例二:主要演示ARM Cortex-A53通過PCIe接口與FPGA進行通信,實現(xiàn)對CameraLink相機圖像的采集、編碼和顯示。實測傳輸幀率為60fps。
案例詳細說明、源碼請掃描下方二維碼或點擊下載鏈接:
http://site.tronlong.com/pfdownload
1 flexspi_read案例
1.1 案例說明
本案例主要演示ARM Cortex-A53通過FlexSPI接口讀取FPGA(Spartan-6采集卡TL-HSAD-LX)發(fā)送的模擬數(shù)據(jù),并進行校驗,通過串口打印相關信息。
(1) 驅(qū)動默認配置FlexSPI為DDR模式(雙邊沿),配置FlexSPI的時鐘源為400MHz,分頻系數(shù)pre_divider和post_divider分別為2和5,此時FlexSPI的ROOT CLK時鐘為400MHz/2/5 = 40MHz,DDR模式的傳輸時鐘SCLK= ROOT SCLK/2 = 20MHz,數(shù)據(jù)位寬為8bit,即理論傳輸速率為40MB/s,實測速率為37.56MB/s。
(2) 驅(qū)動如配置FlexSPI為DDR模式(雙邊沿),配置FlexSPI的時鐘源為400MHz,分頻系數(shù)pre_divider和post_divider分別為1和3,此時FlexSPI的ROOT SCLK時鐘為400MHz/1/3 = 133MHz,DDR模式的傳輸時鐘SCLK = ROOT SCLK/2 = 66.5MHz,數(shù)據(jù)位寬為8bit,即理論傳輸速率為133MB/s,實測速率為114.89MB/s。
FPGA端:發(fā)送從0x00遞增至0xFF的數(shù)據(jù)。
ARM端:讀取數(shù)據(jù)并進行校驗,打印誤碼率、讀取速率和讀取到的數(shù)據(jù)。
程序流程圖如下:
圖 2
1.2 案例測試
圖 3
請按照上圖進行硬件連接,并將案例bin目錄下的可執(zhí)行文件flexspi_read、“driver\bin\”目錄下驅(qū)動文件flexspi_imx8.ko、“dts\image\”目錄下的設備樹文件tlimx8-evm-flexspi.dtb拷貝至評估板文件系統(tǒng)。采集卡TL-HSAD-LX加載或固化“data_to_flexspi\bin\”目錄下的.bit或.mcs文件。在評估板文件系統(tǒng)flexspi_read文件所在路徑下,執(zhí)行如下命令查詢程序參數(shù)說明。
Target# ls
Target# ./flexspi_read -h
圖 4
執(zhí)行如下命令將默認使用的設備樹tlimx8-evm.dtb進行備份,然后把tlimx8-evm-flexspi.dtb拷貝至“/run/media/mmcblk1p1/”目錄并重命名為tlimx8-evm.dtb。
Target# cp /run/media/mmcblk1p1/tlimx8-evm.dtb linux-tlimx8-evm.dtb//備份默認的tlimx8-evm.dtb,新文件名為linux-tlimx8-evm.dtb
Target# cp tlimx8-evm-flexspi.dtb /run/media/mmcblk1p1/tlimx8-evm.dtb
備注:更換設備樹后,需重啟評估板方可使設備樹生效。
圖 5
1.2.1 功能測試
執(zhí)行如下命令加載FlexSPI驅(qū)動。
Target# insmod flexspi_imx8.ko
圖 6
執(zhí)行如下命令進行測試。
Target# ./flexspi_read -a 0x08000000 -s 4096
圖 7
本次測試速率為37.56MB/s,誤碼率為0,與理論速率40MB/s接近。
備注:受限于測試板卡的硬件連接形式的影響,37.56MB/s是零誤碼率時的最高實測速率。
若讀取小于或等于2048Byte的數(shù)據(jù)時,每次讀完需清空FlexSPI的RX Buffer,否則下次讀取的數(shù)據(jù)是緩存在Buffer中的舊數(shù)據(jù)。
Target# devmem2 0x30bb0000 w 0xFFFF7031
圖 8
1.2.2 性能測試
執(zhí)行如下命令卸載flexspi驅(qū)動,并重新加載驅(qū)動。同時采集卡TL-HSAD-LX重新加載或固化FPGA程序。
Target# rmmod flexspi_imx8
Target# insmod flexspi_imx8.ko pre_divider=1 post_divider=3
備注:pre_divider和post_divider為分頻系數(shù),詳細說明請查閱驅(qū)動說明章節(jié)。
圖 9
執(zhí)行如下命令進行測試。
Target# ./flexspi_read -a 0x08000000 -s 4096
圖 10
可以看到本次測試速率為114.89MB/s,與理論速率133MB/s接近。
備注:受限于測試板卡的硬件連接形式的影響,此速率下的誤碼率為99.8%。
1.3 案例關鍵代碼
(1) main函數(shù)
圖 11
(2) 地址映射。
圖 12
(3) 讀取數(shù)據(jù)。
圖 13
(4) 校驗數(shù)據(jù)。
圖 14
(5) 打印數(shù)據(jù)。
圖 15
1.4 FPGA工程關鍵代碼
(1) 端口IO定義
flexspi_sclk和flexspi_ss0_n為輸入信號,flexspi_data和flexspi_data為輸出信號。
圖 16
(2) 時鐘輸入信號flexspi_sclk設置為2倍頻
圖 17
(3) 數(shù)據(jù)發(fā)送
圖 18
圖 19
2 gst_pcie_enc案例
2.1 案例說明
本案例主要演示ARM Cortex-A53通過PCIe接口與FPGA進行通信,實現(xiàn)對CameraLink相機圖像的采集、編碼和顯示。其中ARM端獲取到的原始圖像通過dma-buf機制,在采集、硬件編碼和顯示輸出等功能中進行共享,可實現(xiàn)高效的圖像數(shù)據(jù)“零拷貝”的錄播方案。
FPGA端:
(1) 采集CameraLink相機圖像;
(2) 通過XDMA IP實現(xiàn)為PCIe EP設備,RC端可通過PCIe接口訪問FPGA端DDR以及對VDMA IP的寄存器進行配置。
ARM端:
(1) 作為PCIe RC設備,配置VDMA IP將圖像存儲到FPGA DDR指定位置、將圖像從FPGA DDR通過XDMA搬運到ARM端DDR;
(2) 調(diào)用協(xié)處理器VPU進行H264硬件編碼,并將編碼后的數(shù)據(jù)存儲到文件;
(3) 編碼的同時,通過HDMI顯示實時圖像。
程序工作流程框圖如下所示:
圖 20
2.2 案例測試
請參考下圖,將創(chuàng)龍科技的TLCamerLinkF模塊連接至TLK7-EVM評估板的FMC2接口,TLK7-EVM評估板J1跳線帽選擇1.8V檔位,以配置FMC IO的BANK電壓為1.8V。將CameraLink相機的CL0通過數(shù)據(jù)線連接至TLCameraLinkF模塊的CameraLink1接口。再將TLK7-EVM評估板的PCIe插到TLIMX8-EVM評估板的PCIe插槽上,使用HDMI線纜連接TLIMX8-EVM評估板的HDMI OUT接口至HDMI顯示屏。
圖 21
將該案例bin目錄下的驅(qū)動文件xdma-video.ko拷貝至TLIMX8-EVM評估板文件系統(tǒng)中,并將案例bin目錄下的.bit或.bin文件加載或固化到TLK7-EVM評估板。
評估板上電,可執(zhí)行l(wèi)spci命令檢查PCIe連接是否正常。如不能獲取到如下信息,請檢查硬件連接和FPGA端是否正常運行。
Target# lspci
圖 22
Target# insmod xdma-video.ko debug=1
備注:“debug=1”表示打印幀率信息,可根據(jù)實際需求選擇是否配置。若需修改分辨率和幀率,可執(zhí)行命令“insmod xdma-video.ko width=1280 height=1024 fps=60”,具體的分辨率和幀率大小,請以相機實際可支持范圍為準,分辨率參數(shù)需和相機分辨率參數(shù)匹配,幀率參數(shù)僅作用于軟件上相機參數(shù),不影響實際的相機幀率。
圖 23
執(zhí)行如下命令進行圖像的采集、編碼和顯示,編碼后的test.264文件將保存在當前目錄下。
Target# gst-launch-1.0 -v -e v4l2src device=/dev/video1 ! "video/x-raw, format=(string)NV12, width=(int)1280, height=(int)1024" ! tee name=t ! queue ! vpuenc_h264 ! h264parse ! filesink location=test.264 t. ! queue ! waylandsink
其中"/dev/video1"為設備節(jié)點,請以實際節(jié)點為準,1280和1024為圖像的寬和高。
圖 24
執(zhí)行成功后可觀察到如下輸出,串口不停打印幀率,并在HDMI顯示器上觀看到實時圖像。
備注:幀率顯示為61fps,是由于CameraLink相機輸出的并不是標準的60fps圖像。
圖 25
圖 26
按下“Ctrl C”停止錄制后,將在當前目錄生成test.264文件,并可觀察到實際幀率為59.954fps。
圖 27
執(zhí)行如下命令播放編碼后的視頻,HDMI顯示器顯示對應圖像。
Target# gst-play-1.0 test.264
圖 28
圖 29
播放結(jié)束后,將打印視頻時長、幀率信息。
圖 30
備注:由于碼流文件中不包含播放幀率信息,因此在執(zhí)行“gst-play-1.0 test.264”時未能按60fps進行播放。從串口打印信息可知,實際是以30fps進行播放,并且播放時長為錄制時長的兩倍。在錄制時,將H264碼流封裝成MP4格式可解決此問題,因為封裝成MP4格式時,播放幀率信息將被記錄在MP4文件中。
執(zhí)行如下命令,可將H264碼流保存成MP4文件。
Target# gst-launch-1.0 -v -e v4l2src device=/dev/video1 ! "video/x-raw, format=(string)NV12, width=(int)1280, height=(int)1024" ! tee name=t ! queue ! vpuenc_h264 ! h264parse ! qtmux ! filesink location=test.mp4 t. ! queue ! waylandsink
圖 31
圖 32
注意:H264碼流保存成MP4文件,程序可正常工作,錄制的視頻文件播放幀率正常,但系統(tǒng)會出現(xiàn)概率性的丟幀。為了避免這種情況,在實際的應用編程中,建議將MP4的保存功能另外建立一個pipeline進行,或改用其它開源MP4庫進行開發(fā)。
本站聲明: 本文章由作者或相關機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。
關鍵字:
阿維塔
塞力斯
華為
加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...
關鍵字:
AWS
AN
BSP
數(shù)字化
倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...
關鍵字:
汽車
人工智能
智能驅(qū)動
BSP
北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...
關鍵字:
亞馬遜
解密
控制平面
BSP
8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。
關鍵字:
騰訊
編碼器
CPU
8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。
關鍵字:
華為
12nm
EDA
半導體
8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。
關鍵字:
華為
12nm
手機
衛(wèi)星通信
要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...
關鍵字:
通信
BSP
電信運營商
數(shù)字經(jīng)濟
北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...
關鍵字:
VI
傳輸協(xié)議
音頻
BSP
北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...
關鍵字:
BSP
信息技術(shù)
山海路引?嵐悅新程 三亞2024年8月27日 /美通社/ --?近日,海南地區(qū)六家凱悅系酒店與中國高端新能源車企嵐圖汽車(VOYAH)正式達成戰(zhàn)略合作協(xié)議。這一合作標志著兩大品牌在高端出行體驗和環(huán)保理念上的深度融合,將...
關鍵字:
新能源
BSP
PLAYER
ASIA
上海2024年8月28日 /美通社/ -- 8月26日至8月28日,AHN LAN安嵐與股神巴菲特的孫女妮可?巴菲特共同開啟了一場自然和藝術(shù)的療愈之旅。 妮可·巴菲特在療愈之旅活動現(xiàn)場合影 ...
關鍵字:
MIDDOT
BSP
LAN
SPI
8月29日消息,近日,華為董事、質(zhì)量流程IT總裁陶景文在中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式上表示,中國科技企業(yè)不應怕美國對其封鎖。
關鍵字:
華為
12nm
EDA
半導體
上海2024年8月26日 /美通社/ -- 近日,全球領先的消費者研究與零售監(jiān)測公司尼爾森IQ(NielsenIQ)迎來進入中國市場四十周年的重要里程碑,正式翻開在華發(fā)展新篇章。自改革開放以來,中國市場不斷展現(xiàn)出前所未有...
關鍵字:
BSP
NI
SE
TRACE
上海2024年8月26日 /美通社/ -- 第二十二屆跨盈年度B2B營銷高管峰會(CC2025)將于2025年1月15-17日在上海舉辦,本次峰會早鳥票注冊通道開啟,截止時間10月11日。 了解更多會議信息:cc.co...
關鍵字:
BSP
COM
AI
INDEX
上海2024年8月26日 /美通社/ -- 今日,高端全合成潤滑油品牌美孚1號攜手品牌體驗官周冠宇,開啟全新旅程,助力廣大車主通過駕駛?cè)ヌ剿鞲鼜V闊的世界。在全新發(fā)布的品牌視頻中,周冠宇及不同背景的消費者表達了對駕駛的熱愛...
關鍵字:
BSP
汽車制造
此次發(fā)布標志著Cision首次為亞太市場量身定制全方位的媒體監(jiān)測服務。 芝加哥2024年8月27日 /美通社/ -- 消費者和媒體情報、互動及傳播解決方案的全球領導者Cis...
關鍵字:
CIS
IO
SI
BSP
上海2024年8月27日 /美通社/ -- 近來,具有強大學習、理解和多模態(tài)處理能力的大模型迅猛發(fā)展,正在給人類的生產(chǎn)、生活帶來革命性的變化。在這一變革浪潮中,物聯(lián)網(wǎng)成為了大模型技術(shù)發(fā)揮作用的重要陣地。 作為全球領先的...
關鍵字:
模型
移遠通信
BSP
高通
北京2024年8月27日 /美通社/ -- 高途教育科技公司(紐約證券交易所股票代碼:GOTU)("高途"或"公司"),一家技術(shù)驅(qū)動的在線直播大班培訓機構(gòu),今日發(fā)布截至2024年6月30日第二季度未經(jīng)審計財務報告。 2...
關鍵字:
BSP
電話會議
COM
TE
8月26日消息,華為公司最近正式啟動了“華為AI百校計劃”,向國內(nèi)高校提供基于昇騰云服務的AI計算資源。
關鍵字:
華為
12nm
EDA
半導體