3.2 SPI硬件时序方式

上面的3.1小节是采用SPI模拟时序驱动SD NAND,STM32本身集成有SPI硬件模块,可以直接利用STM32硬件SPI接口读写。

下面贴出底层的适配代码。 上面贴出的驱动代码里,已经将驱动接口部分和协议逻辑部分区分开了,替换底层的SIP读写代码非常方便。

(1)主要替换的代码
/*
函数功能:SPI初始化(模拟SPI)
硬件连接:
MISO--->PB14
MOSI--->PB15
SCLK--->PB13
*/
void SPI_Init(void)
{
/*开启时钟*/
RCC->APB1ENR|=1<<14; //开启SPI2时钟
RCC->APB2ENR|=1<<3; //PB
GPIOB->CRH&=0X000FFFFF; //清除寄存器
GPIOB->CRH|=0XB8B00000;
GPIOB->ODR|=0X7<<13; //PB13/14/15上拉--输出高电平
/*SPI2基本配置*/
SPI2->CR1=0X0; //清空寄存器
SPI2->CR1|=0<<15; //选择“双线双向”模式
SPI2->CR1|=0<<11; //使用8位数据帧格式进行发送/接收;
SPI2->CR1|=0<<10; //全双工(发送和接收);
SPI2->CR1|=1<<9; //启用软件从设备管理
SPI2->CR1|=1<<8; //NSS
SPI2->CR1|=0<<7; //帧格式,先发送高位
SPI2->CR1|=0x0<<3;//当总线频率为36MHZ时,SPI速度为18MHZ,高速。
SPI2->CR1|=1<<2; //配置为主设备
SPI2->CR1|=1<<1; //空闲状态时, SCK保持高电平。
SPI2->CR1|=1<<0; //数据采样从第二个时钟边沿开始。
SPI2->CR1|=1<<6; //开启SPI设备。
}

/*
函数功能:SPI读写一个字节
*/
u8 SPI_ReadWriteOneByte(u8 data_tx)
{
u16 cnt=0;
while((SPI2->SR&1<<1)==0) //等待发送区空--等待发送缓冲为空
{
cnt++;
if(cnt>=65530)return 0; //超时退出 u16=2个字节
}
SPI2->DR=data_tx; //发送一个byte
cnt=0;
while((SPI2->SR&1<<0)==0) //等待接收完一个byte
{
cnt++;
if(cnt>=65530)return 0; //超时退出
}
return SPI2->DR; //返回收到的数据
}

函数功能:SD卡底层接口,通过SPI时序向SD卡读写一个字节
函数参数:data是要写入的数据
返 回 值:读到的数据
*/
u8 SDCardReadWriteOneByte(u8 DataTx)
{
return SPI_ReadWriteOneByte(DataTx);
}

(2)运行效果 (, 下载次数: 100)
举报
内容系网友发布,其中涉及到安全隐患的内容系网友个人行为,不代表面包板社区观点
请点击举报理由
关闭 站长推荐上一条 /1 下一条
  • 返回顶部