STM32作为SPI从设备中断接收5个数据,有时会出错

2019-07-14 16:20发布

STM32的SPI2口,主设备不停的发送0x3a05,0x010a,0x0100,0x0000,0x9d76;
以上5个16位数据为一帧,每帧间有一段时间间隔。

从设备我是这么处理的,利用SPI2的中断接收。
中断程序里,定义个spi2Num作为存放接收数据的位置,如果spi2Num == 0,先判断接收到的数据是不是帧首,如果是帧首的话,spi2Num = 1,且将接收到的这个数据放到接收数组的第一个位置;
然后再次接受中断时,依次根据spi2Num的值放到数组的相应位置,每次接收数据后,spi2Num++;
如果spi2Num > 4,说明已经接收到5个数据了,将spi2Num清零,并置个标志位,主程序里查询这个标志位,再做相应处理(串口将接收数组发送出来)。

现在的问题是,通过串口发送过来的数据,有时候是正确的。
有时候,上电前两次接收到的是正确的,然后都是错误帧。错误帧的第一二个数据都是0x3a05,其他数据依次往后推,最后一个没了。
接收错误时观察SCL和MOSI管脚波形,主机发送的数据是正确的。

以下为产生错误时的MSOI波形图,串口发送的数据,以及工程文件。



1s定时到。
spirecive[0]: 3a05
spirecive[1]: 10a
spirecive[2]: 100
spirecive[3]: 0
spirecive[4]: 9d76
1s定时到。
spirecive[0]: 3a05
spirecive[1]: 3a05
spirecive[2]: 100
spirecive[3]: 0
spirecive[4]: 9d76
1s定时到。
spirecive[0]: 3a05
spirecive[1]: 10a
spirecive[2]: 100
spirecive[3]: 0
spirecive[4]: 9d76
1s定时到。
spirecive[0]: 3a05
spirecive[1]: 10a
spirecive[2]: 100
spirecive[3]: 0
spirecive[4]: 9d76
1s定时到。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
4条回答
wacylee
2019-07-15 07:48
本帖最后由 yonghuzhuce 于 2016-6-8 10:32 编辑

更改了程序,删掉大部分功能。spi2中断接受数据后放到一个30个数据的数组里,接受够30个数据,置个标志位。
主程序里检测到这个标志位后,将30个数据用串口打印出来,如果是3a开头的,前边多加个空行。打印完后,清标志位,继续接受。

spi2RecvTemp[14]:0100
spi2RecvTemp[15]:0000
spi2RecvTemp[16]:9d76

spi2RecvTemp[17]:3a05

spi2RecvTemp[18]:3a05

spi2RecvTemp[19]:010a
spi2RecvTemp[20]:0100
spi2RecvTemp[21]:0000
spi2RecvTemp[22]:9d76

spi2RecvTemp[23]:3a05
spi2RecvTemp[24]:010a
spi2RecvTemp[25]:0100
spi2RecvTemp[26]:0000
spi2RecvTemp[27]:9d76

spi2RecvTemp[28]:3a05
spi2RecvTemp[29]:010a


spi2RecvTemp[0]:3a05

spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a


spi2RecvTemp[3]:3a05
spi2RecvTemp[4]:010a

spi2RecvTemp[5]:3a05
spi2RecvTemp[6]:010a


spi2RecvTemp[7]:3a05
spi2RecvTemp[8]:010a
spi2RecvTemp[9]:0100
spi2RecvTemp[10]:0000
spi2RecvTemp[11]:9d76

spi2RecvTemp[12]:3a05
spi2RecvTemp[13]:010a
spi2RecvTemp[14]:0100
spi2RecvTemp[15]:0000
spi2RecvTemp[16]:9d76

spi2RecvTemp[17]:3a05

spi2RecvTemp[18]:3a05
spi2RecvTemp[19]:010a
spi2RecvTemp[20]:0100
spi2RecvTemp[21]:0000
spi2RecvTemp[22]:9d76

spi2RecvTemp[23]:3a05
spi2RecvTemp[24]:010a


spi2RecvTemp[25]:3a05
spi2RecvTemp[26]:010a
spi2RecvTemp[27]:0100
spi2RecvTemp[28]:0000
spi2RecvTemp[29]:9d76


spi2RecvTemp[0]:3a05


spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a
spi2RecvTemp[8]:0100
spi2RecvTemp[9]:0000
spi2RecvTemp[10]:9d76

spi2RecvTemp[11]:3a05
spi2RecvTemp[12]:010a
spi2RecvTemp[13]:0100
spi2RecvTemp[14]:0000
spi2RecvTemp[15]:9d76

