]> rtime.felk.cvut.cz Git - lincan.git/blob - lincan/utils/readburst.c
8a6d552baccddaecbdd5f8302ffe7c58f3ef56c9
[lincan.git] / lincan / utils / readburst.c
1 #include <stdio.h>
2 #include <stdlib.h>
3 #include <unistd.h>
4 #include <errno.h>
5 #include <signal.h>
6 #include <getopt.h>
7 #include <fcntl.h>
8 #include <sys/types.h>
9 #include <sys/stat.h>
10 #include <sys/time.h>
11 #include <sys/ioctl.h>
12
13 #include "../include/can.h"
14
15 int fd;
16
17 struct canfilt_t canfilt = {
18         .flags = 0,
19         .queid = 0,
20         .cob = 0,
21         .id = 0,
22         .mask = 0
23 };
24
25 int canfilt_fl;
26
27 int can_wait_sec = 5;
28
29 char *can_dev_name = "/dev/can0";
30
31 #define PRT_PREFIX_SIZE 40
32 char prt_prefix[PRT_PREFIX_SIZE];
33
34 char *prt_prefix_in = "CAN %s : ";
35
36 int can_fd_wait(int fd, int wait_sec)
37 {
38         int ret;
39         struct timeval timeout;
40         fd_set set;
41
42         FD_ZERO (&set);
43         FD_SET (fd, &set);
44         timeout.tv_sec = wait_sec;
45         timeout.tv_usec = 0;
46         while ((ret=select(FD_SETSIZE,&set, NULL, NULL,&timeout))==-1
47           &&errno==-EINTR);
48         return ret;
49 }
50
51
52 /*--- handler on SIGINT signal : the program quit with CTL-C ---*/
53 void sortie(int sig)
54 {
55         close(fd);
56         printf("Terminated by user\n");
57         exit(0);
58 }
59
60 static void
61 usage(void)
62 {
63   printf("usage: readburst\n");
64   printf("  -d, --device  <name>     name of CAN device [/dev/can0]\n");
65   printf("  -m, --mask  <num>        CAN filter mask\n");
66   printf("  -i, --id  <num>          CAN filter message ID\n");
67   printf("  -f, --flags <num>        CAN filter flags\n");
68   printf("  -w, --wait <num>         number of seconds to wait in select call\n");
69   printf("  -p, --prefix <str>       string prefix for output\n");
70   printf("  -V, --version            show version\n");
71   printf("  -h, --help               this usage screen\n");
72 }
73
74
75 int main(int argc, char *argv[])
76 {
77         static struct option long_opts[] = {
78                 { "uldev", 1, 0, 'd' },
79                 { "mask",  1, 0, 'm' },
80                 { "id",    1, 0, 'i' },
81                 { "flags", 1, 0, 'f' },
82                 { "wait",  1, 0, 'w' },
83                 { "prefix",1, 0, 'p' },
84                 { "version",0,0, 'V' },
85                 { "help",  0, 0, 'h' },
86                 { 0, 0, 0, 0}
87         };
88         int opt;
89
90         int n,ret;
91         unsigned long i=0;
92         struct canmsg_t readmsg={0,0,5,0,0,{0,}};
93         struct sigaction act;
94
95
96         while ((opt = getopt_long(argc, argv, "d:m:i:f:w:p:Vh",
97                             &long_opts[0], NULL)) != EOF) switch (opt) {
98                 case 'd':
99                         can_dev_name=optarg;
100                         break;
101                 case 'm':
102                         canfilt_fl=1;
103                         canfilt.mask = strtol(optarg,NULL,0);
104                         break;
105                 case 'i':
106                         canfilt_fl=1;
107                         canfilt.id = strtol(optarg,NULL,0);
108                         break;
109                 case 'f':
110                         canfilt_fl=1;
111                         canfilt.flags = strtol(optarg,NULL,0);
112                         break;
113                 case 'w':
114                         can_wait_sec = strtol(optarg,NULL,0);
115                         break;
116                 case 'p':
117                         prt_prefix_in = optarg;
118                         break;
119                 case 'V':
120                         fputs("LinCAN utilities v0.2\n", stdout);
121                         exit(0);
122                 case 'h':
123                 default:
124                         usage();
125                         exit(opt == 'h' ? 0 : 1);
126         }
127
128
129         /*------- register handler on SIGINT signal -------*/
130         act.sa_handler=sortie;
131         sigemptyset(&act.sa_mask);
132         act.sa_flags=0;
133         sigaction(SIGINT,&act,0);
134         /*---------------------------------------*/     
135
136         if ((fd=open(can_dev_name, O_RDWR)) < 0) {
137                 perror("open");
138                 printf("Error opening %s\n", can_dev_name);
139                 exit(1);        
140         }
141         
142         if (canfilt_fl) {
143                 ret = ioctl(fd, CANQUE_FILTER, &canfilt);
144                 if(ret<0) {
145                         perror("ioctl FILTER_QUE");
146                 }
147         }
148
149         snprintf(prt_prefix, PRT_PREFIX_SIZE, prt_prefix_in, can_dev_name);
150         
151         while (1) {
152                 readmsg.flags=0;
153                 readmsg.cob=0;
154                 readmsg.timestamp=0;
155             #if 1
156                 ret=can_fd_wait(fd, can_wait_sec);
157                 printf("%scan_fd_wait returned %d\n", prt_prefix, ret);
158             #endif
159                 ret=read(fd,&readmsg,sizeof(struct canmsg_t));
160                 if(ret <0) {
161                         printf("%sError reading message\n", prt_prefix);
162                 }
163                 else if(ret == 0) {
164                         printf("%sNo message arrived\n", prt_prefix);
165                 } else {
166                         printf("%sRx msg #%lu: id=%lX dlc=%u flg=0x%02x",
167                                 prt_prefix,i,readmsg.id,readmsg.length,readmsg.flags);
168                         for(n=0 ; n<readmsg.length ; n++)
169                                 printf(" %.2X",(unsigned char)readmsg.data[n]);
170                         printf("\n");
171                         i++;
172                 }
173         }
174         return 0;
175 }