色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

如何Dump IP中的寄存器及寄存器的意義

OpenFPGA ? 來源:賽靈思工程師 ? 作者:Fancheng Meng ? 2022-07-15 09:09 ? 次閱讀

QDMA的驅動在進行版本升級時,可能會對部分寄存器的數值進行變更,用戶如果要進行升級,推薦升級到最新的Vivado和驅動版本。如果驅動和Vivado之間的版本相差較大,有時會遇到c2h_cmpt_ready為0的情況,此時IP無法進行數據的傳輸,這種情況通常在傳輸大包或者大流量數據的時會出現,遇到這種情況可將QDMA IP的prefetch depth參數進行修改,以改善傳輸性能。

77a91c7c-03d6-11ed-ba43-dac502259ad0.png

如果是IP在傳輸中發生了錯誤或者出現了丟包的情況,就需要使用ILA IP來抓取QDMA IP中的信號和Dump QDMA IP中的寄存器來進行分析,下面重點講解下如何Dump IP中的寄存器、重點對哪些寄存器進行分析以及寄存器的意義。

Dump 寄存器:

通過以下網站下載QDMA driver, 運行test app中的reg_dump指令來dump QDMA 寄存器的值和context data。

https://github.com/Xilinx/dma_ip_drivers

寄存器的dump操作可以參考下面網址中的user guide界面。
https://xilinx.github.io/dma_ip_drivers/master/QDMA/DPDK/html/userguide.html

寄存器數值代表的意義可以從在PG302的124頁的Register Reference File可以下載到,如下圖所示:

77b6b4e0-03d6-11ed-ba43-dac502259ad0.png ? ?

對dump出的寄存器進行分析:

使用test app dump出的寄存器的數目太多,本文重點以下幾個寄存器進行分析并舉例說明:

QDMA_C2H_STAT_DEBUG_DMA_ENG_3
QDMA_C2H_STAT_DEBUG_DMA_ENG_4
C2H_DROP_DESC_RSP_LEN
C2H_DROP_QID_FIFO_LEN
C2H_DROP_PLD_CNT
QDMA_C2H_STAT_DEBUG_DMA_ENG_3 是一個32 bit的寄存器,涵蓋了許多重要信號的狀態信息,是非常重要的debug寄存器,每一個bit位代表的意義及寄存器默認的數值如下:

77c56490-03d6-11ed-ba43-dac502259ad0.png

在對寄存器的數值進行分析時,需要重點關注3、4、5比特,當3、4、5為低是表明IP并未遇到傳輸錯誤,那么錯誤應該是發生在IP傳輸數據之前,需要對在數據傳輸前的驅動配置階段進行分析和定位。

一般IP內發生傳輸錯誤時,此寄存器的3、4、5位比特會被置高,當wrq_packet_out_data_marker為高時,需要檢查在工程設計中是否使用了s_axis_c2h_cmpt_ctrl_no_wrb_marker信號,此信號的意義如下:
The DMA also has an option not to send completion information to completion ring during a
Marker packet. Port s_axis_c2h_cmpt_ctrl_no_wrb_marker can be set during a marker
packet. This option disables any write to completion ring when that Marker packet is generated.
When this signal is set for a Maker packet, the DMA has no data or completion transfers, but will
respond with maker response on qsts_out_op[7:0].

如果沒有使用此信號,說明IP的傳輸出現了不可修復的錯誤,需要通過其他的寄存器進行進一步的分析,通常在3、4、5bit被置為高時,此寄存器的0,1bit不會全為高,IP會掛起并停止數據的傳輸。IP的傳輸錯誤有可能是發送了過量的描述符,時序問題及邏輯設計的不規范,下面對在遇到IP 傳輸錯誤時的定位方法進行舉例說明:

當發現QDMA_C2H_STAT_DEBUG_DMA_ENG_3的3,4,5比特為高時,可以去查找與丟包相關的寄存器,例如:C2H_DROP_DESC_RSP_LEN,C2H_DROP_QID_FIFO_LEN和C2H_DROP_PLD_CNT。這三個寄存器所代表的意義分別如下所示:

