linux下QT基于socket的can网络通信

这篇博客介绍了如何在Linux环境下使用QT基于Socket进行CAN网络通信。文章提供了Can_Control类的cpp代码,包含can_send()和can_recv()示例函数,并强调了链接函数在开启和配置CAN通信中的作用。博主提醒,当前实现可能存在优化空间,期待读者的参与和分享。此外,文章提及在接收数据时遇到的问题,即如何实现一次发送多包数据。
摘要由CSDN通过智能技术生成

附上Linux下周立功can配置文档:

 

1.cpp代码

Can_Control::Can_Control()
{


}
    int Can_Control::can_send()
    {
        int stSocket_LO, stSend_LO;
        struct sockaddr_can addr; //can总线的地址 同socket编程里面的 socketaddr结构体 用来设置can外设的信息
        struct ifreq ifr;//接口请求结构体

        struct can_frame frame[2] = {
  {0}}; //要发送的buffer
        /* 创建socket套接字
        PF_CAN 为域位 同网络编程中的AF_INET 即ipv4协议
        SOCK_RAW使用的协议类型 SOCK_RAW表示原始套接字 报文头由自己创建
        CAN_RAW为使用的具体协议 为can总线协议
        */
        stSocket_LO = socket(PF_CAN, SOCK_RAW, CAN_RAW);//创建套接字
        strcpy(ifr.ifr_name, "can0" );
        ioctl(stSocket_LO, SIOCGIFINDEX, &ifr); //指定 can0 设备
        addr.can_family = AF_CAN; //协议类型
        addr.can_ifindex = ifr.ifr_ifindex; //can总线外设的具体索引 类似 ip地址
        bind(stSocket_LO, (struct sockaddr *)&addr, sizeof(addr));//将套接字和canbus外设进行绑定,即套接字与 can0 绑定
        //禁用过滤规则,本进程不接收报文,只负责发送
        setsockopt(stSocket_LO, SOL_CAN_RAW, CAN_RAW_FILTER, NULL, 0);
        //生成两个报文
        frame[0].can_id = 0x11;
        frame[0]. can_dlc = 1;
        frame[0].data[0] = '1';
        frame[1].can_id = 0x22;
        frame[1]. can_dlc = 1;
        frame[1].data[0] = '2';
        //循环发送两个报文
    while(1)
        {
            stSend_LO = write(stSocket_LO, &frame[0], sizeof(frame[0])); //发送 frame[0]
            if(stSend_LO != sizeof(frame[0]))
            {
                printf("Send Error frame[0]\n!");
                break; //发送错误,退出
            }
            sleep(1);
            stSend_LO = write(stSocket_LO, &frame[1], sizeof(frame[1])); //发送 frame[1]
            if(stSend_LO != sizeof(frame[0]))
            {
                printf("Send Error frame[1]\n!");
                break;
            }
        sleep(1);
        }
        close(stSocket_LO);//关闭套
  • 7
    点赞
  • 70
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
Linux下面QT写Can通信程序,网络上有很多例子都是互相抄的;本人因为项目原因,通过源代码Socket函数,写了完整的程序,含有2个案例;分享给大家; 这里主要是包含几个步骤,1:绑定Socket;2:cna/can1的设置,3:波特率的设置(如果发送和接收波特率不一致肯定不行的);4:发送;5:接收处理; 下面就贴出部分代码: void MyWindow::startcan(int number) { int ret = 0; //can先关闭 设置好波特率后 再开启can if(number == 0) //can0 { system("ifconfig can0 down");//先关闭 system("ip link set can0 up type can bitrate 50000 triple-sampling on");//设置波特率 system("ifconfig can0 up");//再开启 } else //can1 { system("ifconfig can1 down");//先关闭 system("ip link set can1 up type can bitrate 50000 triple-sampling on");//设置波特率 system("ifconfig can1 up");//再开启 } socket = ::socket(PF_CAN,SOCK_RAW,CAN_RAW); struct ifreq ifr; strcpy((char *)(ifr.ifr_name),number == 0 ? "can0" : "can1"); ioctl(socket,SIOCGIFINDEX,&ifr); addr.can_family = AF_CAN; addr.can_ifindex = ifr.ifr_ifindex; ret = bind(socket,(struct sockaddr*)&addr,sizeof(addr)); if (ret OpenCan(50000); ArmCan = new Thread(zyhapi,socket,port); ArmCan->start(); } void MyWindow::stopcan(int number) { if(ArmCan) { ArmCan->stop(); ArmCan->terminate(); ArmCan->wait(); } zyhapi->CloseCan(number); } //发送 void MyWindow::on_sendbtn_clicked() { /* struct can_frame frame; memset(&frame,0,sizeof(struct can_frame)); std::string str=ui->edit->text().toStdString(); if(str.length() > 8) { QMessageBox::about(this,"error","length of send string must less than 8 bytes"); return; } */ struct can_frame frame; memset(&frame,0,sizeof(struct can_frame)); char buf[8]={0X20,0XFF,0X01,0X02,0X03,0X04,0XFF,0XFF}; frame.can_id = 0x00000020;//发出去的帧ID即:0X00000020 frame.can_dlc = 8;//帧数据长度 for(int i=0;i<frame.can_dlc;i++) { frame.data[i]=buf[i];//帧数据 } //frame.can_id = 0x123; //strcpy((char*)frame.data,str.c_str()); //frame.can_dlc = str.length(); sendto(socket,&frame,sizeof(struct can_frame),0,(struct sockaddr*)&addr,sizeof(addr)); /* struct can_frame frame; char buf[8]={0X20,0XFF,0X01,0X02,0X03,0X04,0XFF,0XFF}; frame.can_id = 0x00000020;//发出去的帧ID即:0X00000020 frame.can_dlc = 8;//帧数据长度 for(int i=0;iWriteCan(frame.can_id,frame.data,frame.can_dlc);//发数据,通过can端口-- 暂时默认 CAN0 端口 */ }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值