Thanks Gemini!
This commit is contained in:
parent
ebad5379dd
commit
f1388e93bd
5 changed files with 46 additions and 53 deletions
|
@ -10,7 +10,7 @@ STATIC = ../src/libhexagram.a
|
||||||
OBJS = capture.o can2dump.o replay.o pcapreplay.o pcap2can.o main.o
|
OBJS = capture.o can2dump.o replay.o pcapreplay.o pcap2can.o main.o
|
||||||
NAME = hexagram
|
NAME = hexagram
|
||||||
|
|
||||||
RM = /bin/rm
|
RM = rm
|
||||||
|
|
||||||
all: $(NAME)
|
all: $(NAME)
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,7 @@ char *hexagram_arglist_can2dump(void) {
|
||||||
return "ifname [file.can] [candump.txt]";
|
return "ifname [file.can] [candump.txt]";
|
||||||
}
|
}
|
||||||
|
|
||||||
static void usage(int argc, char **argv, const char *message, ...) {
|
static int usage(int argc, char **argv, const char *message, ...) {
|
||||||
if (message) {
|
if (message) {
|
||||||
va_list args;
|
va_list args;
|
||||||
|
|
||||||
|
@ -25,34 +25,22 @@ static void usage(int argc, char **argv, const char *message, ...) {
|
||||||
|
|
||||||
fprintf(stderr, "usage: hexagram %s %s\n", argv[0], hexagram_arglist_can2dump());
|
fprintf(stderr, "usage: hexagram %s %s\n", argv[0], hexagram_arglist_can2dump());
|
||||||
|
|
||||||
exit(1);
|
return 1;
|
||||||
}
|
|
||||||
|
|
||||||
static int convert(hexagram_capture *capture, const char *file, const char *ifname) {
|
|
||||||
struct timeval timestamp;
|
|
||||||
struct can_frame frame;
|
|
||||||
|
|
||||||
FILE *fh;
|
|
||||||
|
|
||||||
if ((fh = fopen(file, "w")) == NULL) {
|
|
||||||
goto error_fopen;
|
|
||||||
}
|
|
||||||
|
|
||||||
while (hexagram_capture_read(capture, ×tamp, &frame) >= 0) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(fh);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
error_fopen:
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int hexagram_main_can2dump(int argc, char **argv) {
|
int hexagram_main_can2dump(int argc, char **argv) {
|
||||||
hexagram_can_if *can_if;
|
|
||||||
hexagram_capture *capture;
|
hexagram_capture *capture;
|
||||||
|
const char *ifname;
|
||||||
|
FILE *fh;
|
||||||
|
|
||||||
|
struct timeval timestamp;
|
||||||
|
struct can_frame frame;
|
||||||
|
|
||||||
|
if (argc <= 1) {
|
||||||
|
return usage(argc, argv, "No CAN interface name provided");
|
||||||
|
}
|
||||||
|
|
||||||
|
ifname = argv[1];
|
||||||
|
|
||||||
if (argc == 2) {
|
if (argc == 2) {
|
||||||
if ((capture = hexagram_capture_open_fd(fileno(stdin), O_RDONLY)) == NULL) {
|
if ((capture = hexagram_capture_open_fd(fileno(stdin), O_RDONLY)) == NULL) {
|
||||||
|
@ -60,47 +48,51 @@ int hexagram_main_can2dump(int argc, char **argv) {
|
||||||
|
|
||||||
goto error_capture_open;
|
goto error_capture_open;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fh = stdout;
|
||||||
} else if (argc == 3) {
|
} else if (argc == 3) {
|
||||||
if ((capture = hexagram_capture_open_file(argv[2], O_RDONLY)) == NULL) {
|
if ((capture = hexagram_capture_open_file(argv[2], O_RDONLY)) == NULL) {
|
||||||
perror("hexagram_capture_open_file()");
|
perror("hexagram_capture_open_file()");
|
||||||
|
|
||||||
goto error_capture_open;
|
goto error_capture_open;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fh = stdout;
|
||||||
|
} else if (argc == 4) {
|
||||||
|
if ((capture = hexagram_capture_open_file(argv[2], O_RDONLY)) == NULL) {
|
||||||
|
perror("hexagram_capture_open_file()");
|
||||||
|
|
||||||
|
goto error_capture_open;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((fh = fopen(argv[3], "w")) == NULL) {
|
||||||
|
goto error_fopen;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
usage(argc, argv, NULL);
|
usage(argc, argv, NULL);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((can_if = hexagram_can_if_open(argv[1])) == NULL) {
|
while (hexagram_capture_read(capture, ×tamp, &frame) >= 0) {
|
||||||
perror("hexagram_can_if_open()");
|
fprintf(fh, "%s 0x%x %02x %02x %02x %02x %02x %02x %02x %02x\n",
|
||||||
|
ifname, frame.can_id,
|
||||||
goto error_can_if_open;
|
frame.data[0], frame.data[1], frame.data[2], frame.data[3],
|
||||||
|
frame.data[4], frame.data[5], frame.data[6], frame.data[7]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hexagram_capture_can2dump(capture, can_if, 1.0) < 0) {
|
if (argc == 2) {
|
||||||
perror("hexagram_capture_can2dump()");
|
|
||||||
|
|
||||||
goto error_capture_can2dump;
|
|
||||||
}
|
|
||||||
|
|
||||||
hexagram_can_if_close(can_if);
|
|
||||||
|
|
||||||
if (argc == 3) {
|
|
||||||
hexagram_capture_close(capture);
|
|
||||||
} else {
|
|
||||||
hexagram_capture_destroy(capture);
|
hexagram_capture_destroy(capture);
|
||||||
|
} else if (argc >= 3) {
|
||||||
|
hexagram_capture_close(capture);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
error_capture_can2dump:
|
error_fopen:
|
||||||
hexagram_can_if_close(can_if);
|
if (argc == 2) {
|
||||||
|
|
||||||
error_can_if_open:
|
|
||||||
if (argc == 3) {
|
|
||||||
hexagram_capture_close(capture);
|
|
||||||
} else {
|
|
||||||
hexagram_capture_destroy(capture);
|
hexagram_capture_destroy(capture);
|
||||||
|
} else if (argc >= 3) {
|
||||||
|
hexagram_capture_close(capture);
|
||||||
}
|
}
|
||||||
|
|
||||||
error_capture_open:
|
error_capture_open:
|
||||||
|
|
|
@ -10,7 +10,7 @@ STATIC = ../src/libhexagram.a
|
||||||
|
|
||||||
EXAMPLES = view
|
EXAMPLES = view
|
||||||
|
|
||||||
RM = /bin/rm
|
RM = rm
|
||||||
|
|
||||||
all: $(EXAMPLES)
|
all: $(EXAMPLES)
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#ifndef _HEXAGRAM_CAN_H
|
#ifndef _HEXAGRAM_CAN_H
|
||||||
#define _HEXAGRAM_CAN_H
|
#define _HEXAGRAM_CAN_H
|
||||||
|
|
||||||
|
#include <sys/select.h>
|
||||||
#include <net/if.h>
|
#include <net/if.h>
|
||||||
|
|
||||||
#include <linux/can.h>
|
#include <linux/can.h>
|
||||||
|
|
|
@ -23,10 +23,10 @@ HEADERS_BUILD = $(addprefix $(INCLUDE_PATH)/$(HEADER_SUBDIR)/, $(HEADERS))
|
||||||
AR = $(CROSS)ar
|
AR = $(CROSS)ar
|
||||||
RANLIB = $(CROSS)ranlib
|
RANLIB = $(CROSS)ranlib
|
||||||
|
|
||||||
RM = /bin/rm
|
RM = rm
|
||||||
LN = /bin/ln
|
LN = ln
|
||||||
RMDIR = /bin/rmdir
|
RMDIR = rmdir
|
||||||
INSTALL = /usr/bin/install
|
INSTALL = install
|
||||||
|
|
||||||
all: $(STATIC) $(SONAME_FULL) $(SONAME) $(SONAME_SHORT)
|
all: $(STATIC) $(SONAME_FULL) $(SONAME) $(SONAME_SHORT)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue