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

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

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

Petalinux加速axi-dma內(nèi)核驅(qū)動(dòng)緩沖區(qū)讀過(guò)程

C29F_xilinx_inc ? 來(lái)源:賽靈思 ? 作者:賽靈思 ? 2022-02-16 16:21 ? 次閱讀

1、參考https://forums.xilinx.com/t5/%E5%B5%8C%E5%85%A5%E5%BC%8F-%E7%A1%AC%E4%BB...

按照官方說(shuō)明,copy數(shù)據(jù)速率基本為系統(tǒng)ddr的帶寬。

2、工程 生成數(shù)據(jù)大小2048X2048 4MB 也就是一次dma數(shù)據(jù)大小,一次dma數(shù)據(jù)的大小與axi-dma核中buffer lenght registr有關(guān),長(zhǎng)度最大26,也就是2^26個(gè)字節(jié),為64MB,工程中加入ila核用來(lái)調(diào)試。

poYBAGIMpTyAYJvtAAJCVgOdWlk847.png

3、生成bit后,導(dǎo)出xsa文件。
4、在vitis中應(yīng)用xsa文件,新建a5_zynqmp_fsbl工程,按照官方說(shuō)明,修改sfsbl_main.c,并編譯,在debug文件夾中可以找到a5_zynqmp_fsbl.elf文件。

poYBAGIMpT6AG_TAAAU0cuw5eRo039.png

5、在petalinux環(huán)境中新建工程,參考以前的博客,直到petalinux-build。
6、修改設(shè)備樹(shù)

poYBAGIMpT-AaMEDAAGzAPp__24370.png

7、重新petalinux-build。
8、在image/linux文件夾下

pYYBAGIMpUGAAOv_AAH9HYEgbjE594.png

9、拷貝出bl31.elf boot.scr image.ub pmufw.elf system.bit system.dtb u-boot.elf 七個(gè)文件,以及vitis中生成的a5_zynqmp_fsbl.elf共8個(gè)文件,到linux_dma_test.
10、在petalinux工程中,build文件夾中拷貝bootgen.bif文件,并修改成如下

poYBAGIMpUOAVpOTAADAWGY0B3U139.png

11、新建regs.init

pYYBAGIMpUSAUO1OAAAxkZn3Sl0889.png

12、生成BOOT.BIN,然后一起將BOOT.BIN image.ub和boot.scr復(fù)制到sd卡。

poYBAGIMpUWAfNwZAADSrgahF0g870.png

13、測(cè)試

poYBAGIMpUeALBDKAAC60ij8J_A905.png

pYYBAGIMpUmAYEEzAAJCH3rUgI8607.png

14、上電開(kāi)機(jī),加載axi-dma的驅(qū)動(dòng),將3.0U盤掛在到mnt下

poYBAGIMpUyAJ250AAEGdErzqQs418.png

由以上可以看出,pl生成一張4MB的數(shù)據(jù)耗時(shí)43ms,將4MB數(shù)據(jù)由dma讀緩沖區(qū)copy到內(nèi)核緩沖區(qū)耗時(shí)4ms,基本接近ddr的帶寬。整個(gè)鏈路中的帶寬完全受限于U盤的存儲(chǔ)速度。

15、U盤中的圖片,大小128MB,數(shù)據(jù)正確。

