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

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創作中心

完善資料讓更多小伙伴認識你,還能領取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
    +關注

    關注

    1644

    文章

    22004

    瀏覽量

    616258
  • 寄存器
    +關注

    關注

    31

    文章

    5429

    瀏覽量

    123880

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    74ALVCH16646 16位總線收發/寄存器規格書

    電子發燒友網站提供《74ALVCH16646 16位總線收發/寄存器規格書.pdf》資料免費下載
    發表于 02-19 15:44 ?0次下載
    74ALVCH16646 16位<b class='flag-5'>總線</b>收發<b class='flag-5'>器</b>/<b class='flag-5'>寄存器</b>規格書

    使用ads1298時,部分寄存器讀寫不正常,為什么?

    你好,我使用ads1298時遇到了如下問題,希望可以解答: (1)部分寄存器讀寫不正常,寄存器讀寫
    發表于 02-13 08:24

    調試ads1192、ads1198等系列的芯片中,發現寄存器上報的導聯狀態一直處于不穩定狀態,為什么?

    我們調試ads1192、ads1198等系列的芯片中,發現寄存器上報的導聯狀態一直處于不穩定狀態。導聯連上時,寄存器可以上報穩定的連上狀態,但是當脫落時,發現導聯寄存器上報的狀態一
    發表于 11-20 06:25

    接口的控制與狀態寄存器什么作用

    的行為并獲取硬件的狀態信息。 接口的控制與狀態寄存器的作用 現代計算機系統,硬件設備與軟件之間的交互是通過一系列的接口來實現的。這些接口不僅需要能夠傳輸數據,還需要能夠控制硬件設備
    的頭像 發表于 10-17 10:42 ?1468次閱讀

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

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

    微處理寄存器的作用

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

    通用寄存器是什么意思

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

    寄存器的類型和作用

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

    寄存器故障分析

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

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

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

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

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

    寄存器尋址的實現方式

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

    寄存器有哪幾種?可以實現什么功能?

    寄存器是計算機中用于存儲數據和指令的高速存儲設備,是計算機硬件的重要組成部分。寄存器的種類很多,不同的寄存器具有不同的功能。 通用寄存器(General-Purpose Registe
    的頭像 發表于 07-12 10:32 ?2234次閱讀

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

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

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

    移位寄存器是一種在數字電路和計算機科學中廣泛使用的存儲設備,它可以用來存儲和傳輸數據。移位寄存器,數據可以通過移位操作來實現數據的傳輸和
    的頭像 發表于 07-12 10:14 ?2953次閱讀
    主站蜘蛛池模板: 亚洲欧美日韩国产另类电影 | 色婷婷激情AV精品影院 | 天美传媒果冻传媒入口视频 | 蜜柚影院在线观看免费高清中文 | 午夜办公室在线观看高清电影 | 亚洲欧美综合中文字幕 | 欧美牲交A欧美牲交VDO | 欧美一区二区三区免费播放 | 午夜在线观看免费完整直播网页 | 嘴巴舔着她的私处插 | 国产亚洲视频中文字幕 | 8x8x我要打机飞在线观看 | 5g天天影院天天看天天爽 | 久久中文字幕无线观看 | 娇妻中日久久持久久 | 国产色精品久久人妻99蜜桃麻豆 | 大学生高潮无套内谢视频 | 国产精品视频第一区二区三区 | 国产人妻人伦精品9 | 久热人人综合人人九九精品视频 | 乡土女性网动态图解 | 4hu四虎免费影院www | 亚洲国产成人精品不卡青青草原 | 国产免费久久精品国产传媒 | 70岁妇女牲交色牲片 | 国产三级影院 | 99er久久国产精品在线 | 儿子操妈妈视频 | se01国产短视频在线观看 | 日产久久视频 | 国产在线一区二区三区四区 | 国产99久久久欧美黑人刘玥 | 蜜桃狠狠色伊人亚洲综合网站 | 精品久久久久久电影网 | 你是淫荡的我的女王 | 好大快用力深一点h视频 | 世界第一黄暴漫画家 | 国产精品看高国产精品不卡 | 囯产免费久久久久久国产免费 | 亚洲免费每日在线观看 | 色呦呦人人视频 |

    電子發燒友

    中國電子工程師最喜歡的網站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品