STM32 SPI2问题

STM32 SPI2问题,第1张

while (SPI_I2S_GetFlagStatus(SPI1, SPI_I2S_FLAG_TXE) == RESET)

姐姐,您里面是获取SPI1的TXE标志位,好锋而您是对SPI2做的初始化。。。后面有向SPI2发数据。。。SPI1根本就没睁兄初始化过,所以TXE状态友早晌位为0初始态

定义了变量key,使用key的代码为:key = SPI2_ReadWriteByte(0x00);执行函数并将函数返回值赋值给key,没有使用这个返回。

比如

int b=a;

从a中读取数据负值给b.

其实,我是感觉声明罩棚圆和负值的地方离那么远很奇怪。

反正循环里面又不用,为什么不到负值的时候才声明。

扩展资料:

使用变物塌量并不需要了解变量在计算机内存中的地址,只要通过变量名引用变量就可以查看或更改变量的值。在VB Script中只有一个基本数据类型,即Variant,因此所有变量的数据类型都是Variant。

例如,可以创建一个名为Click Count的变量和启来存储用户单击Web页面上某个对象的次数。

参考资料来源:百度百科-变量

这个问题需要有实物调试,

原因可能有很多,硬件,软件方面。

思路是:

先排除硬件问题,用这个SPI通道测试一下其他通讯

再仔细对照一下AD7190的规格书,看看初始化,设置是否正确,

然后再检查一下发送接收的过程和步骤是否正确。

整理一下代码:

void SPI_Init(void)

{

 RCC->APB2ENR|=1<<3 //PB的时钟使能

 RCC->APB1ENR|=1<<14 //SPI2时钟使能

 GPIOB->CRH&=0X000F0FFF //PB11 PB13 PB15复用推挽 PB14浮空输入

 GPIOB->CRH|=0XB4B0B000

 GPIOB->ODR|=1<<11 //上拉

 GPIOB->ODR|=1<<13

 GPIOB->ODR|=1<<15

 SPI2->CR1|=0<<10  //全双工

 简枣SPI2->CR1|=1<<9   //软件SSM,NSS引脚的电平由SSI位的值决定

 SPI2->CR1|=1<<8   //SSI位

 SPI2->CR1|=1<<2   //配置为主设备

 SPI2->CR1|=0<<11  //使拦歼拆用8位数据格式

 SPI2->CR1|=1<<1   //空闲状态sck=1保持高电平

 SPI2->CR1|=1<<0   //数据采样从第二个时钟边沿开始

 SPI2->CR1|=3<<3 改基   //fsck=36M/16 波特率控制

 SPI2->CR1|=0<<7 //先发送MSB 

 SPI2->CR1|=1<<6 //使能spi设备

}

void SPI2_Send_ReveiceFull(u8 *data,u8 len)

{

CS=0

for(i=0i<leni++)

{

while((SPI2->SR&(1<<1))==0) //检查spi标志位设置与否,发送缓存空标志位TXE=1为空跳出

SPI2->DR=*(data+i)

while((SPI2->SR&(1<<0))==0) //检查指定spi标志位设置与否,接受缓存非空标志位RXNE为非空跳出

temp=SPI2->DR

*(AD7190_ReveiceData+len-i-1)=temp

}

CS=1

}

void AD7190_Init(void)

{

//复位

AD7190_SendaData[2]=0xff

AD7190_SendaData[1]=0xff

AD7190_SendaData[0]=0xff

SPI2_Send_ReveiceFull(AD7190_SendaData,3)

SPI2_Send_ReveiceFull(AD7190_SendaData,3)

SPI2_Send_ReveiceFull(AD7190_SendaData,3)

//设置配置寄存器

AD7190_SendaData[0]=0x10

SPI2_Send_ReveiceFull(AD7190_SendaData,1)

AD7190_SendaData[2]=0x10   //基准电压选择需确定

AD7190_SendaData[1]=0x03 //通道选择需配置

AD7190_SendaData[0]=0x07 //输入范围 

SPI2_Send_ReveiceFull(AD7190_SendaData,3)

//设置模式寄存器

AD7190_SendaData[0]=0x08

SPI2_Send_ReveiceFull(AD7190_SendaData,1)

AD7190_SendaData[2]=0x10 //使用外部时钟

AD7190_SendaData[1]=0x03

AD7190_SendaData[0]=0xff

SPI2_Send_ReveiceFull(AD7190_SendaData,3)

//读模式

for(i=0i<4i++)AD7190_SendaData[i]=0x00

AD7190_SendaData[0]=0x48

SPI2_Send_ReveiceFull(AD7190_SendaData,1)

AD7190_SendaData[0]=0x00

SPI2_Send_ReveiceFull(AD7190_SendaData,3)

//读配置寄存器

AD7190_SendaData[0]=0x50

SPI2_Send_ReveiceFull(AD7190_SendaData,1)

SPI2_Send_ReveiceFull(AD7190_SendaData,3)

//读数据寄存器

AD7190_SendaData[0]=0x5C //5C

SPI2_Send_ReveiceFull(AD7190_SendaData,1)

AD7190_SendaData[0]=0xff

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/yw/12436833.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存