77d7a7f4-03d6-11ed-ba43-dac502259ad0.png

因為操作不當導致IP發生丟包時,C2H_DROP_DESC_RSP_LEN,C2H_DROP_QID_FIFO_LEN和C2H_DROP_PLD_CNT 三個寄存器的數值分別為在IP丟包時:描述符的長度、Qid Fifo中的包長和負載Fifo 0中的信用值。當IP發生丟包時,根據以上三個寄存器的前18bit的數值,會比較容易判斷驅動或者工程中可能存在的問題。

原文標題:開發者分享|QDMA與driver的問題定位和分析

文章出處:【微信公眾號:OpenFPGA】歡迎添加關注!文章轉載請注明出處。

審核編輯:彭靜

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 寄存器
    +關注

    關注

    31

    文章

    5357

    瀏覽量

    120619
  • 數據
    +關注

    關注

    8

    文章

    7079

    瀏覽量

    89165
  • bit
    bit
    +關注

    關注

    0

    文章

    48

    瀏覽量

    32024

原文標題:開發者分享|QDMA與driver的問題定位和分析

文章出處:【微信號:Open_FPGA,微信公眾號:OpenFPGA】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Modbus協議的讀取保持寄存器

    功能碼用于讀取從設備保持寄存器的內容,不支持廣播模式。消息頓中指定了需要讀取的保持寄存器的起始地址和數目。而保持寄存器各地址的具體內容和意義
    的頭像 發表于 10-30 10:54 ?1561次閱讀

    寄存器間接尋址和寄存器尋址的區別

    寄存器間接尋址和寄存器尋址是計算機體系結構兩種重要的尋址方式,它們在指令執行過程起著關鍵作用。下面將從定義、原理、特點、應用場景以及區別等方面對這兩種尋址方式進行詳細闡述。
    的頭像 發表于 10-05 17:13 ?1759次閱讀

    通用寄存器是什么意思

    在計算機體系結構,通用寄存器是中央處理(CPU)內部最為核心和基礎的組成部分之一。它們被設計為能夠存儲和傳輸各種類型的數據和指令,是CPU進行數據處理和運算的關鍵工具。通用寄存器
    的頭像 發表于 09-05 14:13 ?1048次閱讀

    寄存器的類型和作用

    在計算機科學寄存器(Register)是一種高速存儲單元,它位于CPU內部,與CPU的運算單元和邏輯控制單元緊密相連。寄存器的主要作用是暫時存儲指令、操作數和地址等臨時數據,以便CPU快速訪問和處理。由于
    的頭像 發表于 09-05 14:11 ?2135次閱讀

    數字寄存器的原理和使用

    數字寄存器是計算機體系結構至關重要的組成部分,其原理和使用對于理解計算機的工作原理和數據存儲方式具有重要意義。
    的頭像 發表于 09-05 14:08 ?638次閱讀

    寄存器故障分析

    寄存器故障分析是計算機硬件維護與系統穩定性保障的重要環節。寄存器作為計算機的關鍵組成部分,負責存儲和傳輸數據,其穩定性和可靠性直接影響到整個計算機系統的性能。以下是對
    的頭像 發表于 08-29 11:26 ?1087次閱讀

    寄存器是什么意思?寄存器是如何構成的?

    在計算機科學,寄存器(Register)是一個高速存儲單元,它位于中央處理(CPU)內部,用于存儲計算機程序執行過程中所需要的數據、指令地址或狀態信息。寄存器是計算機體系結構
    的頭像 發表于 08-02 18:23 ?4421次閱讀
    <b class='flag-5'>寄存器</b>是什么意思?<b class='flag-5'>寄存器</b>是如何構成的?

    寄存器尋址和直接尋址的區別

    寄存器尋址和直接尋址是計算機指令系統的兩種基本尋址方式。它們在指令的執行過程起著至關重要的作用,決定了指令操作數的來源和目標。下面我們將介紹這兩種尋址方式的特點、區別以及在實際應用
    的頭像 發表于 07-12 10:42 ?2028次閱讀

    寄存器尋址的實現方式

    在計算機體系結構,寄存器尋址是一種常見的尋址方式,它允許程序直接訪問CPU內部的寄存器寄存器尋址可以提高程序的執行效率,因為它避免了對內存的訪問。
    的頭像 發表于 07-12 10:36 ?718次閱讀

    寄存器分為基本寄存器和什么兩種

    寄存器是計算機中用于存儲數據的高速存儲單元,它們是CPU內部的重要組成部分。寄存器可以分為基本寄存器和擴展寄存器兩種類型。 一、基本寄存器
    的頭像 發表于 07-12 10:31 ?1470次閱讀

    移位寄存器右移是怎么移位的

    移位寄存器是一種在數字電路和計算機科學中廣泛使用的存儲設備,它可以用來存儲和傳輸數據。在移位寄存器,數據可以通過移位操作來實現數據的傳輸和處理。移位寄存器的移位操作有兩種基本形式:左
    的頭像 發表于 07-12 10:14 ?1619次閱讀

    干貨滿滿:ARM的內核寄存器講解

    內核寄存器與外設寄存器: 內核寄存器與外設寄存器是完全不同的概念。內核寄存器是指 CPU 內部的寄存器
    發表于 04-17 11:47 ?3899次閱讀
    干貨滿滿:ARM的內核<b class='flag-5'>寄存器</b>講解

    如何根據自己設計寄存器配置總線定義來生成一套寄存器配置模版

    無論是FPGA還是ASIC,系統設計總會存在配置寄存器總線的使用,我們會將各種功能、調試寄存器掛載在寄存器總線上使用。
    的頭像 發表于 03-04 13:56 ?1168次閱讀
    如何根據自己設計<b class='flag-5'>中</b>的<b class='flag-5'>寄存器</b>配置總線定義來生成一套<b class='flag-5'>寄存器</b>配置模版

    CPU的6個主要寄存器

    CPU寄存器是中央處理內的組成部分,是有限存貯容量的高速存貯部件。寄存器是CPU內部的元件,包括通用寄存器、專用寄存器和控制
    的頭像 發表于 02-03 15:15 ?4500次閱讀

    移位寄存器的工作原理 移位寄存器左移和右移怎么算

    移位寄存器是一種用于在數字電路實現數據移位操作的基本電路元件。它由多個觸發以及相關控制電路組成,具有存儲、接受和移動數據的功能。移位寄存器可以分為兩種類型:串行移位
    的頭像 發表于 01-18 10:52 ?9040次閱讀
    主站蜘蛛池模板: 99视频国产在线| 国产色情短视频在线网站| 久久re6热在线视频精品| 亚洲色欲色欲WWW在线丝| 久久人妻少妇嫩草AV无码| 91天仙tv嫩模福利| 日本久久久久亚洲中字幕| 日本无码免费久久久精品| 国产成人免费不卡在线观看| 亚洲精品国产精品精| 蜜柚视频高清在线| 高清国产免费观看视频在线| 亚洲欧美韩国综合色| 嫩草www视频在线观看高清| 最新 国产 精品 精品 视频| 国产在线精品亚洲视频在线| 在线播放国产视频| 日本免费无码A专区在线观看| 好爽别插了无码视频| 亚洲精品国偷拍电影自产在线| 久久国产欧美| 邓奴的视频IVK| 少爷被多个暗卫肉高h| 精品视频网站| 战狼4在线观看完免费完整版| 欧美videqsdesex0| 国产偷啪自怕网| asian4you裸模| 一本之道加勒比在线观看| 口工漫画r18全彩啪啪| 国产AV国片精品无套内谢无码 | 国产爱豆果冻传媒在线观看视频| 国产精品伦一区二区三级视频| 日韩一区精品视频一区二区| 国产婷婷色一区二区三区在线| 99久久免费看少妇高潮A片| 欧美一夜爽爽爽爽爽爽| 好吊日视频在线| 俄罗斯老妇女BBXX| 999国产高清在线精品| 一本之道高清www在线观看|