国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

在SpinalHDL中如何優雅地實現寄存器總線讀寫

FPGA之家 ? 來源:CSDN技術社區 ? 作者:weixin_39611666 ? 2021-04-08 17:28 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

對于FPGA系統設計里,寄存器控制通道的設計是系統控制中必不可少的部分。今日且看SpinalHDL中如何優雅地實現寄存器總線讀寫。

Bus Slave Factory

在SpinalHDL里,其Libraries里提供了關于總線相關的庫。包含AMBA3、AMBA4、AVALON等總線類型,并提供了bus slave factory工具:

1bb53004-95c8-11eb-8b86-12bb97331649.png

通過bus slave factory,我們可以方便地實現寄存器讀寫,其提供了一系列寄存器讀寫方法。這里列舉幾個常用的方法(完整的方法列表可參照SpinalHDL-Doc):

read(that,address,bitOffset)

注冊寄存器讀操作到指定地址,比特偏移為bitOffset 。

write(that,address,bitOffset)

注冊寄存器寫操作到指定地址,比特偏移為bitOffset。

readAndWrite(that,address,bitOffset)

注冊寄存器讀寫操作到指定地址,比特偏移為bitOffset 。

readMultiWord(that,address)

注冊大位寬寄存器(超過總線數據位寬)讀操作到指定地址,其中address地址存放對應低比特,高比特地址向上累加。

writeMultiWord(that,address)

注冊大位寬寄存器(超過總線數據位寬)寫操作到指定地址,其中address地址存放對應低比特,高比特地址向上累加。

除此之外,bus slave factory還提供了printDataModel函數用于打印寄存器列表。而且在生成RTL時,其會自動檢測寄存器地址是否存在沖突。

AXI4-Lite總線實現

這里以AXI4-Lite總線舉例,通過AXI4-Lite總線讀寫三組寄存器:

en:單比特信號,可讀可寫。

plus:單比特信號,可讀寫,寫1自動清零。

cnt:64比特信號,可讀。

這里給出完整的代碼結構:

1be7147a-95c8-11eb-8b86-12bb97331649.png

這里代碼5~10行代碼聲明模塊端口,第12行代碼規范AXI4-Lite端口名稱。代碼第15~18行通過slave factory實現AXI4-Lite寄存器讀寫。代碼第19行打印輸出寄存器列表。

由于plus寫1清零,因此代碼14行用于實現清零操作。

通過下面的語法生成RTL代碼:

1c02ad02-95c8-11eb-8b86-12bb97331649.png

在生成RTL代碼的同時,會打印寄存器列表:

1c513a62-95c8-11eb-8b86-12bb97331649.png

仿真結果

SpinalHDL里提供了AXI4-Lite總線的基礎仿真庫,這里直接調用其仿真庫,完整的仿真代碼如下:

1c5fa5ac-95c8-11eb-8b86-12bb97331649.png

通過gtkWave觀察波形:

1cfc2076-95c8-11eb-8b86-12bb97331649.png

可以看到,功能符合我們的設計,寫寄存器0x4信號plus拉高1個時鐘周期后自動清零。 這里簡單幾行代碼實現了AXI4-Lite總線控制寄存器讀寫,對于我們在真正的項目實現里,能夠極大簡化我們的工作量和bug產生。盡管現在各個大廠或許有專門的總線控制寄存器讀寫代碼生成工具,但SpinalHDL這種形式從本質上解決了Verilog描述的重復性工作。

寫在最后

雖然SpinalHDL這種slave factory工具能夠讓我們在工程中快捷的實現想要的功能,但對于初學者來說,理解掌握AXI4-Lite這些標準的總線協議時序還是非常有必要的(Verilog or SpinalHDL實現都行嘍)~
編輯:lyn

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

    關注

    1660

    文章

    22412

    瀏覽量

    636393
  • 寄存器
    +關注

    關注

    31

    文章

    5608

    瀏覽量

    130001

