dsp-spi外围扩展..docVIP

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
dsp-spi外围扩展.

SPI:扩展一些外围设备 SPITXBUF和SPIDATA从高位开始存储 注意:在同一个时刻只能有一个从机起作用 如何设置SPI成为从机 通过设置SPI工作控制寄存器SPICTL的MASTER/SLAVE为0来使得SPI工作于从机模式,编程的语句为 Spiregs.spictl.bit.master_slave=0 从机接收功能较多:通过编程可以禁止从spi的发送功能 编程语句为spiaregs.spictl.bit.talk=0 数据格式问题 简单的说:即数据写入发送缓冲和数据寄存器时,是从高位开始写的;而从接收缓冲寄存器取数据时 从低位开始取 SPI时钟配置 相位以及极性决定了四种不同的时钟方案 其他三个以此类推,同样可得出其意思。 通过将SPIFFTX寄存器中的spiffen位置位来启动SPI的FIFO功能,将SPIFFTX寄存器中的SPIFFEN位置位,可以在任何状态下复位FIFO模式,SPIFIFO将重新开始发送和接收数据。 数据从fifo转移到移位寄存器的速度是可编程的 SPIFFCT寄存器的0-7位 SPI的中断 有疑问的知识点 关于左对齐右对齐的问题? 从低位写进去,为左对齐,向SPITXBUF写操作必须是左对齐的。 由于数据先移入SPI的最高有效位,所以数据在此寄存器当中进行右对齐存储。 接收完整的字 DSP TMS320F2812的SPI使用总结 1. spi速率不能超过15M,超过后会出现严重误码 2. 如果接收方式为中断接收,SPICCR字符长度控制位决定了中断的字长。如字长为8,中断等级为1,则每接收一个字节产生一次中断。如字长为16,中断等级为1,则每接收2个字节产生一次中断。 3. 注意主模式和从模式的极性一定要相同。主模式为上升沿采样,下降沿输出。从模式也应该为上升沿采样,下降沿输出。否则会出现采样数据不准确。 4. 注意数据写入SPITXBUF时是左对齐,而读入SPIRXBUF是右对齐。这个问题在16位字长时不突出。但是在16位以下数据字长时要特别注意。一般方法是做左移运算。 5. 注意SPI FIFO的用法。 本人在调试过程中,遇到的最大问题就是数据丢失,困扰多天。后来查明原因,因为开启SPI FIFO增强功能,不能根据SpiaRegs.SPISTS.bit.BUFFULL_FLAG来暂停发送数据。因为此时的TXBUF是从TX FIFO中得数据。程序中写入TXBUF,只是写入发送缓冲器即FIFO。根据先进先出原理,你源源不断的向TXBUF写数据,则FIFO里总是保存你最后写入的数据,而不会将SpiaRegs.SPISTS.bit.BUFFULL_FLAG位置一,所以会发现数据丢失。正确的方法应该判断SPI TX FIFO中的字的个数。如果发送FIFO里已经有16个字了,此时应该停止发送新数据,而等待SPI总线上主机的时钟将TXBUF里数据移出,FIFO数据自动装载一个字到TXBUF里,这时才能发送新数据。

文档评论(0)

xznh + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档