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

Posted 盛夏夜

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[国嵌攻略][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;

}

以上是关于[国嵌攻略][158][SPI裸机驱动设计]的主要内容,如果未能解决你的问题,请参考以下文章

[国嵌攻略][164][USB驱动程序设计]

[国嵌攻略][155][I2C用户态驱动设计]

[国嵌攻略][117][LED驱动程序设计]

[国嵌攻略][151][nandflash驱动程序设计]

[国嵌攻略][156][I2C自编设备驱动设计]

SPI裸机驱动程序设计