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

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

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

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

在SpinalHDL中如何優(yōu)雅地實(shí)現(xiàn)寄存器總線讀寫

FPGA之家 ? 來(lái)源:CSDN技術(shù)社區(qū) ? 作者:weixin_39611666 ? 2021-04-08 17:28 ? 次閱讀

對(duì)于FPGA系統(tǒng)設(shè)計(jì)里,寄存器控制通道的設(shè)計(jì)是系統(tǒng)控制中必不可少的部分。今日且看SpinalHDL中如何優(yōu)雅地實(shí)現(xiàn)寄存器總線讀寫。

Bus Slave Factory

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

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

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

read(that,address,bitOffset)

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

write(that,address,bitOffset)

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

readAndWrite(that,address,bitOffset)

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

readMultiWord(that,address)

注冊(cè)大位寬寄存器(超過(guò)總線數(shù)據(jù)位寬)讀操作到指定地址,其中address地址存放對(duì)應(yīng)低比特,高比特地址向上累加。

writeMultiWord(that,address)

注冊(cè)大位寬寄存器(超過(guò)總線數(shù)據(jù)位寬)寫操作到指定地址,其中address地址存放對(duì)應(yīng)低比特,高比特地址向上累加。

除此之外,bus slave factory還提供了printDataModel函數(shù)用于打印寄存器列表。而且在生成RTL時(shí),其會(huì)自動(dòng)檢測(cè)寄存器地址是否存在沖突。

AXI4-Lite總線實(shí)現(xiàn)

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

en:?jiǎn)伪忍?a target="_blank">信號(hào),可讀可寫。

plus:?jiǎn)伪忍匦盘?hào),可讀寫,寫1自動(dòng)清零。

cnt:64比特信號(hào),可讀。

這里給出完整的代碼結(jié)構(gòu):

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

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

由于plus寫1清零,因此代碼14行用于實(shí)現(xiàn)清零操作。

通過(guò)下面的語(yǔ)法生成RTL代碼:

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

在生成RTL代碼的同時(shí),會(huì)打印寄存器列表:

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

仿真結(jié)果

SpinalHDL里提供了AXI4-Lite總線的基礎(chǔ)仿真庫(kù),這里直接調(diào)用其仿真庫(kù),完整的仿真代碼如下:

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

通過(guò)gtkWave觀察波形:

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

可以看到,功能符合我們的設(shè)計(jì),寫寄存器0x4信號(hào)plus拉高1個(gè)時(shí)鐘周期后自動(dòng)清零。 這里簡(jiǎn)單幾行代碼實(shí)現(xiàn)了AXI4-Lite總線控制寄存器讀寫,對(duì)于我們?cè)谡嬲捻?xiàng)目實(shí)現(xiàn)里,能夠極大簡(jiǎn)化我們的工作量和bug產(chǎn)生。盡管現(xiàn)在各個(gè)大廠或許有專門的總線控制寄存器讀寫代碼生成工具,但SpinalHDL這種形式從本質(zhì)上解決了Verilog描述的重復(fù)性工作。

寫在最后

雖然SpinalHDL這種slave factory工具能夠讓我們?cè)诠こ讨锌旖莸膶?shí)現(xiàn)想要的功能,但對(duì)于初學(xué)者來(lái)說(shuō),理解掌握AXI4-Lite這些標(biāo)準(zhǔn)的總線協(xié)議時(shí)序還是非常有必要的(Verilog or SpinalHDL實(shí)現(xiàn)都行嘍)~
編輯:lyn

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(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)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1630

    文章

    21794

    瀏覽量

    605129
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5363

    瀏覽量

    120926

原文標(biāo)題:SpinalHDL—優(yōu)雅地實(shí)現(xiàn)總線寄存器讀寫

