ATLY之spi_flash.docxVIP

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

1、以下是SPI FLASH传送数据的函数/*****************************************************************************/// 函数 : spi_transfer (*send, *recv, num_bytes)// 描述 : 此函数把发送的数据写到SPI控制器的发送FIFO中,并从接收FIFO中读出从SPI总线接收到的数据./*****************************************************************************/voidspi_transfer (Xuint32 BaseAddress, Xuint8 *send, Xuint8 *recv, Xuint8 num_bytes){Xuint8 NumBytesRcvd = 0;Xuint8 NumBytesSent = 0;// 把发送的数据写入到SPI控制器的发送FIFO中while(num_bytes--) { XSpi_WriteReg(BaseAddress, XSP_DTR_OFFSET, *send++); NumBytesSent++; }// 设置SPICR寄存器,使能Master Transactions XSpi_Clear_Inhibit(BaseAddress);// 等待发送FIFO为空while (!(XSpi_ReadReg(BaseAddress, XSP_SR_OFFSET) XSP_SR_TX_EMPTY_MASK));// 从接收FIFO中接收数据while ((XSpi_ReadReg(BaseAddress, XSP_SR_OFFSET) XSP_SR_RX_EMPTY_MASK) == 0) { *recv++ = XSpi_ReadReg(BaseAddress,XSP_DRR_OFFSET); NumBytesRcvd++; }// 设置SPICR寄存器,Master Transactions 不使能 XSpi_Set_Inhibit(BaseAddress);/*如果没有数据发送或发送的数据不等于接收的数据,则显示错误 * If no data was sent or the data that was sent was not received, * then return an error */if ((NumBytesSent != NumBytesRcvd) || (NumBytesSent == 0)) {print(SPI XFER ERROR\r\n); }}问题:为什么FIFO发送完数据就得进行FIFO接收数据,难道发送出去的数据和接收的数据是一致的吗?2、以下是读SPI FLASH的状态寄存器的函数// 函数 : SF_read_status_register (Xuint32 BaseAddress)// 描述 : 这函数读SPI FLASH的状态寄存器返回状态寄存器的值.Xuint8SF_read_status_register (Xuint32 BaseAddress){Xuint8 status_reg[2], op_code[2]; op_code[0] = RDSR; SPI_FLASH_CS_LOW();// 读状态寄存器 spi_transfer(BaseAddress, op_code, status_reg, 2); SPI_FLASH_CS_HIGH();return status_reg[1];}问题:为什么返回值为status_reg[1],为什么需要传送两个数据?难道是时序的问题吗?答案:其实这两个问题是一个问题。这得追溯到SPI总线协议了。spi 串行外围设备接口,它是一个环形总线结构,由SS,SCK,SDI,SDO,构成,这里SDI,SDO是相对于主机MASTER说的。其时序很简单,主要是在SCK控制下,主从设备的双向移位寄存器进行数据交换。上升沿发送、下降沿接收、高位先发送。上升沿到来的时候,sdo上的电平将被发送到从设备的寄存器中。下降沿到来的时候,sdi上的电平将被接收到主设备的寄存器中。假设主机和从机初始化就绪:并且主机的sbuff=0xaa ,从机的sbuff=0x55 ,下面将分步对spi的8个时钟周期的数据情况演示一遍(假设上升沿发送数据)。------------------------------------------------

文档评论(0)

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

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

1亿VIP精品文档

相关文档