[国嵌攻略][158][SPI裸机驱动设计]

SPI控制器工作流程

SPI控制器提供2个SPI接口。每个SPI接口有两个通道,分别为TX通道和RX通道。CPU要写数据到FIFO中,先写数据到SPI_TX_DATA寄存器中,这样此寄存器中的内容就会自动移动到发送FIFO中;同理,如果CPU要从接收FIFO中读取数据,就访问寄存器SPI_RX_DATA,紧接着接收FIFO的数据就会自动移动到SPI_RX_DATA寄存器中。

 

OK6410 SPI裸机程序分析

//SPI初始化

u8 SPI_Init(){

//SPI复位

CH_CFG0 |= BIT5;   //SPI软复位

   

//设置引脚

rGPCCON &= ~0xFFFF;

rGPCCON |= 0x2222;

 

//配置CFG寄存器

CH_CFG0 = 0b0111;

 

//配置MODE_CFG0

MODE_CFG0 = (63<<11);

 

//设置时钟

CLK_CFG0 = 100;

CLK_CFG) |= 1<<8;

 

return 0;

}

 

//SPI读写

u32 SPIx_ReadWriteData(u32 TxData){

do{

temp = (SPI_STAS0>>6) & 0x7F;   //获取发送FIFO数据数量

}whlie(temp > 63);   //发送FIFO满了,等待

 

SPI_TXDATA0 = TxData;   //发送数据

 

do{

    temp = (SPI_STAS0>>13) & 0x7F;   //获取接收数据数量

}whlie(temp == 0);   //接收FIFO为空,等待

 

return SPI_RXDATA0;

}

posted @   盛夏夜  阅读(298)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示