原文標題:SpinalHDL—優雅地實現總線寄存器讀寫

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    RDMA設計38:寄存器功能驗證與分析

    。由于DUT寄存器數量較多,這里用全局計數寄存器為例說明寄存器功能驗證過程。對于寄存器的仿真需要考慮
    發表于 02-09 10:26

    請問如何實現C語言訪問MCU寄存器

    單片機的特殊功能寄存器SFR,是SRAM地址已經確定的SRAM單元,C語言環境下對其訪問歸納起來有兩種方法。 采用標準C的強制類型轉換和指針來實現   采用標準C的強制轉換和指針的概念來實現
    發表于 12-26 07:00

    匯編寄存器的知識

    學習匯編語言,首先必須了解兩個知識點:寄存器和內存模型。 先來看寄存器。CPU 本身只負責運算,不負責儲存數據。數據一般都儲存在內存之中,CPU 要用的時候就去內存讀寫數據。 但是,CPU
    發表于 11-20 06:45

    嵌入式系統必懂的 20 個寄存器

    了嵌入式系統開發者必懂的20個寄存器,讓你快速掌握MCU的核心操作方法。01寄存器基礎寄存器是CPU內部用于高速存取數據的小容量存儲單元,是計算機執行指令、處理
    的頭像 發表于 11-14 10:28 ?1110次閱讀
    嵌入式系統必懂的 20 個<b class='flag-5'>寄存器</b>

    基于hbirdv2的APB總線添加外設(二)

    的要求設計APB總線接口。其次,需要根據外設的需要來設計對應外設的寄存器,如定義一些只讀、讀寫寄存器等。寄存器后級的具體算法需根據自己算法需
    發表于 10-29 07:49

    基于hbirdv2的APB總線添加外設(三)

    main.c即可實現寄存器讀寫。 讀: 寫: 方法二: (1)hbirdv2.h添加
    發表于 10-29 06:39

    E203添加浮點數方法:寄存器設計

    決這個問題,根據浮點 CSR 的讀寫指令由普通 CSR 讀寫指令實現的特點,筆者 CSR 寄存器
    發表于 10-24 13:25

    蜂鳥內核DMA的硬件實現——寄存器配置

    :DMA寄存器的配置、讀寫模塊和fifo。 這里主要分享對DMA寄存器配置的分析討論。 寄存器配置 開始傳輸前,DMA控制
    發表于 10-24 08:46

    DMA硬件實現——讀寫實現

    寄存器、長度寄存器回到初始狀態0,狀態寄存器回到初始狀態111。 此外,由于這里一次進行16個數據的讀寫,需要一個fifo模塊存放數據。這里例化了fifo。下一小部分具體闡述fifo
    發表于 10-24 07:58

    NVMe高速傳輸之擺脫XDMA設計31: 寄存器功能驗證與分析1

    待測設計, 系統控制模塊寄存器通過 AXI4-Lite 接口訪問, 該接口與axi4_lite_agent 對應, 因此可以直接在測試用例
    發表于 09-30 10:01

    ?SN74HCT595 8位移位寄存器技術解析與應用指南

    Texas Instruments SN74HCT595/SN74HCT595-Q1 8位移位寄存器包含8位串進并出移位寄存器,向8位D類存儲寄存器饋送信號。存儲寄存器具有并行 3 狀
    的頭像 發表于 09-19 14:31 ?956次閱讀
    ?SN74HCT595 8位移位<b class='flag-5'>寄存器</b>技術解析與應用指南

    TPIC6595 8位功率移位寄存器技術文檔摘要

    該TPIC6595是一款單片、高壓、大電流功率的8位移位寄存器,設計用于需要相對較高負載功率的系統。該器件輸出端包含一個內置電壓鉗位,用于電感瞬態保護。功率驅動應用包括繼電器、螺線管和其他
    的頭像 發表于 09-09 11:10 ?929次閱讀
    TPIC6595 8位功率移位<b class='flag-5'>寄存器</b>技術文檔摘要

    ?TPIC6B595 8位功率移位寄存器技術文檔總結

    TPIC6B595器件是一款單片、高壓、電流功率8位移位寄存器,設計用于需要相對高負載功率的系統。該器件輸出端包含一個內置電壓鉗位,用于電感瞬態保護。功率驅動應用包括繼電器、螺線
    的頭像 發表于 09-09 10:16 ?1014次閱讀
    ?TPIC6B595 8位功率移位<b class='flag-5'>寄存器</b>技術文檔總結

    ?TLC6C5912 12通道移位寄存器LED驅動技術文檔總結

    該TLC6C5912是一款單片、壓、低電流功率 12 位移位寄存器 設計用于需要相對中等負載功率的系統,例如 LED。 該器件包含一個 12 位串行輸入并行輸出移位寄存器,可為 12 位饋電
    的頭像 發表于 08-26 14:16 ?1003次閱讀
    ?TLC6C5912 12通道移位<b class='flag-5'>寄存器</b>LED驅動<b class='flag-5'>器</b>技術文檔總結

    使用寄存器點亮LED燈

    學習本章時,配合以上芯片手冊的“19. I/O Ports”章節一起閱讀,效果會更佳,特別是涉及到寄存器說明的部分。本章內容涉及到較多寄存器方面的深入內容,對于初學者而言這些內容豐富也較難理解,但非常有必要細讀研究、夯實基礎。
    的頭像 發表于 05-28 17:37 ?1323次閱讀
    使用<b class='flag-5'>寄存器</b>點亮LED燈