OpenEdv-开源电子网

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

请教一个问题:stm32 can 通信 只能接收一次数据

[复制链接]

2

主题

4

帖子

0

精华

新手入门

积分
5
金钱
5
注册时间
2016-4-23
在线时间
5 小时
发表于 2016-4-27 09:45:15 | 显示全部楼层 |阅读模式
7金钱
用的一个最小系统版加vp230模块作为接收方,另一个开发板作为发送方发送了一次数据后,发送第二次就接收不到了。
不过我将接收方换成另一个开发板就接受几次都没有问题?这是什么情况?
如果我用另一块开发板实验没问题的话那应该不是程序的问题啊?
但是如果是电路问题为什么第一次的数据能接收到呢?
部分程序如下
发送机:
void CAN_SetMsg1(void)
{          
  //TxMessage.StdId=0x00;                                                 
  TxMessage.ExtId=0x1314;                                         //使用的扩展ID
  TxMessage.IDE=CAN_ID_EXT;                                         //扩展模式
  TxMessage.RTR=CAN_RTR_DATA;                                 //发送的是数据
  TxMessage.DLC=1;                                                         //数据长度为2字节
  TxMessage.Data[0]=0xAB;
}

void CAN_SetMsg2(void)
{          
  //TxMessage.StdId=0x00;                                                 
  TxMessage.ExtId=0x1314;                                         //使用的扩展ID
  TxMessage.IDE=CAN_ID_EXT;                                         //扩展模式
  TxMessage.RTR=CAN_RTR_DATA;                                 //发送的是数据
  TxMessage.DLC=1;                                                         //数据长度为2字节
  TxMessage.Data[0]=0xCD;
}

void CAN_SetMsg3(void)
{          
  //TxMessage.StdId=0x00;                                                 
  TxMessage.ExtId=0x1314;                                         //使用的扩展ID
  TxMessage.IDE=CAN_ID_EXT;                                         //扩展模式
  TxMessage.RTR=CAN_RTR_DATA;                                 //发送的是数据
  TxMessage.DLC=1;                                                         //数据长度为2字节
  TxMessage.Data[0]=0x12;
}


int main(void)
{

        /* 配置CAN模块 */
        CAN_Config();  


while(1)
   {
        /*设置要通过CAN发送的信息*/
         if(GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_0) == 0)
         {
         delay(0xffff);
         CAN_SetMsg1();
         CAN_Transmit(CAN1, &TxMessage);
         while(GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_0)==0);
         }


         if(GPIO_ReadInputDataBit(GPIOC, GPIO_Pin_13) == 0)
         {
         delay(0xffff);
         CAN_SetMsg2();
         CAN_Transmit(CAN1, &TxMessage);
         while(GPIO_ReadInputDataBit(GPIOC, GPIO_Pin_13)==0);
         }



         if(GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_8) == 0)
         {
         delay(0xffff);
         CAN_SetMsg3();
         CAN_Transmit(CAN1, &TxMessage);
         while(GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_8)==0);
         }


         if(GPIO_ReadInputDataBit(GPIOD, GPIO_Pin_3) == 0)
         {
         delay(0xffff);
         CAN_SetMsg4();
         CAN_Transmit(CAN1, &TxMessage);
         while(GPIO_ReadInputDataBit(GPIOD, GPIO_Pin_3)==0);
         }
   }
   }

void CAN_SetMsg4(void)
{          
  //TxMessage.StdId=0x00;                                                 
  TxMessage.ExtId=0x1314;                                         //使用的扩展ID
  TxMessage.IDE=CAN_ID_EXT;                                         //扩展模式
  TxMessage.RTR=CAN_RTR_DATA;                                 //发送的是数据
  TxMessage.DLC=1;                                                         //数据长度为2字节
  TxMessage.Data[0]=0x34;
}


接收机:
void USB_LP_CAN1_RX0_IRQHandler(void)
{
   
  CAN_Receive(CAN1, CAN_FIFO0, &RxMessage);
  /* 比较是否是发送的数据和ID */
  if((RxMessage.ExtId==0x1314) && (RxMessage.IDE==CAN_ID_EXT)
     && (RxMessage.DLC==1) && (RxMessage.Data[0]==0xAB))
  {
    flag = 0;

    GPIO_SetBits(GPIOE, GPIO_Pin_0);                                               //接收成功
  }
  else
  {
    flag = 0xff;                                            //接收失败
  }
  if((RxMessage.ExtId==0x1314) && (RxMessage.IDE==CAN_ID_EXT)
     && (RxMessage.DLC==1) && (RxMessage.Data[0]==0xCD))
  {                                                                                                                               
    flag = 0;
     GPIO_ResetBits(GPIOE, GPIO_Pin_0);                                               //接收成功
  }
  else
  {
    flag = 0xff;                                            //接收失败
  }
    if((RxMessage.ExtId==0x1314) && (RxMessage.IDE==CAN_ID_EXT)
     && (RxMessage.DLC==1) && (RxMessage.Data[0]==0x12))
  {
    flag = 0;
      GPIO_SetBits(GPIOE, GPIO_Pin_0);                                               //接收成功
  }
  else
  {
    flag = 0xff;                                            //接收失败
  }
    if((RxMessage.ExtId==0x1314) && (RxMessage.IDE==CAN_ID_EXT)
     && (RxMessage.DLC==1) && (RxMessage.Data[0]==0x34))
  {
    flag = 0;
    GPIO_ResetBits(GPIOE, GPIO_Pin_0);                                               //接收成功
  }
  else
  {
    flag = 0xff;                                            //接收失败
  }
}

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

26

主题

201

帖子

0

精华

高级会员

Rank: 4

积分
606
金钱
606
注册时间
2013-12-14
在线时间
125 小时
发表于 2016-4-27 09:58:34 | 显示全部楼层
你用一个led判断接收成功和失败?
回复

使用道具 举报

2

主题

4

帖子

0

精华

新手入门

积分
5
金钱
5
注册时间
2016-4-23
在线时间
5 小时
 楼主| 发表于 2016-4-27 10:13:47 | 显示全部楼层
lialong1989 发表于 2016-4-27 09:58
你用一个led判断接收成功和失败?

恩,主要是我要用can来控制继电器。你的意思是我要用寄存器来看看是不是真的发送成功么?
回复

使用道具 举报

26

主题

201

帖子

0

精华

高级会员

Rank: 4

积分
606
金钱
606
注册时间
2013-12-14
在线时间
125 小时
发表于 2016-4-27 10:44:10 | 显示全部楼层
chenzeyu1994 发表于 2016-4-27 10:13
恩,主要是我要用can来控制继电器。你的意思是我要用寄存器来看看是不是真的发送成功么?

可以debug,在can接收中断中添加一个全局变量,进一次中断,这个变量+1,就可以排除是哪里的问题了
回复

使用道具 举报

354

主题

1475

帖子

12

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
8093
金钱
8093
注册时间
2015-10-15
在线时间
2918 小时
发表于 2016-4-28 12:01:33 | 显示全部楼层
最好是debug一下。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-18 09:13

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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