spi2RecvTemp[16]:3a05
spi2RecvTemp[17]:010a
spi2RecvTemp[18]:0100
spi2RecvTemp[19]:0000
spi2RecvTemp[20]:9d76

spi2RecvTemp[21]:3a05
spi2RecvTemp[22]:010a
spi2RecvTemp[23]:0100
spi2RecvTemp[24]:0000
spi2RecvTemp[25]:9d76

spi2RecvTemp[26]:3a05
spi2RecvTemp[27]:010a
spi2RecvTemp[28]:0100
spi2RecvTemp[29]:0000


spi2RecvTemp[0]:3a05

spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a
spi2RecvTemp[8]:0100
spi2RecvTemp[9]:0000
spi2RecvTemp[10]:9d76

spi2RecvTemp[11]:3a05
spi2RecvTemp[12]:010a
spi2RecvTemp[13]:0100
spi2RecvTemp[14]:0000
spi2RecvTemp[15]:9d76

spi2RecvTemp[16]:3a05
spi2RecvTemp[17]:010a
spi2RecvTemp[18]:0100
spi2RecvTemp[19]:0000
spi2RecvTemp[20]:9d76

spi2RecvTemp[21]:3a05
spi2RecvTemp[22]:010a
spi2RecvTemp[23]:0100
spi2RecvTemp[24]:0000

spi2RecvTemp[25]:3a05
spi2RecvTemp[26]:010a
spi2RecvTemp[27]:0100
spi2RecvTemp[28]:0000
spi2RecvTemp[29]:9d76


spi2RecvTemp[0]:3a05

spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a
spi2RecvTemp[8]:0100
spi2RecvTemp[9]:0000
spi2RecvTemp[10]:9d76

spi2RecvTemp[11]:3a05
spi2RecvTemp[12]:010a
spi2RecvTemp[13]:0100
spi2RecvTemp[14]:0000
spi2RecvTemp[15]:9d76

spi2RecvTemp[16]:3a05
spi2RecvTemp[17]:010a
spi2RecvTemp[18]:0100
spi2RecvTemp[19]:0000
spi2RecvTemp[20]:9d76

spi2RecvTemp[21]:3a05
spi2RecvTemp[22]:010a
spi2RecvTemp[23]:0100


spi2RecvTemp[24]:3a05
spi2RecvTemp[25]:010a
spi2RecvTemp[26]:0100
spi2RecvTemp[27]:0000
spi2RecvTemp[28]:9d76

spi2RecvTemp[29]:3a05


spi2RecvTemp[0]:3a05


spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a
spi2RecvTemp[8]:0100
spi2RecvTemp[9]:0000
spi2RecvTemp[10]:9d76

spi2RecvTemp[11]:3a05
spi2RecvTemp[12]:010a
spi2RecvTemp[13]:0100
spi2RecvTemp[14]:0000
spi2RecvTemp[15]:9d76

spi2RecvTemp[16]:3a05
spi2RecvTemp[17]:010a
spi2RecvTemp[18]:0100
spi2RecvTemp[19]:0000
spi2RecvTemp[20]:9d76

spi2RecvTemp[21]:3a05
spi2RecvTemp[22]:010a
spi2RecvTemp[23]:0100


spi2RecvTemp[24]:3a05
spi2RecvTemp[25]:010a
spi2RecvTemp[26]:0100
spi2RecvTemp[27]:0000
spi2RecvTemp[28]:9d76

spi2RecvTemp[29]:3a05


spi2RecvTemp[0]:3a05


spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a


spi2RecvTemp[8]:3a05
spi2RecvTemp[9]:010a
spi2RecvTemp[10]:0100
spi2RecvTemp[11]:0000
spi2RecvTemp[12]:9d76

spi2RecvTemp[13]:3a05
spi2RecvTemp[14]:010a
spi2RecvTemp[15]:0100
spi2RecvTemp[16]:0000
spi2RecvTemp[17]:9d76

spi2RecvTemp[18]:3a05
spi2RecvTemp[19]:010a
spi2RecvTemp[20]:0100
spi2RecvTemp[21]:0000
spi2RecvTemp[22]:9d76

spi2RecvTemp[23]:3a05
spi2RecvTemp[24]:010a
spi2RecvTemp[25]:0100
spi2RecvTemp[26]:0000
spi2RecvTemp[27]:9d76

spi2RecvTemp[28]:3a05
spi2RecvTemp[29]:010a


spi2RecvTemp[0]:3a05

spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a


