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

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

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

SpinalHDL中的SpiMasterCtrl模塊做使用說明詳解

FPGA之家 ? 來源:CSDN技術(shù)社區(qū) ? 作者:似猿非猿的FPGA ? 2021-04-19 09:58 ? 次閱讀

最近偶爾需要用到SPI模塊。正巧看到SpinalHDL中所提供的SPI-Master設(shè)計(jì)??赐曛笥葹榕宸绱撕?jiǎn)潔而又全面的設(shè)計(jì)方式。本篇不對(duì)SPI協(xié)議進(jìn)行講解,僅針對(duì)SpinalHDL中的SpiMasterCtrl模塊做使用說明。

源代碼值得一讀和學(xué)習(xí)。

》》SpiMasterCtrl配置參數(shù) SpiMasterCtrl的配置參數(shù)類為SpiMasterCtrlGenerics:

case class SpiMasterCtrlGenerics( ssWidth : Int, timerWidth : Int, dataWidth : Int = 8){ def ssGen = ssWidth != 0}

這里主要有三個(gè)參數(shù):

ssWidth:SPI使用片選信號(hào)時(shí)片選信號(hào)個(gè)數(shù)。即指定了SPI從設(shè)備個(gè)數(shù)。當(dāng)該值為0時(shí),則只有一個(gè)從設(shè)備,且SPI不使用片選信號(hào)。

timerWidth: 時(shí)鐘分頻計(jì)數(shù)器位寬。由于SPI時(shí)鐘信號(hào)是由主時(shí)鐘計(jì)數(shù)分頻而來,因此該值指定了計(jì)數(shù)器的位寬,根據(jù)SPI想要跑的最小頻率來定義該值。

dataWidth:指定單次傳輸?shù)奈粚挕?/p>

》》

接口定義

SpiMasterCtrl的接口主要包含下面四組接口:

val config = in(SpiMasterCtrlConfig(generics))val cmd = slave Stream(SpiMasterCmd(generics))val rsp = master Flow(Bits(dataWidth bits))val spi = master(SpiMaster(ssWidth))

》》

config接口

config接口組成為:

case class SpiMasterCtrlConfig(generics : SpiMasterCtrlGenerics) extends Bundle{ val kind = SpiKind() val sclkToogle = UInt(generics.timerWidth bits) val ss = if(generics.ssGen) new Bundle { val activeHigh = Bits(generics.ssWidth bits) val setup = UInt(generics.timerWidth bits) val hold = UInt(generics.timerWidth bits) val disable = UInt(generics.timerWidth bits) } else null}

kind接口指定了SPI接口的屬性CPOL及CPHA的值

case class SpiKind() extends Bundle { val cpol = Bool val cpha = Bool}

sclkToggle指定SPI的運(yùn)行時(shí)鐘頻率。SPI時(shí)鐘頻率為:

系統(tǒng)時(shí)鐘頻率/((sclkToggle+1)*2)

當(dāng)SPI使用了片選信號(hào)時(shí),ss接口包含的內(nèi)容為:

activeHigh:每個(gè)bit對(duì)應(yīng)一個(gè)從設(shè)備片選信號(hào)是高電平有效還是低電平有效。

setup:片選信號(hào)使能和開始發(fā)送數(shù)據(jù)之間的時(shí)鐘周期間隔數(shù)(加1)。

hold:發(fā)送完數(shù)據(jù)到片選信號(hào)釋放前的時(shí)鐘周期數(shù)(加1)。

disable:片選信號(hào)釋放后到重新使能需間隔的時(shí)鐘周期數(shù)(加1)。

》》

cmd接口

cmd接口類型為Stream類型接口,包含內(nèi)容為SpiMasterCmd:

case class SpiMasterCmd(generics : SpiMasterCtrlGenerics) extends Bundle{ val mode = if(generics.ssGen) SpiMasterCtrlCmdMode() else null val args = Bits(Math.max(widthOf(SpiMasterCtrlCmdData(generics)), log2Up(generics.ssWidth) + 1 ) bits)

def isData = if(generics.ssGen) mode === SpiMasterCtrlCmdMode.DATA else True

def argsData = { val ret = SpiMasterCtrlCmdData(generics) ret.assignFromBits(args) ret } def argsSs = { val ret = SpiMasterCtrlCmdSs(generics) ret.assignFromBits(args) ret }}

mode表明指令的類型:

object SpiMasterCtrlCmdMode extends SpinalEnum(binarySequential){ val DATA, SS = newElement()}

DATA:數(shù)據(jù)發(fā)送指令。

SS:片選操作指令。

args為指令數(shù)據(jù)。根據(jù)指令形式的不同,可通過提供的argsData、argsSS方法解析出相應(yīng)的指令內(nèi)容:

