衡阳派盒市场营销有限公司

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

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

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

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

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

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

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

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

Dump 寄存器:

通過以下網(wǎng)站下載QDMA driver, 運(yùn)行test app中的reg_dump指令來dump QDMA 寄存器的值和context data。

https://github.com/Xilinx/dma_ip_drivers

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

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

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

對dump出的寄存器進(jìn)行分析:

使用test app dump出的寄存器的數(shù)目太多,本文重點(diǎn)以下幾個寄存器進(jìn)行分析并舉例說明:

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的寄存器,涵蓋了許多重要信號的狀態(tài)信息,是非常重要的debug寄存器,每一個bit位代表的意義及寄存器默認(rèn)的數(shù)值如下:

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

在對寄存器的數(shù)值進(jìn)行分析時,需要重點(diǎn)關(guān)注3、4、5比特,當(dāng)3、4、5為低是表明IP并未遇到傳輸錯誤,那么錯誤應(yīng)該是發(fā)生在IP傳輸數(shù)據(jù)之前,需要對在數(shù)據(jù)傳輸前的驅(qū)動配置階段進(jìn)行分析和定位。

一般IP內(nèi)發(fā)生傳輸錯誤時,此寄存器的3、4、5位比特會被置高,當(dāng)wrq_packet_out_data_marker為高時,需要檢查在工程設(shè)計中是否使用了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的傳輸出現(xiàn)了不可修復(fù)的錯誤,需要通過其他的寄存器進(jìn)行進(jìn)一步的分析,通常在3、4、5bit被置為高時,此寄存器的0,1bit不會全為高,IP會掛起并停止數(shù)據(jù)的傳輸。IP的傳輸錯誤有可能是發(fā)送了過量的描述符,時序問題及邏輯設(shè)計的不規(guī)范,下面對在遇到IP 傳輸錯誤時的定位方法進(jìn)行舉例說明:

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

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

因?yàn)椴僮鞑划?dāng)導(dǎo)致IP發(fā)生丟包時,C2H_DROP_DESC_RSP_LEN,C2H_DROP_QID_FIFO_LEN和C2H_DROP_PLD_CNT 三個寄存器的數(shù)值分別為在IP丟包時:描述符的長度、Qid Fifo中的包長和負(fù)載Fifo 0中的信用值。當(dāng)IP發(fā)生丟包時,根據(jù)以上三個寄存器的前18bit的數(shù)值,會比較容易判斷驅(qū)動或者工程中可能存在的問題。

原文標(biāo)題:開發(fā)者分享|QDMA與driver的問題定位和分析

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

審核編輯:彭靜

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

    關(guān)注

    31

    文章

    5363

    瀏覽量

    121156
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    7139

    瀏覽量

    89573
  • bit
    bit
    +關(guān)注

    關(guān)注

    0

    文章

    48

    瀏覽量

    32057

原文標(biāo)題:開發(fā)者分享|QDMA與driver的問題定位和分析

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

