衡阳派盒市场营销有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

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

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

最近偶爾需要用到SPI模塊。正巧看到SpinalHDL中所提供的SPI-Master設計。看完之后尤為佩服如此簡潔而又全面的設計方式。本篇不對SPI協議進行講解,僅針對SpinalHDL中的SpiMasterCtrl模塊做使用說明。

源代碼值得一讀和學習。

》》SpiMasterCtrl配置參數 SpiMasterCtrl的配置參數類為SpiMasterCtrlGenerics:

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

這里主要有三個參數:

ssWidth:SPI使用片選信號時片選信號個數。即指定了SPI從設備個數。當該值為0時,則只有一個從設備,且SPI不使用片選信號。

timerWidth: 時鐘分頻計數器位寬。由于SPI時鐘信號是由主時鐘計數分頻而來,因此該值指定了計數器的位寬,根據SPI想要跑的最小頻率來定義該值。

dataWidth:指定單次傳輸的位寬。

》》

接口定義

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的運行時鐘頻率。SPI時鐘頻率為:

系統時鐘頻率/((sclkToggle+1)*2)

當SPI使用了片選信號時,ss接口包含的內容為:

activeHigh:每個bit對應一個從設備片選信號是高電平有效還是低電平有效。

setup:片選信號使能和開始發送數據之間的時鐘周期間隔數(加1)。

hold:發送完數據到片選信號釋放前的時鐘周期數(加1)。

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

》》

cmd接口

cmd接口類型為Stream類型接口,包含內容為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:數據發送指令。

SS:片選操作指令。

args為指令數據。根據指令形式的不同,可通過提供的argsData、argsSS方法解析出相應的指令內容:

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

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

》》rsp接口 該接口為flow形式。當操作為數據讀操作時,數據的讀返回結果從該接口返回。》》SPI接口 對外SPI接口。》》driveFrom SpiMasterCtrl提供了一個driveFrom方法將接口映射到總線的slaveFactory上:

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

其實現了讀寫8bit的功能,同時帶有終端功能。SpianlHDL中提供了一個APB總線的demo:

感興趣的小伙伴可以照此實現自己的需求。個人需求位寬多于8bit,自己實現了一個映射,很容易~
編輯:lyn

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • SPI
    SPI
    +關注

    關注

    17

    文章

    1722

    瀏覽量

    92134
  • config
    +關注

    關注

    0

    文章

    15

    瀏覽量

    4661

原文標題:值得學習的SPI-Master

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

收藏 人收藏

    評論

    相關推薦

    功率分析儀使用說明

    功率分析儀的使用說明主要包括安裝、設置、測量及數據分析等步驟,以下是詳細的使用指南:
    的頭像 發表于 01-28 14:55 ?103次閱讀

    AN030:SPICE模型使用說明

    電子發燒友網站提供《AN030:SPICE模型使用說明.pdf》資料免費下載
    發表于 01-23 16:44 ?0次下載
    AN030:SPICE模型<b class='flag-5'>使用說明</b>

    PROFINET轉SSI協議模塊快速使用說明

    Profinet網關PROFINET轉SSI協議 PN4SSI模塊快速使用說明
    的頭像 發表于 10-17 16:13 ?393次閱讀
    PROFINET轉SSI協議<b class='flag-5'>模塊</b>快速<b class='flag-5'>使用說明</b>

    CAN/CANFD卡接口函數使用說明

    電子發燒友網站提供《CAN/CANFD卡接口函數使用說明.pdf》資料免費下載
    發表于 10-15 17:35 ?0次下載

    SDRuno軟件使用說明 v1.22.002

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

    身份證云解碼模塊(CSYJM-3)產品使用說明

    解碼模塊
    jf_08279201
    發布于 :2024年09月05日 11:52:16

    氧氣傳感器使用說明

    電子發燒友網站提供《氧氣傳感器使用說明書.pdf》資料免費下載
    發表于 08-08 12:49 ?0次下載

    閃電定位儀的使用說明

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

    永磁機構驅動模塊10KV SF6全絕緣斷路器柜使用說明

    該文檔是南網專用的永磁機構驅動模塊10KV SF6全絕緣斷路器柜使用說明書。
    發表于 06-24 14:16 ?0次下載

    TJDZ-RC522 RFID讀卡模塊用戶操作手冊

    RC522讀卡模塊使用說明
    發表于 06-19 14:32 ?1次下載

    Keithley6517A使用說明

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

    Diamond開發工具使用說明

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

    功率計的使用說明

    功率計是電力電子、通信、科研等領域中不可或缺的測量工具,用于準確測量電路的功率值。為了確保功率計的正確使用和測量結果的準確性,本使用說明將詳細介紹功率計的基本操作、連接電路、設置參數、進行測量以及數據處理與分析等步驟,并結合注意事項,為用戶提供全面的使用指導。
    的頭像 發表于 05-15 17:01 ?2948次閱讀

    簡單信箱保存使用說明

    電子發燒友網站提供《簡單信箱保存使用說明書.pdf》資料免費下載
    發表于 04-03 09:08 ?0次下載

    淺析SpinalHDLPipeline的復位定制

    之前有系列文章介紹了SpinalHDLPipeline的使用,最近在一個功能模塊真實的使用了這個lib。
    的頭像 發表于 03-17 17:31 ?1128次閱讀
    淺析<b class='flag-5'>SpinalHDL</b><b class='flag-5'>中</b>Pipeline<b class='flag-5'>中</b>的復位定制
    百家乐官网赌的技巧| 新世百家乐官网的玩法技巧和规则| 百家乐大赌城| 有关百家乐官网玩家论坛| 娱乐城开户送38体验金| 百家乐打线| 十六浦娱乐| 聚众玩百家乐的玩法技巧和规则 | 实战百家乐的玩法技巧和规则| 打百家乐的介绍| 百家乐官网笑话| 百家乐官网胜率被控制| 新西兰百家乐的玩法技巧和规则 | 百家乐官网在线娱乐场| 沙坪坝区| 百家乐园云鼎娱乐平台| 百家乐官网筹码套装100片| 金都百家乐官网现金网| 皇冠网hg3155| 申博太阳城娱乐| 百家乐龙虎斗等| 澳门赌百家乐官网的玩法技巧和规则 | 足球投注技巧| 全讯网qtqnet好玩| 百家乐官网网络赌博地址| 星河娱乐城| 百乐坊娱乐城噢门| 网页棋牌游戏| A8百家乐的玩法技巧和规则| 百家乐二游戏机| 希尔顿百家乐官网娱乐城| 百家乐官网包台| 百家乐官网玩法简介| 铂金娱乐| 最新皇冠网止| 久盛| 大发888站| 威尼斯人娱乐城lm0| 鑫鼎百家乐娱乐城| 百家乐的关键技巧| 百家乐官网77s|