OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3652|回复: 3

spi中断处理函数不被执行...

[复制链接]

9

主题

50

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2014-5-28
在线时间
16 小时
发表于 2016-6-15 15:50:15 | 显示全部楼层 |阅读模式
9金钱
本帖最后由 any_014 于 2016-6-15 15:51 编辑

stm32作为从设备,要通过spi2和主设备通讯。
现在是用中断接收数据的,接收完一帧信息后置个标志位。
主程序里有个函数,函数中判断spi接收标志位,如果是1的话,通过串口将接收到的数据发送出来。

以上这部分,磕磕碰碰的算是调通了(画了很久)。主函数里不能只做spi通讯部分吧,然后加上其他程序部分。结果spi通讯这里就不工作了...

  •         while(1)
  •         {
  •                 SPI2_SalveProcess();
  •                 printf("\r\n\r\nhahaha);
  •         }



主函数里的第一个语句,是spi2通讯部分的函数,如果只保留这个,通讯没问题。然后在其后随便加了个printf语句,结果spi通讯就不工作了...
具体现象是,不再通过串口将接收到的数据发送过来,并且作为spi从设备,接收数据的同时,应该也发送数据,结果,没有数据发出去。

以下为SPI2_SalveProcess()函数:
  • void SPI2_SalveProcess()
  • {
  •         u8 i;
  •         if(COMP_OK())
  •         {
  •                 LVDS_EN(0);
  •         }
  •         else
  •         {
  •                 if(GPIO_ReadInputDataBit(GPIOC, GPIO_Pin_7) == 0)
  •                 {
  •                         LVDS_EN(1);
  •                         SPI_I2S_SendData(SPI2, spi2RecvBuff[0]);
  •                 }
  •         }
  •         if(spi2RecvOk == 1)
  •         {
  •                 printf("\r\nSPI2 recive sucess");
  •                 for(i = 0; i < 5; i++)
  •                         printf("\r\nspi2RecvBuff[%d]: %04x", i, spi2RecvBuff);
  •                 spi2RecvOk = 0;
  •                 spi2RecvNum = 0;
  •         }
  • }




以下为spi2中断处理函数:
  • void SPI2_IRQHandler(void)
  • {
  •         u16 spi2Temp;
  •         spi2Temp = SPI_I2S_ReceiveData(SPI2);
  •         if(spi2RecvOk == 0)
  •         {
  •                 if(spi2RecvNum == 0)
  •                 {
  •                         if((spi2Temp & 0xff00) == 0x3a00)
  •                         {
  •                                 SPI_I2S_SendData(SPI2, spi2SendBuff[1]);
  •                                 spi2RecvBuff[0] = spi2Temp;
  •                                 spi2RecvNum = 1;
  •                                 spi2SendNum = 2;
  •                         }
  •                         else
  •                                 SPI_I2S_SendData(SPI2, spi2SendBuff[0]);
  •                 }
  •                 else
  •                 {
  •                         SPI_I2S_SendData(SPI2, spi2SendBuff[spi2SendNum]);
  •                         spi2RecvBuff[spi2RecvNum] = spi2Temp;
  •                         spi2RecvNum++;
  •                         if(spi2RecvNum > 4)
  •                                 spi2RecvOk = 1;
  •                         spi2SendNum += 1;
  •                         spi2SendNum %= 5;
  •                 }
  •         }
  • }



串口只开了接收中断,并且,现在的操作,并没有通过串口向单片机发送数据。
spi2也只是开了接收中断。
以下为中断优先级配置:
  • void NVIC_Configuration(void)
  • {
  •         NVIC_InitTypeDef NVIC_InitStructure;
  •         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  •         NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  •         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;
  •         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
  •         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  •         NVIC_Init(&NVIC_InitStructure);
  •         NVIC_InitStructure.NVIC_IRQChannel = SPI2_IRQn;
  •         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  •         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
  •         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  •         NVIC_Init(&NVIC_InitStructure);
  •         NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn;
  •         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3;
  •         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
  •         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  •         NVIC_Init(&NVIC_InitStructure);
  •         NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;
  •         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 3;
  •         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;
  •         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  •         NVIC_Init(&NVIC_InitStructure);
  • }




最佳答案

查看完整内容[请看2#楼]

SPI2_SalveProcess()函数里包含这部分,这部分是检测COMP_OK管脚,使LVDS_EN管脚和它反向。 函数里再加上其他部分,整个扫描周期变长,是的LVDS_EN不能及时反转,所以SPI信号过不来。 现在想,应该是这个问题。 如果是这样的话,只能把COMP_OK改成外部中断了。 [mw_shl_code=c,true] if(COMP_OK() != 0) { LVDS_EN(0); } else { if(GPIO_ReadInputDataBit(GPIOC, GPIO_Pin_7) == 0) { LVDS_EN(1); ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

9

主题

50

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2014-5-28
在线时间
16 小时
 楼主| 发表于 2016-6-15 15:50:16 | 显示全部楼层
SPI2_SalveProcess()函数里包含这部分,这部分是检测COMP_OK管脚,使LVDS_EN管脚和它反向。
函数里再加上其他部分,整个扫描周期变长,是的LVDS_EN不能及时反转,所以SPI信号过不来。
现在想,应该是这个问题。
如果是这样的话,只能把COMP_OK改成外部中断了。

[mw_shl_code=c,true]        if(COMP_OK() != 0)
        {
                LVDS_EN(0);               
        }
        else
        {
                if(GPIO_ReadInputDataBit(GPIOC, GPIO_Pin_7) == 0)
                {
                        LVDS_EN(1);
                        SPI_I2S_SendData(SPI2, spi2RecvBuff[0]);       
                }
        }[/mw_shl_code]
回复

使用道具 举报

0

主题

183

帖子

0

精华

高级会员

Rank: 4

积分
684
金钱
684
注册时间
2016-1-27
在线时间
184 小时
发表于 2016-6-15 16:46:11 | 显示全部楼层
不知道你SPI通讯时数据与数据之间的间隔是多少时间?
示波器挂一下,看看有没有时钟?
回复

使用道具 举报

9

主题

50

帖子

0

精华

初级会员

Rank: 2

积分
128
金钱
128
注册时间
2014-5-28
在线时间
16 小时
 楼主| 发表于 2016-6-15 17:12:24 | 显示全部楼层
不吃鱼的老鼠 发表于 2016-6-15 16:46
不知道你SPI通讯时数据与数据之间的间隔是多少时间?
示波器挂一下,看看有没有时钟?

现在有点眉目了。
用示波器测了下波形。
LVDS_EN这个管脚一直是高电平,这是个电子开关的使能脚,低电平时才有SPI信号过来。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-12 12:27

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表