spi2RecvTemp[8]:3a05
spi2RecvTemp[9]:010a
spi2RecvTemp[10]:0100
spi2RecvTemp[11]:0000
spi2RecvTemp[12]:9d76

spi2RecvTemp[13]:3a05
spi2RecvTemp[14]:010a
spi2RecvTemp[15]:0100
spi2RecvTemp[16]:0000
spi2RecvTemp[17]:9d76

spi2RecvTemp[18]:3a05
spi2RecvTemp[19]:010a
spi2RecvTemp[20]:0100
spi2RecvTemp[21]:0000
spi2RecvTemp[22]:9d76

spi2RecvTemp[23]:3a05
spi2RecvTemp[24]:010a
spi2RecvTemp[25]:0100
spi2RecvTemp[26]:0000
spi2RecvTemp[27]:9d76

spi2RecvTemp[28]:3a05
spi2RecvTemp[29]:010a


spi2RecvTemp[0]:3a05


spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a


spi2RecvTemp[8]:3a05
spi2RecvTemp[9]:010a
spi2RecvTemp[10]:0100
spi2RecvTemp[11]:0000

spi2RecvTemp[12]:3a05
spi2RecvTemp[13]:010a
spi2RecvTemp[14]:0100
spi2RecvTemp[15]:0000
spi2RecvTemp[16]:9d76

spi2RecvTemp[17]:3a05
spi2RecvTemp[18]:010a
spi2RecvTemp[19]:0100
spi2RecvTemp[20]:0000
spi2RecvTemp[21]:9d76

spi2RecvTemp[22]:3a05
spi2RecvTemp[23]:010a
spi2RecvTemp[24]:0100
spi2RecvTemp[25]:0000
spi2RecvTemp[26]:9d76

spi2RecvTemp[27]:3a05
spi2RecvTemp[28]:010a
spi2RecvTemp[29]:0100


spi2RecvTemp[0]:3a05

spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a


spi2RecvTemp[8]:3a05
spi2RecvTemp[9]:010a
spi2RecvTemp[10]:0100
spi2RecvTemp[11]:0000

spi2RecvTemp[12]:3a05
spi2RecvTemp[13]:010a
spi2RecvTemp[14]:0100
spi2RecvTemp[15]:0000
spi2RecvTemp[16]:9d76

spi2RecvTemp[17]:3a05
spi2RecvTemp[18]:010a
spi2RecvTemp[19]:0100
spi2RecvTemp[20]:0000
spi2RecvTemp[21]:9d76

spi2RecvTemp[22]:3a05
spi2RecvTemp[23]:010a
spi2RecvTemp[24]:0100
spi2RecvTemp[25]:0000
spi2RecvTemp[26]:9d76

spi2RecvTemp[27]:3a05
spi2RecvTemp[28]:010a
spi2RecvTemp[29]:0100


spi2RecvTemp[0]:3a05

spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a


spi2RecvTemp[8]:3a05
spi2RecvTemp[9]:010a
spi2RecvTemp[10]:0100
spi2RecvTemp[11]:0000

spi2RecvTemp[12]:3a05
spi2RecvTemp[13]:010a
spi2RecvTemp[14]:0100
spi2RecvTemp[15]:0000

spi2RecvTemp[16]:3a05
spi2RecvTemp[17]:010a
spi2RecvTemp[18]:0100
spi2RecvTemp[19]:0000
spi2RecvTemp[20]:9d76

spi2RecvTemp[21]:3a05
spi2RecvTemp[22]:010a
spi2RecvTemp[23]:0100
spi2RecvTemp[24]:0000
spi2RecvTemp[25]:9d76

spi2RecvTemp[26]:3a05
spi2RecvTemp[27]:010a
spi2RecvTemp[28]:0100
spi2RecvTemp[29]:0000


spi2RecvTemp[0]:3a05


spi2RecvTemp[1]:3a05
spi2RecvTemp[2]:010a
spi2RecvTemp[3]:0100
spi2RecvTemp[4]:0000
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a


spi2RecvTemp[8]:3a05
spi2RecvTemp[9]:010a
spi2RecvTemp[10]:0100
spi2RecvTemp[11]:0000

spi2RecvTemp[12]:3a05
spi2RecvTemp[13]:010a
spi2RecvTemp[14]:0100
spi2RecvTemp[15]:0000

spi2RecvTemp[16]:3a05
spi2RecvTemp[17]:010a
spi2RecvTemp[18]:0100
spi2RecvTemp[19]:0000
spi2RecvTemp[20]:9d76

spi2RecvTemp[21]:3a05
spi2RecvTemp[22]:010a
spi2RecvTemp[23]:0100
spi2RecvTemp[24]:0000
spi2RecvTemp[25]:9d76