收藏 人收藏

    評論

    相關(guān)推薦

    Modbus協(xié)議的讀取保持寄存器

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

    寄存器間接尋址和寄存器尋址的區(qū)別

    寄存器間接尋址和寄存器尋址是計算機(jī)體系結(jié)構(gòu)兩種重要的尋址方式,它們在指令執(zhí)行過程起著關(guān)鍵作用。下面將從定義、原理、特點(diǎn)、應(yīng)用場景以及區(qū)別等方面對這兩種尋址方式進(jìn)行詳細(xì)闡述。
    的頭像 發(fā)表于 10-05 17:13 ?2106次閱讀

    微處理寄存器的作用

    微處理寄存器是計算機(jī)體系結(jié)構(gòu)的核心組成部分,它們扮演著至關(guān)重要的角色。寄存器是一種高速的存儲單元,用于暫時存儲數(shù)據(jù)、指令和地址等信息
    的頭像 發(fā)表于 10-05 15:07 ?696次閱讀

    通用寄存器是什么意思

    在計算機(jī)體系結(jié)構(gòu),通用寄存器是中央處理(CPU)內(nèi)部最為核心和基礎(chǔ)的組成部分之一。它們被設(shè)計為能夠存儲和傳輸各種類型的數(shù)據(jù)和指令,是CPU進(jìn)行數(shù)據(jù)處理和運(yùn)算的關(guān)鍵工具。通用寄存器
    的頭像 發(fā)表于 09-05 14:13 ?1213次閱讀

    寄存器的類型和作用

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

    數(shù)字寄存器的原理和使用

    數(shù)字寄存器是計算機(jī)體系結(jié)構(gòu)至關(guān)重要的組成部分,其原理和使用對于理解計算機(jī)的工作原理和數(shù)據(jù)存儲方式具有重要意義
    的頭像 發(fā)表于 09-05 14:08 ?733次閱讀

    寄存器故障分析

    寄存器故障分析是計算機(jī)硬件維護(hù)與系統(tǒng)穩(wěn)定性保障的重要環(huán)節(jié)。寄存器作為計算機(jī)的關(guān)鍵組成部分,負(fù)責(zé)存儲和傳輸數(shù)據(jù),其穩(wěn)定性和可靠性直接影響到整個計算機(jī)系統(tǒng)的性能。以下是對
    的頭像 發(fā)表于 08-29 11:26 ?1274次閱讀

    寄存器是什么意思?寄存器是如何構(gòu)成的?

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

    寄存器尋址和直接尋址的區(qū)別

    寄存器尋址和直接尋址是計算機(jī)指令系統(tǒng)的兩種基本尋址方式。它們在指令的執(zhí)行過程起著至關(guān)重要的作用,決定了指令操作數(shù)的來源和目標(biāo)。下面我們將介紹這兩種尋址方式的特點(diǎn)、區(qū)別以及在實(shí)際應(yīng)用
    的頭像 發(fā)表于 07-12 10:42 ?2405次閱讀

    寄存器尋址的實(shí)現(xiàn)方式

    在計算機(jī)體系結(jié)構(gòu),寄存器尋址是一種常見的尋址方式,它允許程序直接訪問CPU內(nèi)部的寄存器。寄存器尋址可以提高程序的執(zhí)行效率,因?yàn)樗苊饬藢?nèi)存的訪問。
    的頭像 發(fā)表于 07-12 10:36 ?833次閱讀

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

    寄存器是計算機(jī)中用于存儲數(shù)據(jù)的高速存儲單元,它們是CPU內(nèi)部的重要組成部分。寄存器可以分為基本寄存器和擴(kuò)展寄存器兩種類型。 一、基本寄存器
    的頭像 發(fā)表于 07-12 10:31 ?1618次閱讀

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

    移位寄存器是一種在數(shù)字電路和計算機(jī)科學(xué)中廣泛使用的存儲設(shè)備,它可以用來存儲和傳輸數(shù)據(jù)。在移位寄存器,數(shù)據(jù)可以通過移位操作來實(shí)現(xiàn)數(shù)據(jù)的傳輸和處理。移位寄存器的移位操作有兩種基本形式:左
    的頭像 發(fā)表于 07-12 10:14 ?1758次閱讀

    寄存器和內(nèi)存的區(qū)別

    在計算機(jī)體系結(jié)構(gòu)寄存器和內(nèi)存是兩個至關(guān)重要的組成部分。它們各自承擔(dān)著不同的角色,共同確保計算機(jī)系統(tǒng)的正常運(yùn)行。本文將對寄存器和內(nèi)存進(jìn)行詳細(xì)的介紹,包括它們的定義、功能以及二者之間的主要區(qū)別。
    的頭像 發(fā)表于 05-12 17:11 ?2574次閱讀

    干貨滿滿:ARM的內(nèi)核寄存器講解

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

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

    無論是FPGA還是ASIC,系統(tǒng)設(shè)計總會存在配置寄存器總線的使用,我們會將各種功能、調(diào)試寄存器掛載在寄存器總線上使用。
    的頭像 發(fā)表于 03-04 13:56 ?1247次閱讀
    如何根據(jù)自己設(shè)計<b class='flag-5'>中</b>的<b class='flag-5'>寄存器</b>配置總線定義來生成一套<b class='flag-5'>寄存器</b>配置模版
    百家乐官网打印机破解| 大三巴百家乐的玩法技巧和规则 | 大发888pt| 必博| 肇东市| 海淀区| 申博百家乐官网公式软件| 都坊百家乐官网的玩法技巧和规则| 百家乐园zyylc| 百家乐网页游戏网址| 运城百家乐的玩法技巧和规则| 元游棋牌游戏大厅| 棋牌游戏网| 百家乐官网取胜秘笈| 百家乐官网白菜价| 百家乐官网三宝| 去澳门百家乐官网的玩法技巧和规则| 浩博百家乐娱乐城| 威尼斯人娱乐城总部| 迭部县| 362百家乐官网的玩法技巧和规则 大集汇百家乐官网的玩法技巧和规则 | 广东百家乐桌布| 大发888娱乐场网页| 百家乐官网视频软件| 百家乐官网下注法| 威尼斯人娱乐城投注| 菲律宾太阳城88| 百家乐官网网投开户| 百家乐官网特殊计| 威尼斯人娱乐场图片| 百家乐官网娱乐开户| 新濠百家乐官网的玩法技巧和规则 | 盈得利百家乐娱乐城| 青神县| 破解百家乐官网真人游戏| 网络百家乐游戏机怎么破解| 云鼎百家乐作弊| 国外合法赌博网站| 莫斯科百家乐官网的玩法技巧和规则 | 金牌百家乐的玩法技巧和规则| 波音现金网投注|