poYBAGIMpVmADcOWABP3Mu4LBzg213.png

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

    關(guān)注

    1

    文章

    556

    瀏覽量

    24642
  • 編譯
    +關(guān)注

    關(guān)注

    0

    文章

    647

    瀏覽量

    32743
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    內(nèi)存緩沖區(qū)和內(nèi)存的關(guān)系

    內(nèi)存緩沖區(qū)和內(nèi)存之間的關(guān)系是計(jì)算機(jī)體系結(jié)構(gòu)中一個(gè)至關(guān)重要的方面,它們共同協(xié)作以提高數(shù)據(jù)處理的效率和系統(tǒng)的整體性能。
    的頭像 發(fā)表于 09-10 14:38 ?286次閱讀

    單片機(jī)中的幾種環(huán)形緩沖區(qū)的分析和實(shí)現(xiàn)

    單片機(jī)中的幾種環(huán)形緩沖區(qū)的分析和實(shí)現(xiàn)一、簡(jiǎn)介環(huán)形緩沖區(qū)(RingBuffer)是一種高效的使用內(nèi)存的方法,它將一段固定長(zhǎng)度的內(nèi)存看成一個(gè)環(huán)形結(jié)構(gòu),用于存儲(chǔ)數(shù)據(jù),能夠避免使用動(dòng)態(tài)申請(qǐng)內(nèi)存導(dǎo)致的內(nèi)存碎片
    的頭像 發(fā)表于 08-14 08:39 ?538次閱讀
    單片機(jī)中的幾種環(huán)形<b class='flag-5'>緩沖區(qū)</b>的分析和實(shí)現(xiàn)

    ESP8266有雙緩沖區(qū)嗎?

    我想實(shí)時(shí)傳輸一些信號(hào)的測(cè)量數(shù)據(jù)。信號(hào)的采樣周期為 1 ms。我想每 500 毫秒發(fā)送 2048 字節(jié)(一個(gè)數(shù)據(jù)包)。ESP8266有雙緩沖區(qū)(2x 2048字節(jié))嗎?其想法是計(jì)數(shù)填充一個(gè)緩沖區(qū)(周期
    發(fā)表于 07-16 07:29

    創(chuàng)建DMA通道時(shí),能否將DMA緩沖區(qū)的大小指定為8字節(jié),并將DMA緩沖區(qū)的編號(hào)指定為1?

    創(chuàng)建 DMA 通道時(shí),能否將 DMA 緩沖區(qū)的大小指定為 8 字節(jié),并將 DMA 緩沖區(qū)的編號(hào)指定為 1?
    發(fā)表于 05-31 07:46

    stm32野火開(kāi)發(fā)板上做USB通信,PC端USB的緩沖區(qū)和串口緩沖區(qū)的大小是多少?

    ADC采集的波形還原,也就是畫(huà)圖。 我就不明白,安裝的驅(qū)動(dòng)作用是?修改了PID和VID。 還有PC端的USB作用不是太明白?是一下那種情況: 1、stm32端傳過(guò)來(lái)的數(shù)據(jù)根本沒(méi)有經(jīng)過(guò)USB的緩沖區(qū),而是
    發(fā)表于 05-17 14:02

    Stm32采用環(huán)形緩沖區(qū)接收rk3588的數(shù)據(jù)代碼

    Stm32采用環(huán)形緩沖區(qū)接收rk3588的數(shù)據(jù)代碼
    的頭像 發(fā)表于 05-15 10:10 ?435次閱讀

    交換機(jī)與路由器緩沖區(qū):尋找完美大小

    *本文系SDNLAB編譯自瞻博網(wǎng)絡(luò)技術(shù)專家兼高級(jí)工程總監(jiān)Sharada Yeluri領(lǐng)英 在路由器和交換機(jī)中,緩沖區(qū)至關(guān)重要,可以防止網(wǎng)絡(luò)擁塞期間的數(shù)據(jù)丟失。緩沖區(qū)到底要多大?這個(gè)問(wèn)題在
    的頭像 發(fā)表于 04-11 16:56 ?917次閱讀
    交換機(jī)與路由器<b class='flag-5'>緩沖區(qū)</b>:尋找完美大小

    交換芯片緩沖區(qū)大小是什么

    交換芯片緩沖區(qū)大小并不一定是固定的。緩沖區(qū)的設(shè)計(jì)和實(shí)現(xiàn)會(huì)根據(jù)芯片的具體型號(hào)、規(guī)格以及應(yīng)用場(chǎng)景的不同而有所差異。一些交換芯片可能具有固定大小的緩沖區(qū),以滿足特定的性能需求或成本限制。然而,隨著技術(shù)
    的頭像 發(fā)表于 03-18 14:42 ?462次閱讀

    使用UART FIFO緩沖區(qū)時(shí),緩沖區(qū)中的數(shù)據(jù)有時(shí)會(huì)損壞的原因?

    我在使用 UART FIFO 緩沖區(qū)時(shí)遇到了以下問(wèn)題。 問(wèn)題描述: 當(dāng)通過(guò)兩個(gè) UART 通道使用完整的 UART FIFO 緩沖區(qū)并通過(guò)兩個(gè)通道進(jìn)行通信時(shí),緩沖區(qū)中的數(shù)據(jù)有時(shí)會(huì)損壞,例如,UART
    發(fā)表于 03-06 06:59

    沒(méi)有辦法通過(guò)FX3固件檢查緩沖區(qū)是卡住了還是已滿?

    我正在嘗試通過(guò)多通道 DMA 緩沖區(qū)直播 1080p60 視頻,但是我們遇到了一個(gè)問(wèn)題,即在向 FX3 寫(xiě)入一定數(shù)量的緩沖區(qū)之后,我們看到當(dāng)前線程 WATERMARK 和 READY 標(biāo)志保持不變
    發(fā)表于 02-23 08:01

    xmc7100 DMA為什么沒(méi)有將ADC數(shù)據(jù)寄存器值傳送到存儲(chǔ)器緩沖區(qū)?

    我使用的是 xmc7100 芯片,為什么 DMA 沒(méi)有將 ADC 數(shù)據(jù)寄存器值傳送到存儲(chǔ)器緩沖區(qū)
    發(fā)表于 01-29 08:33

    西門子博診斷緩沖區(qū)的使用方法

    可從在線和診斷視圖中“診斷”文件夾的“診斷緩沖區(qū)”組中讀出 CPU 的診斷緩沖區(qū)。
    的頭像 發(fā)表于 12-11 10:24 ?3490次閱讀
    西門子博診斷<b class='flag-5'>緩沖區(qū)</b>的使用方法

    使用malloc建立緩沖區(qū)時(shí)出現(xiàn)錯(cuò)誤怎么解決?

    ,我不知道現(xiàn)在這個(gè)已知系統(tǒng)的中斷頻率,所以我做了一個(gè)偷懶的想法,先把輸入數(shù)據(jù)3秒的數(shù)據(jù)放在自建的緩沖區(qū),再將這個(gè)數(shù)據(jù)處理后再輸出,延時(shí)大概3s數(shù)據(jù)的時(shí)間,現(xiàn)在但是使用malloc建立緩沖區(qū)時(shí)出現(xiàn)錯(cuò)誤,請(qǐng)問(wèn),怎么拯救?
    發(fā)表于 11-30 07:39

    操作系統(tǒng)不同的緩沖區(qū)概念

    常常聽(tīng)到有程序員會(huì)跟你討論:“我們?cè)谧x寫(xiě)文件的時(shí)候,系統(tǒng)是有緩存的”。但實(shí)際上有一部分人把用戶進(jìn)程緩存區(qū)和系統(tǒng)空間緩存區(qū)的概念混淆了,包括這兩種緩沖區(qū)的用法和所要解決的問(wèn)題,還有其它類似的概念。本文
    的頭像 發(fā)表于 11-10 10:38 ?1147次閱讀
    操作系統(tǒng)不同的<b class='flag-5'>緩沖區(qū)</b>概念

    C++環(huán)形緩沖區(qū)設(shè)計(jì)與實(shí)現(xiàn)

    一、環(huán)形緩沖區(qū)基礎(chǔ)理論解析(Basic Theory of Circular Buffer) 1.1 環(huán)形緩沖區(qū)的定義與作用(Definition and Function of Circular
    的頭像 發(fā)表于 11-09 11:21 ?1629次閱讀
    C++環(huán)形<b class='flag-5'>緩沖區(qū)</b>設(shè)計(jì)與實(shí)現(xiàn)