91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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之家 ? 來源: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

通過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è)大位寬寄存器(超過總線數(shù)據(jù)位寬)讀操作到指定地址,其中address地址存放對(duì)應(yīng)低比特,高比特地址向上累加。

writeMultiWord(that,address)

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

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

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

這里以AXI4-Lite總線舉例,通過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行通過slave factory實(shí)現(xiàn)AXI4-Lite寄存器讀寫。代碼第19行打印輸出寄存器列表。

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

通過下面的語法生成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

通過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é)者來說,理解掌握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ī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1660

    文章

    22427

    瀏覽量

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

    關(guān)注

    31

    文章

    5611

    瀏覽量

    130062

原文標(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ǎn)推薦

    RDMA設(shè)計(jì)38:寄存器功能驗(yàn)證與分析

    。由于DUT寄存器數(shù)量較多,這里用全局計(jì)數(shù)寄存器為例說明寄存器功能驗(yàn)證過程。對(duì)于寄存器的仿真需要考慮
    發(fā)表于 02-09 10:26

    請(qǐng)問如何實(shí)現(xiàn)C語言訪問MCU寄存器?

    單片機(jī)的特殊功能寄存器SFR,是SRAM地址已經(jīng)確定的SRAM單元,C語言環(huán)境下對(duì)其訪問歸納起來有兩種方法。 采用標(biāo)準(zhǔn)C的強(qiáng)制類型轉(zhuǎn)換和指針來實(shí)現(xiàn)   采用標(biāo)準(zhǔn)C的強(qiáng)制轉(zhuǎn)換和指針的概念來實(shí)現(xiàn)
    發(fā)表于 12-26 07:00

    匯編寄存器的知識(shí)

    學(xué)習(xí)匯編語言,首先必須了解兩個(gè)知識(shí)點(diǎn):寄存器和內(nèi)存模型。 先來看寄存器。CPU 本身只負(fù)責(zé)運(yùn)算,不負(fù)責(zé)儲(chǔ)存數(shù)據(jù)。數(shù)據(jù)一般都儲(chǔ)存在內(nèi)存之中,CPU 要用的時(shí)候就去內(nèi)存讀寫數(shù)據(jù)。 但是,CPU
    發(fā)表于 11-20 06:45

    嵌入式系統(tǒng)必懂的 20 個(gè)寄存器

    了嵌入式系統(tǒng)開發(fā)者必懂的20個(gè)寄存器,讓你快速掌握MCU的核心操作方法。01寄存器基礎(chǔ)寄存器是CPU內(nèi)部用于高速存取數(shù)據(jù)的小容量存儲(chǔ)單元,是計(jì)算機(jī)執(zhí)行指令、處理
    的頭像 發(fā)表于 11-14 10:28 ?1137次閱讀
    嵌入式系統(tǒng)必懂的 20 個(gè)<b class='flag-5'>寄存器</b>

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

    的要求設(shè)計(jì)APB總線接口。其次,需要根據(jù)外設(shè)的需要來設(shè)計(jì)對(duì)應(yīng)外設(shè)的寄存器,如定義一些只讀、讀寫寄存器等。寄存器后級(jí)的具體算法需根據(jù)自己算法需
    發(fā)表于 10-29 07:49

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

    main.c即可實(shí)現(xiàn)對(duì)寄存器讀寫。 讀: 寫: 方法二: (1)hbirdv2.h添加
    發(fā)表于 10-29 06:39

    E203添加浮點(diǎn)數(shù)方法:寄存器設(shè)計(jì)

    決這個(gè)問題,根據(jù)浮點(diǎn) CSR 的讀寫指令由普通 CSR 讀寫指令實(shí)現(xiàn)的特點(diǎn),筆者 CSR 寄存器
    發(fā)表于 10-24 13:25

    蜂鳥內(nèi)核DMA的硬件實(shí)現(xiàn)——寄存器配置

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

    DMA硬件實(shí)現(xiàn)——讀寫實(shí)現(xiàn)

    寄存器、長(zhǎng)度寄存器回到初始狀態(tài)0,狀態(tài)寄存器回到初始狀態(tài)111。 此外,由于這里一次進(jìn)行16個(gè)數(shù)據(jù)的讀寫,需要一個(gè)fifo模塊存放數(shù)據(jù)。這里例化了fifo。下一小部分具體闡述fifo
    發(fā)表于 10-24 07:58

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

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

    ?SN74HCT595 8位移位寄存器技術(shù)解析與應(yīng)用指南

    Texas Instruments SN74HCT595/SN74HCT595-Q1 8位移位寄存器包含8位串進(jìn)并出移位寄存器,向8位D類存儲(chǔ)寄存器饋送信號(hào)。存儲(chǔ)寄存器具有并行 3 狀
    的頭像 發(fā)表于 09-19 14:31 ?1001次閱讀
    ?SN74HCT595 8位移位<b class='flag-5'>寄存器</b>技術(shù)解析與應(yīng)用指南

    TPIC6595 8位功率移位寄存器技術(shù)文檔摘要

    該TPIC6595是一款單片、高壓、大電流功率的8位移位寄存器,設(shè)計(jì)用于需要相對(duì)較高負(fù)載功率的系統(tǒng)。該器件輸出端包含一個(gè)內(nèi)置電壓鉗位,用于電感瞬態(tài)保護(hù)。功率驅(qū)動(dòng)應(yīng)用包括繼電器、螺線管和其他
    的頭像 發(fā)表于 09-09 11:10 ?939次閱讀
    TPIC6595 8位功率移位<b class='flag-5'>寄存器</b>技術(shù)文檔摘要

    ?TPIC6B595 8位功率移位寄存器技術(shù)文檔總結(jié)

    TPIC6B595器件是一款單片、高壓、電流功率8位移位寄存器,設(shè)計(jì)用于需要相對(duì)高負(fù)載功率的系統(tǒng)。該器件輸出端包含一個(gè)內(nèi)置電壓鉗位,用于電感瞬態(tài)保護(hù)。功率驅(qū)動(dòng)應(yīng)用包括繼電器、螺線
    的頭像 發(fā)表于 09-09 10:16 ?1032次閱讀
    ?TPIC6B595 8位功率移位<b class='flag-5'>寄存器</b>技術(shù)文檔總結(jié)

    ?TLC6C5912 12通道移位寄存器LED驅(qū)動(dòng)技術(shù)文檔總結(jié)

    該TLC6C5912是一款單片、壓、低電流功率 12 位移位寄存器 設(shè)計(jì)用于需要相對(duì)中等負(fù)載功率的系統(tǒng),例如 LED。 該器件包含一個(gè) 12 位串行輸入并行輸出移位寄存器,可為 12 位饋電
    的頭像 發(fā)表于 08-26 14:16 ?1019次閱讀
    ?TLC6C5912 12通道移位<b class='flag-5'>寄存器</b>LED驅(qū)動(dòng)<b class='flag-5'>器</b>技術(shù)文檔總結(jié)

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

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