上面一篇文章是讲述碰到的问题,还纠结了很久。实际上是手头资料太少了,对于芯片寄存器描述的资料里面有说到。
因此,“只发”或者是“只收”,只要在BIDIMODE寄存器上配置了单线双向模式,必须要将主设备的MOSI和从设备的MISO接在一块儿。如果是双线模式,即是MISO接MISO,就用不着反接了。
还有一个问题就是,由于是霍尔传感器,对于数据传输的时序要求也比较高。
在传输数据的时候除去单纯拉低片选拉高片选之外,也要注意时钟信号的开关。严格按照时序要求给,收到的数据后面就稳定且准确了。
部门哥哥说这个直接操作寄存器的效率比调用库函数更高 ,用库函数有一点延时。
贴一下部门哥哥写的框架,真的好厉害。考虑真的很周全,感觉指针的用法真的需要好好学习。
static void Init_data_buf(uint8_t *buf,uint8_t len)
{
uint8_t i = 0;
for (i=0;i<len;i++)
{
buf[i] = 0;
}
}
uint8_t* SPI_I2S_ReadData(uint8_t Dev_num)
{
Init_data_buf(recie_buf,sizeof(recie_buf));
Init_data_buf(fiil_buf,sizeof(fiil_buf));
HoneyO60md.DevState = 0;
switch (Dev_num)
{
case DEV_model_NO1:
DEV_model_NO1_ENABLE;
Delay_us(1);
SPI_Cmd(SPI2, ENABLE);
Delay_us(10);
recie_buf[0] = SPI2_ReadWriteByte(0);
recie_buf[1] = SPI2_ReadWriteByte(0);
recie_Data_Deal(&recie_buf[0], &fiil_buf[0]);
SPI2->CR1 &= 0xFFBF;
Delay_us(10);
DEV_model_NO1_DISABLE;
break;
case DEV_model_NO2:
DEV_model_NO2_ENABLE;
recie_buf[0]=SPI2_ReadWriteByte(0xff);
Delay_us(20);
DEV_model_NO2_DISABLE;
break;
case DEV_model_NO3:
DEV_model_NO3_ENABLE;
recie_buf[0]=SPI2_ReadWriteByte(0);
DEV_model_NO3_DISABLE;
break;
default:
break;
}
return &fiil_buf[0];
}
void recie_Data_Deal(unsigned char *buf,unsigned char *sebuf)
{
unsigned int PressH, PressL = 0;
deal_start=1;
HoneyO60md.DevState = ((buf[1]&(~0x3f))>>6);
}