case class SpiMasterCtrlCmdData(generics : SpiMasterCtrlGenerics) extends Bundle{ val data = Bits(generics.dataWidth bits) val read = Bool//True表示讀操作,F(xiàn)alse表示寫操作}

case class SpiMasterCtrlCmdSs(generics : SpiMasterCtrlGenerics) extends Bundle{ val enable = Bool //True:使能,F(xiàn)alse:Disable val index = UInt(log2Up(generics.ssWidth) bits) //指定待操作的片選信號(hào)位置}

》》rsp接口 該接口為flow形式。當(dāng)操作為數(shù)據(jù)讀操作時(shí),數(shù)據(jù)的讀返回結(jié)果從該接口返回?!贰稴PI接口 對(duì)外SPI接口?!贰穌riveFrom SpiMasterCtrl提供了一個(gè)driveFrom方法將接口映射到總線的slaveFactory上:

def driveFrom(bus : BusSlaveFactory, baseAddress : Int = 0)(generics : SpiMasterCtrlMemoryMappedConfig) = new Area {

其實(shí)現(xiàn)了讀寫8bit的功能,同時(shí)帶有終端功能。SpianlHDL中提供了一個(gè)APB總線的demo:

感興趣的小伙伴可以照此實(shí)現(xiàn)自己的需求。個(gè)人需求位寬多于8bit,自己實(shí)現(xiàn)了一個(gè)映射,很容易~
編輯: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)投訴
  • SPI
    SPI
    +關(guān)注

    關(guān)注

    17

    文章

    1718

    瀏覽量

    91893
  • config
    +關(guān)注

    關(guān)注

    0

    文章

    15

    瀏覽量

    4646

原文標(biāo)題:值得學(xué)習(xí)的SPI-Master

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

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    PROFINET轉(zhuǎn)SSI協(xié)議模塊快速使用說明

    Profinet網(wǎng)關(guān)PROFINET轉(zhuǎn)SSI協(xié)議 PN4SSI模塊快速使用說明
    的頭像 發(fā)表于 10-17 16:13 ?361次閱讀
    PROFINET轉(zhuǎn)SSI協(xié)議<b class='flag-5'>模塊</b>快速<b class='flag-5'>使用說明</b>

    CAN/CANFD卡接口函數(shù)使用說明

    電子發(fā)燒友網(wǎng)站提供《CAN/CANFD卡接口函數(shù)使用說明.pdf》資料免費(fèi)下載
    發(fā)表于 10-15 17:35 ?0次下載

    SDRuno軟件使用說明 v1.22.002

    SDRuno軟件使用說明 v1.22.002
    發(fā)表于 10-14 11:44 ?1次下載

    閃電定位儀的使用說明

    閃電定位儀的使用說明
    發(fā)表于 07-08 14:59 ?0次下載

    永磁機(jī)構(gòu)驅(qū)動(dòng)模塊10KV SF6全絕緣斷路器柜使用說明

    該文檔是南網(wǎng)專用的永磁機(jī)構(gòu)驅(qū)動(dòng)模塊10KV SF6全絕緣斷路器柜使用說明書。
    發(fā)表于 06-24 14:16 ?0次下載

    Keithley6517A使用說明

    Keithley6517A的基本使用說明書(日文版)
    發(fā)表于 06-07 17:09 ?3次下載

    Diamond開發(fā)工具使用說明

    Diamond開發(fā)工具使用說明
    發(fā)表于 05-23 09:14 ?0次下載

    功率計(jì)的使用說明

    功率計(jì)是電力電子、通信、科研等領(lǐng)域中不可或缺的測(cè)量工具,用于準(zhǔn)確測(cè)量電路的功率值。為了確保功率計(jì)的正確使用和測(cè)量結(jié)果的準(zhǔn)確性,本使用說明將詳細(xì)介紹功率計(jì)的基本操作、連接電路、設(shè)置參數(shù)、進(jìn)行測(cè)量以及數(shù)據(jù)處理與分析等步驟,并結(jié)合注意事項(xiàng),為用戶提供全面的使用指導(dǎo)。
    的頭像 發(fā)表于 05-15 17:01 ?2856次閱讀

    簡(jiǎn)單信箱保存使用說明

    電子發(fā)燒友網(wǎng)站提供《簡(jiǎn)單信箱保存使用說明書.pdf》資料免費(fèi)下載
    發(fā)表于 04-03 09:08 ?0次下載

    淺析SpinalHDLPipeline的復(fù)位定制

    之前有系列文章介紹了SpinalHDLPipeline的使用,最近在一個(gè)功能模塊真實(shí)的使用了這個(gè)lib。
    的頭像 發(fā)表于 03-17 17:31 ?1091次閱讀
    淺析<b class='flag-5'>SpinalHDL</b><b class='flag-5'>中</b>Pipeline<b class='flag-5'>中</b>的復(fù)位定制

    TLT507-Ubuntu系統(tǒng)使用說明

    TLT507-Ubuntu系統(tǒng)使用說明
    的頭像 發(fā)表于 01-26 09:58 ?1059次閱讀
    TLT507-Ubuntu系統(tǒng)<b class='flag-5'>使用說明</b>

    TL3588-Buildroot系統(tǒng)使用說明(二)

    TL3588-Buildroot系統(tǒng)使用說明(二)
    的頭像 發(fā)表于 01-25 14:37 ?914次閱讀
    TL3588-Buildroot系統(tǒng)<b class='flag-5'>使用說明</b>(二)

    TL3588-Buildroot系統(tǒng)使用說明(二)

    TL3588-Buildroot系統(tǒng)使用說明(二)
    的頭像 發(fā)表于 01-25 13:58 ?932次閱讀
    TL3588-Buildroot系統(tǒng)<b class='flag-5'>使用說明</b>(二)

    TL3588-Buildroot系統(tǒng)使用說明(一)

    TL3588-Buildroot系統(tǒng)使用說明(一)
    的頭像 發(fā)表于 01-25 11:38 ?1154次閱讀
    TL3588-Buildroot系統(tǒng)<b class='flag-5'>使用說明</b>(一)

    TL3588-Qt工程編譯、GPU核心使用說明

    TL3588-Qt工程編譯、GPU核心使用說明
    的頭像 發(fā)表于 01-24 14:03 ?1040次閱讀
    TL3588-Qt工程編譯、GPU核心<b class='flag-5'>使用說明</b>