18video性欧美19sex,欧美高清videosddfsexhd,性少妇videosexfreexxx片中国,激情五月激情综合五月看花,亚洲人成网77777色在线播放

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

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

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

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

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

掃碼添加小助手

加入工程師交流群

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

Bus Slave Factory

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

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

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

read(that,address,bitOffset)

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

write(that,address,bitOffset)

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

readAndWrite(that,address,bitOffset)

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

readMultiWord(that,address)

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

writeMultiWord(that,address)

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

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

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

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

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

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

cnt:64比特信號,可讀。

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

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

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

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

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

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

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

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

仿真結(jié)果

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

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

通過gtkWave觀察波形:

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

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

寫在最后

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

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

    關(guān)注

    1650

    文章

    22214

    瀏覽量

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

    關(guān)注

    31

    文章

    5498

    瀏覽量

    128127

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計31: 寄存器功能驗(yàn)證與分析1

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

    使用寄存器點(diǎn)亮LED燈

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

    74ALVCH16646 16位總線收發(fā)/寄存器規(guī)格書

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

    74LV4094移位和存儲總線寄存器規(guī)格書

    電子發(fā)燒友網(wǎng)站提供《74LV4094移位和存儲總線寄存器規(guī)格書.pdf》資料免費(fèi)下載
    發(fā)表于 02-14 16:20 ?0次下載
    74LV4094移位和存儲<b class='flag-5'>總線</b><b class='flag-5'>寄存器</b>規(guī)格書

    讀寫ADS1216Y的寄存器,寫一個寄存器然后讀這個寄存器會得到兩個值,怎么回事?

    我在讀寫ADS1216Y的寄存器,寫一個寄存器然后讀這個寄存器會得到兩個值,例如:寫入0XAA, 會讀到0XFA和0XAA
    發(fā)表于 02-14 07:11

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

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

    74HC4094;74HCT4094移位存儲總線寄存器規(guī)格書

    電子發(fā)燒友網(wǎng)站提供《74HC4094;74HCT4094移位存儲總線寄存器規(guī)格書.pdf》資料免費(fèi)下載
    發(fā)表于 02-08 16:40 ?0次下載
    74HC4094;74HCT4094移位存儲<b class='flag-5'>總線</b><b class='flag-5'>寄存器</b>規(guī)格書

    請問DAC121C085的寄存器可以讀寫多少次?

    請問DAC121C085的寄存器可以讀寫多少次?想使用此DAC產(chǎn)生正弦波,需要不斷通過I2C總線往DAC121C085寄存器寫入數(shù)據(jù),這對DAC的壽命有影響嗎?
    發(fā)表于 12-13 07:08

    用opt3001獲取數(shù)據(jù)時發(fā)現(xiàn)數(shù)據(jù)有問題,讀取寄存器原始數(shù)據(jù)時候發(fā)現(xiàn)寄存器E[3:0]位不正確如何解決?

    用opt3001獲取數(shù)據(jù)時發(fā)現(xiàn)數(shù)據(jù)有問題,讀取寄存器原始數(shù)據(jù)時候發(fā)現(xiàn)寄存器E[3:0]位不正確,超過了11,請問這種情況該如何解決? 以下是讀取的Result Register原始值 FAULT
    發(fā)表于 12-12 07:07

    DAC7718讀寫寄存器,只有部分寄存器能夠讀取和寫入,為什么?

    我用NXP LPC11C24 通過SPI接口控制DAC7718只有部分寄存器能夠讀寫,例如寄存器0x00,0x07,0x1F,0x0F,均能夠工作,通過寫寄存器0x07能夠廣播控制所
    發(fā)表于 12-09 08:42

    AFE4400STM32上的驅(qū)動程序,發(fā)現(xiàn)寄存器配置總是失敗,為什么?

    您好,最近在寫AFE4400STM32上的驅(qū)動程序,發(fā)現(xiàn)寄存器配置總是失敗。為什么會有這個判斷?因?yàn)橥粋€寄存器寫入一個字節(jié)后然后再讀,讀出來的值不一致,總是 oxFFFFFF,我在前
    發(fā)表于 12-04 08:09

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

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

    ADS125H02通過cs2讀寫寄存器失敗的原因?

    做比例式的rtd測量嗎? 2,當(dāng)我用cs1讀寫寄存器時,一切正常,但當(dāng)我用cs2讀寫寄存器(>=0x10)時,出現(xiàn)錯誤,跟蹤發(fā)現(xiàn)返回數(shù)據(jù)收到的是FF,00,00,00。操作
    發(fā)表于 11-18 07:07

    ADS131M03的寄存器讀寫是要在轉(zhuǎn)換觸發(fā)的中斷中進(jìn)行配置,還是可以standby狀態(tài)下進(jìn)行?

    命令,將ADC設(shè)置為standby模式,請問standby模式下,DRDY不在發(fā)生變化,此時能對芯片進(jìn)行寄存器讀寫嗎? 2、DRDY的中斷觸發(fā)
    發(fā)表于 11-13 07:08

    TLV320DAC3101讀寫寄存器不穩(wěn)定是怎么回事?如何解決?

    本人最近在用TLV320DAC3101這塊芯片,通過I2C讀寫該芯片的寄存器,但是進(jìn)場發(fā)生讀寫失敗的情況,比較典型的就是程序下進(jìn)去讀寫成功,然后復(fù)位一下或者重新上電,
    發(fā)表于 10-31 08:07