Linux CAN通信

Linux CAN通信


        实现了Linux下的CAN通信——初始化,发两个送和接收(采用队列形式),使用两个线程,还有一个超时响应目前未写。接收部分使用select实现。


#ifndef _CAN_H_
#define _CAN_H_#include <stdio.h>
#include <sys/ioctl.h>
#include <arpa/inet.h>
#include <net/if.h>
#include <linux/socket.h>
#include <linux/can.h>
#include <linux/can/error.h>
#include <linux/can/raw.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <time.h>
#include <pthread.h>
#include "can_queue.h"
#include "type.h"#ifndef AF_CAN
#define AF_CAN 29
#endif
#ifndef PF_CAN
#define PF_CAN AF_CAN
#endiftypedef enum
{CAN_PORT_0 = 0, // can0CAN_PORT_1,     // can1
}can_port_t ;typedef struct
{char *name;int fd;fd_set fdsr;pthread_t send_thread;pthread_t recv_thread;pthread_t time_thread;  can_queue_t *send_queue; // 接受和发送的队列can_queue_t *recv_queue;
} can_t;void *CanInit(int arg);#endif /* _CAN_H_ */
#include "can.h"static can_t *can_init(int name)
{int ret;struct sockaddr_can addr;struct ifreq ifr;struct can_filter rfilter[1];can_t *current = (can_t *)malloc(sizeof(can_t));current->fd = Socket(PF_CAN, SOCK_RAW, CAN_RAW);sprintf(ifr.ifr_name, "can%d", name);current->name = (char *)malloc(6);memset(current->name, 0, 6);sprintf(current->name, "can%d", name);ret = ioctl(current->fd, SIOCGIFINDEX, &ifr);if(ret < 0){exit(0);}addr.can_family = AF_CAN;addr.can_ifindex = ifr.ifr_ifindex;Bind(current->fd, (struct sockaddr *)&addr, sizeof(addr));rfilter[0].can_id = 0x2;rfilter[0].can_mask = 0;Setsockopt(current->fd, SOL_CAN_RAW, CAN_RAW_FILTER, &rfilter, sizeof(rfilter));return current;
}static void *can_send_thread(void *arg)
{int ret;can_t *current = arg;can_frame_t frame;uint8_t read_ret = 0;while(1){Write(current->fd, &frame, sizeof(frame));read_ret = current->send_queue->can_read(current->send_queue, &frame);if(CAN_OK == read_ret){ret = Write(current->fd, &frame, sizeof(frame));usleep(1200);}usleep(100);}return NULL;
}static void *can_recv_thread(void *arg)
{int ret, i;can_frame_t frame;struct timeval tv;fd_set rset;can_t *current = arg;while (1){tv.tv_sec = 0;tv.tv_usec = 200;FD_ZERO(&rset);FD_SET(current->fd, &rset);ret = select(current->fd + 1, &rset, NULL, NULL, NULL);if (0 == ret){return NULL;}ret = read(current->fd, &frame, sizeof(frame));if (ret < sizeof(frame)){return NULL;}if (current->recv_queue->can_write(current->recv_queue, &frame) == CAN_ERROR){}}return NULL;
}void *CanInit(int arg)
{can_t *current = can_init(arg);current->recv_queue = CanQueueInit(CAN_RECV_QUEUE_SIZE);current->send_queue = CanQueueInit(CAN_SEND_QUEUE_SIZE);pthread_create(&current->send_thread, NULL, can_send_thread, (void *)current);pthread_create(&current->recv_thread, NULL, can_recv_thread, (void *)current);
}



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/466034.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(四)Kinect人脸识别

kinect可以通过摄动摄像头不仅可以获取人脸位置旋转信息&#xff0c;也可以获取脸部轮廓的三维坐标 可以参考插件中的场景KinectFaceTrackingDemo1-4&#xff0c;在kinectManager基础上需要脚本FacetrackingManager。 1&#xff09;通过KinectManager kinectManager KinectMan…

广东总冠军

lets go tiger 看这篇文章之前&#xff0c;先看看我们看球的视频 恭喜广东拿下总冠军&#xff01; 恭喜胡明轩夺得FMVP&#xff01; 我当时预测的是周鹏或者胡明轩拿下FMVP&#xff0c;最后是胡明轩&#xff0c;广东后场三条枪表现都非常亮眼。如果是上一场广东夺冠&#xff0c…

Spring切入点表达式常用写法

Spring切入点表达式常用写法自从使用AspectJ风格切面配置&#xff0c;使得Spring的切面配置大大简化&#xff0c;但是AspectJ是另外一个开源项目&#xff0c;其规则表达式的语法也稍稍有些怪异。下面给出一些常见示例的写法&#xff1a;比如&#xff0c;下面是一个对Service包上…

每日一题(1) —— 数组计算

判断下面代码是否可执行&#xff1f;如果可执行&#xff0c;执行结果是多少&#xff1f; #include <stdio.h>int main(void) {int array[10] {0, 2, 3, 4, 5, 6, 7, 8, 9, 10};0[array] 1;printf("%d\n", (-1)[array 5]);return 0; } 分析&#xff1a; C语…

SQLAlchemy Script

SQLAlchemy: 1.由于sqlalchemy中没有提供choice方法&#xff0c;所以借助SQLAlchemy-Utils组件提供的choice方法 from sqlalchemy_utils import ChoiceType Base declarative_base() class Xuan(Base): __tablename__ xuan types_choices ( (1,欧美), (2,日韩), (3,老男孩),…

内存文章汇总,并剖析mmap

