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

    文章

    1700

    浏览量

    91298
  • config
    +关注

    关注

    0

    文章

    15

    浏览量

    4617

原文标题:值得学习的SPI-Master

文章出处:【微信号:zhuyandz,微信公众号:FPGA之家】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    PROFINET转SSI协议模块快速使用说明

    Profinet网关PROFINET转SSI协议 PN4SSI模块快速使用说明
    的头像 发表于 10-17 16:13 267次阅读
    PROFINET转SSI协议<b class='flag-5'>模块</b>快速<b class='flag-5'>使用说明</b>

    SDRuno软件使用说明 v1.22.002

    SDRuno软件使用说明 v1.22.002
    发表于 10-14 11:44 1次下载

    永磁机构驱动模块10KV SF6全绝缘断路器柜使用说明

    该文档是南网专用的永磁机构驱动模块10KV SF6全绝缘断路器柜使用说明书。
    发表于 06-24 14:16 0次下载

    Keithley6517A使用说明

    Keithley6517A的基本使用说明书(日文版)
    发表于 06-07 17:09 2次下载

    Diamond开发工具使用说明

    Diamond开发工具使用说明
    发表于 05-23 09:14 0次下载

    功率计的使用说明

    功率计是电力电子、通信、科研等领域中不可或缺的测量工具,用于准确测量电路的功率值。为了确保功率计的正确使用和测量结果的准确性,本使用说明将详细介绍功率计的基本操作、连接电路、设置参数、进行测量以及数据处理与分析等步骤,并结合注意事项,为用户提供全面的使用指导。
    的头像 发表于 05-15 17:01 2362次阅读

    简单信箱保存使用说明

    电子发烧友网站提供《简单信箱保存使用说明书.pdf》资料免费下载
    发表于 04-03 09:08 0次下载

    浅析SpinalHDLPipeline的复位定制

    之前有系列文章介绍了SpinalHDLPipeline的使用,最近在一个功能模块真实的使用了这个lib。
    的头像 发表于 03-17 17:31 990次阅读
    浅析<b class='flag-5'>SpinalHDL</b><b class='flag-5'>中</b>Pipeline<b class='flag-5'>中</b>的复位定制

    TLT507-Ubuntu系统使用说明

    TLT507-Ubuntu系统使用说明
    的头像 发表于 01-26 09:58 958次阅读
    TLT507-Ubuntu系统<b class='flag-5'>使用说明</b>

    TL3588-Buildroot系统使用说明(二)

    TL3588-Buildroot系统使用说明(二)
    的头像 发表于 01-25 13:58 845次阅读
    TL3588-Buildroot系统<b class='flag-5'>使用说明</b>(二)

    TL3588-Buildroot系统使用说明(一)

    TL3588-Buildroot系统使用说明(一)
    的头像 发表于 01-25 11:38 1050次阅读
    TL3588-Buildroot系统<b class='flag-5'>使用说明</b>(一)

    TL3588-Qt工程编译、GPU核心使用说明

    TL3588-Qt工程编译、GPU核心使用说明
    的头像 发表于 01-24 14:03 863次阅读
    TL3588-Qt工程编译、GPU核心<b class='flag-5'>使用说明</b>

    国扬智能光模块使用说明

    电子发烧友网站提供《国扬智能光模块使用说明.ppt》资料免费下载
    发表于 12-26 10:02 0次下载

    小Q精灵微气象产品使用说明

    电子发烧友网站提供《小Q精灵微气象产品使用说明.docx》资料免费下载
    发表于 12-25 09:24 0次下载

    色环电阻识别使用说明

    电子发烧友网站提供《色环电阻识别使用说明.exe》资料免费下载
    发表于 12-13 17:02 0次下载