spi2RecvTemp[26]:3a05
spi2RecvTemp[27]:010a
spi2RecvTemp[28]:0100
spi2RecvTemp[29]:0000


spi2RecvTemp[0]:3a05
spi2RecvTemp[1]:010a
spi2RecvTemp[2]:0100
spi2RecvTemp[3]:0000
spi2RecvTemp[4]:9d76

spi2RecvTemp[5]:3a05
spi2RecvTemp[6]:010a
spi2RecvTemp[7]:0100
spi2RecvTemp[8]:0000
spi2RecvTemp[9]:9d76

spi2RecvTemp[10]:3a05
spi2RecvTemp[11]:010a
spi2RecvTemp[12]:0100
spi2RecvTemp[13]:0000
spi2RecvTemp[14]:9d76

spi2RecvTemp[15]:3a05
spi2RecvTemp[16]:010a
spi2RecvTemp[17]:0100
spi2RecvTemp[18]:0000
spi2RecvTemp[19]:9d76

spi2RecvTemp[20]:3a05
spi2RecvTemp[21]:010a
spi2RecvTemp[22]:0100
spi2RecvTemp[23]:0000
spi2RecvTemp[24]:9d76

spi2RecvTemp[25]:3a05
spi2RecvTemp[26]:010a
spi2RecvTemp[27]:0100
spi2RecvTemp[28]:0000
spi2RecvTemp[29]:9d76


spi2RecvTemp[0]:3a05
spi2RecvTemp[1]:010a
spi2RecvTemp[2]:0100
spi2RecvTemp[3]:0000
spi2RecvTemp[4]:9d76

spi2RecvTemp[5]:3a05
spi2RecvTemp[6]:010a
spi2RecvTemp[7]:0100
spi2RecvTemp[8]:0000
spi2RecvTemp[9]:9d76

spi2RecvTemp[10]:3a05
spi2RecvTemp[11]:010a
spi2RecvTemp[12]:0100
spi2RecvTemp[13]:0000
spi2RecvTemp[14]:9d76

spi2RecvTemp[15]:3a05
spi2RecvTemp[16]:010a
spi2RecvTemp[17]:0100
spi2RecvTemp[18]:0000
spi2RecvTemp[19]:9d76

spi2RecvTemp[20]:3a05
spi2RecvTemp[21]:010a
spi2RecvTemp[22]:0100

spi2RecvTemp[23]:3a05
spi2RecvTemp[24]:010a
spi2RecvTemp[25]:0100
spi2RecvTemp[26]:0000
spi2RecvTemp[27]:9d76

spi2RecvTemp[28]:3a05
spi2RecvTemp[29]:010a


spi2RecvTemp[0]:3a05
spi2RecvTemp[1]:010a
spi2RecvTemp[2]:0100
spi2RecvTemp[3]:0000
spi2RecvTemp[4]:9d76
spi2RecvTemp[5]:9d76

spi2RecvTemp[6]:3a05
spi2RecvTemp[7]:010a
spi2RecvTemp[8]:0100
spi2RecvTemp[9]:0000
spi2RecvTemp[10]:9d76

spi2RecvTemp[11]:3a05
spi2RecvTemp[12]:010a
spi2RecvTemp[13]:0100
spi2RecvTemp[14]:0000
spi2RecvTemp[15]:9d76

spi2RecvTemp[16]:3a05
spi2RecvTemp[17]:010a
spi2RecvTemp[18]:0100
spi2RecvTemp[19]:0000
spi2RecvTemp[20]:9d76

spi2RecvTemp[21]:3a05
spi2RecvTemp[22]:010a
spi2RecvTemp[23]:0100
spi2RecvTemp[24]:0000
spi2RecvTemp[25]:9d76

spi2RecvTemp[26]:3a05
spi2RecvTemp[27]:010a
spi2RecvTemp[28]:0100

看前半部分,好象是有规律的,接受的前两个数据,都是0x3a05。
前两帧有错误,后边开始接受正确了。
我就猜想,可能真的是主设备发送的数据有时候出了问题,联系发送了两个帧首?
看到后半段,貌似大部分又正确了,结果中间有部分丢失后边的数据。
现在只保留了串口中断,SPI中断,定时器中断。
串口只在接受满30个数据并置了标志位后才发送数据,此时虽然有SPI中断,但并不保存数据到数组里。
SPI接受数据时可能影响的只有定时器中断了,不过已经把SPI中断的优先级设最高了。
一会试试关掉定时器。

一周热门 更多>