在看这篇文章之前&#xff0c;可以先看看下面这几篇文章Linux内存&#xff0c;先看这篇文章Linux内存寻址方式Linux虚拟内存TLBLinux物理内存初始化Linux io内存存在的意义~修改cmdline 把内存改成512MB用mtrace定位内存泄漏什么是内存泄漏&#xff1f;Linux内存管理slub分配器…

[综述泛读] A survey on web services composition (IJWGS, 2005)

Time: 2.5 hours Dustdar S, Schreiner W. "A survey on web services composition." International Journal of Web and Grid Services: 1-30. 2005 (30 pages, 单栏) (gs:169) Schahram Dustdar (维也纳技术大学, full prof) Dusdar是Distributed Systems Group的老…

Spring 事务与脏读、不可重复读、幻读

索引&#xff1a; 目录索引 参看代码 GitHub&#xff1a; 1.Spring 事务 2.事务行为 一、Spring 事务: Spring 的事务机制是用统一的机制来处理不同数据访问技术的事务处理。 Spring 的事务机制提供了一个 PlatformTransactionManager 接口&#xff0c;不同的数据访问技术的事务…

韦老师的开发板和嵌入式书籍赠送

大家五一快乐&#xff01;我知道这个时候大家都没有什么心思学习&#xff0c;所以找了联合了几个朋友一起给大家送点东西。这几个技术号主都非常用心的给大家分享技术文章&#xff0c;我相信&#xff0c;跟他们一起&#xff0c;你们也能变得更加优秀。奖品包括&#xff1a;1. 韦…

每日一题(2)—— -2与2的比较

分析下面的代码&#xff0c;求运行结果。 #include <stdio.h>int main(void) {if(-2 > 2){printf("11111\r\n");}else{printf("22222\r\n");}return 0; }分析&#xff1a; -2和2都没有声明存储类型&#xff0c;编译器默认按int存储&#xff0c;所…

正则表达式之道

正则表达式之道 原著&#xff1a;Steve Mansour smanscruznet.com Revised: June 5, 1999 (copied by jm /at/ jmason.org from , after the original disappeared! ) 翻译&#xff1a;Neo Lee neo.leegmail.com 2004年10月16日 英文版原文 译者按&#xff1a;原文因为年代久远…

truffle unbox react 出坑指南

最近几天差点就被这鬼东西给逼疯了&#xff0c;truffle init 、truffle unbox webpack 不管我怎么运行都是对的&#xff0c;唯独truffle unbox react 不管在哪个windows都会报错&#xff0c;换了好几台电脑&#xff0c;心都累完了&#xff0c;还好我坚持了下来&#xff0c;找了…

单片机6年想转嵌入式Linux ,不知如何下手?

刷知乎看到下面这个提问。单片机6年想转嵌入式Linux &#xff0c;不知如何下手&#xff1f;现在挺尴尬&#xff0c;做的单片机产品总是感觉重复重复再重复&#xff0c;想学习点新东西&#xff0c;不知道如何转。说实话&#xff0c;这个问题自己关注了很久。今天就借题主这个问题…

Visual Studio 2008在设计视图和代码视图切换的快捷键F7

使用VS2008的快捷键F7可以在设计器视图和代码视图进行切换&#xff0c;相当于“视图”菜单 ->“代码”&#xff08;或者“设计器”&#xff09;。在设计器视图可以按F7查看源代码&#xff0c;在代码视图可以按F7转到设计界面。 这是VS2008默认的键盘映射方案&#xff0c;…

每日一题(3)—— -2与2的比较(二)

分析下面的代码&#xff0c;求运行结果。 #include <stdio.h>int main(void) {if(-2L > 2UL){printf("11111\r\n");}else{printf("22222\r\n");}return 0; }分析&#xff1a; 常量后面接L表示long型存储&#xff0c;UL表示unsigned long型存储&a…

嵌入式技术面试时的10大潜规则

编排 | strongerHuang微信公众号 | 嵌入式专栏找工作也是一门技能&#xff0c;有的人很快就找到自己喜欢的工作&#xff0c;有的人找了很久也没找到合适的工作。下面给大家分享几点找工作过程中存在的“潜规则”内容。嵌入式专栏1面试的本质不是考试&#xff0c;而是告诉面试官…

Introducing the ClearGLASS App on ClearOS

<iframe width"890" height"500" src"https://www.youtube.com/embed/tTLnK7dgRIk" frameborder"0" allow"autoplay; encrypted-media" allowfullscreen></iframe> https://www.clearcenter.com 转载于:https:/…

系统为什么要分层?

在日常的软件开发当中&#xff0c;我们一般都是采用了分层的方式来架构系统&#xff0c;但是为什么我们需要分层进行架构呢&#xff1f;在此之前&#xff0c;我觉得需要 搞明白两个概念&#xff0c;什么是软件的伸缩性&#xff0c;什么是性能。首先&#xff0c;什么是软件的伸缩…

每日一题(4)—— (a ^ b 2)

分析下面的代码&#xff0c;求运算结果。 #include <stdio.h>int main(void) {int a 6, b 4;printf("%d\n", a ^ b << 2);return 0; }分析&#xff1a; 主要是考的是“优先级”和按位“异或”&#xff0c; 左移运算符优先级高于按位异或运算符&#…

轻轻的你来了,悄悄的你走了,邓总没有带走一个bug

写这篇文章的时候&#xff0c;比较晚&#xff0c;所以思绪是清晰的&#xff0c;这个时候刚好是邓总来公司跟我交接离职的最后一天。给邓总制作的告别MV&#xff1a;我跟邓总2017年12月在恒大认识&#xff0c;我们入职时间相差一周&#xff0c;我入职的时候就开始注意到旁边的这…