文章出處:【微信號(hào):zhuyandz,微信公眾號(hào):FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    調(diào)試ads1192、ads1198等系列的芯片中,發(fā)現(xiàn)寄存器上報(bào)的導(dǎo)聯(lián)狀態(tài)一直處于不穩(wěn)定狀態(tài),為什么?

    我們調(diào)試ads1192、ads1198等系列的芯片中,發(fā)現(xiàn)寄存器上報(bào)的導(dǎo)聯(lián)狀態(tài)一直處于不穩(wěn)定狀態(tài)。導(dǎo)聯(lián)連上時(shí),寄存器可以上報(bào)穩(wěn)定的連上狀態(tài),但是當(dāng)脫落時(shí),發(fā)現(xiàn)導(dǎo)聯(lián)寄存器上報(bào)的狀態(tài)一
    發(fā)表于 11-20 06:25

    接口的控制與狀態(tài)寄存器什么作用

    的行為并獲取硬件的狀態(tài)信息。 接口的控制與狀態(tài)寄存器的作用 現(xiàn)代計(jì)算機(jī)系統(tǒng),硬件設(shè)備與軟件之間的交互是通過(guò)一系列的接口來(lái)實(shí)現(xiàn)的。這些接口不僅需要能夠傳輸數(shù)據(jù),還需要能夠控制硬件設(shè)備
    的頭像 發(fā)表于 10-17 10:42 ?562次閱讀

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

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

    微處理寄存器的作用

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

    寄存器的類型和作用

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

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

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

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

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

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

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

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

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

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

    移位寄存器是一種在數(shù)字電路和計(jì)算機(jī)科學(xué)中廣泛使用的存儲(chǔ)設(shè)備,它可以用來(lái)存儲(chǔ)和傳輸數(shù)據(jù)。移位寄存器,數(shù)據(jù)可以通過(guò)移位操作來(lái)實(shí)現(xiàn)數(shù)據(jù)的傳輸和
    的頭像 發(fā)表于 07-12 10:14 ?1721次閱讀

    威綸觸摸屏RW寄存器如何使用

    威綸觸摸屏是一種廣泛應(yīng)用于工業(yè)自動(dòng)化領(lǐng)域的設(shè)備,它具有易用性、靈活性和可靠性等特點(diǎn)。威綸觸摸屏,RW寄存器是一種非常重要的數(shù)據(jù)存儲(chǔ)方式,它可以幫助用戶實(shí)現(xiàn)數(shù)據(jù)的
    的頭像 發(fā)表于 06-11 16:32 ?4888次閱讀

    八進(jìn)制總線收發(fā)寄存器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《八進(jìn)制總線收發(fā)寄存器數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-29 09:59 ?0次下載
    八進(jìn)制<b class='flag-5'>總線</b>收發(fā)<b class='flag-5'>器</b>和<b class='flag-5'>寄存器</b>數(shù)據(jù)表

    帶3態(tài)輸出的16位總線收發(fā)寄存器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《帶3態(tài)輸出的16位總線收發(fā)寄存器數(shù)據(jù)表.pdf》資料免費(fèi)下載
    發(fā)表于 05-24 09:09 ?0次下載
    帶3態(tài)輸出的16位<b class='flag-5'>總線</b>收發(fā)<b class='flag-5'>器</b>和<b class='flag-5'>寄存器</b>數(shù)據(jù)表

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

    無(wú)論是FPGA還是ASIC,系統(tǒng)設(shè)計(jì)總會(huì)存在配置寄存器總線的使用,我們會(huì)將各種功能、調(diào)試寄存器掛載
    的頭像 發(fā)表于 03-04 13:56 ?1220次閱讀
    如何根據(jù)自己設(shè)計(jì)<b class='flag-5'>中</b>的<b class='flag-5'>寄存器</b>配置<b class='flag-5'>總線</b>定義來(lái)生成一套<b class='flag-5'>寄存器</b>配置模版

    TC3XX寄存器讀寫時(shí)間過(guò)長(zhǎng)怎么解決?

    我目前在做TC3XX底層代碼優(yōu)化,經(jīng)過(guò)之前多次測(cè)試目前可以確定該系列芯片對(duì)單個(gè)寄存器地址的讀寫耗時(shí)超過(guò)100us。請(qǐng)問(wèn)對(duì)于寄存器讀寫耗時(shí)你們官方有沒(méi)有確切的文件說(shuō)明?還有就是既然
    發(fā)表于 01-25 06:56
    主站蜘蛛池模板: 亚洲合集综合久久性色| 宿舍BL 纯肉各种PLAY H| 久久偷拍国2017| 甜性涩爱全集在线观看| 97视频免费在线| 久爱精品亚洲电影午夜| 日本内射精品一区二区视频| 20岁αsrian男同志免费| 黑人巨摘花破女处| 色老汉网址导航| 国产亚洲精品久久7777777| 久久久久久久久久毛片精品美女 | 九色PORNY真实丨国产免费| 日本精油按摩| 成人免费肉动漫无遮网站| 天美传媒在线观看免费完整版| 男人和女人全黄一级毛片| 国产精品亚洲二线在线播放 | 日韩少妇爆乳无码专区| 国产午夜精品理论片影院| 99久视频只有精品2019| 亚洲无遮挡| 性做久久久久久久久浪潮| 日本 稀土矿| 亚洲 日本 中文字幕 制服| 囯产精品久久久久久久久蜜桃| 日本二区三区欧美亚洲国| 2020亚洲国产在线播放在线| 麻豆精品传媒一二三区| 2022年国产精品久久久久| 开心色99xxxx开心色| 中文字幕在线播放视频| 毛茸茸womansex| 成人国产在线不卡视频| 天堂色| 久久亚洲精品AV成人无| 在线电台收听| 欧美亚洲日韩国码在线观看| 国产免费午夜高清| 亚洲乱色视频在线观看 | 亚洲一区综合图区|