[国嵌攻略][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 @ 2016-03-18 16:54  盛夏夜  阅读(295)  评论(0编辑  收藏  举报