From: Oliver Hartkopp Date: Wed, 14 Nov 2012 19:06:50 +0000 (+0100) Subject: candump: new option to print extra message information X-Git-Url: https://rtime.felk.cvut.cz/gitweb/sojka/can-utils.git/commitdiff_plain/d166ecc8a36759ca05aeb2d4e2eec744c9dfb886 candump: new option to print extra message information Added -x option to print extra message infos per frame: RX/TX : Indicates whether the frame was sent or received from the local host BRS : bit rate setting enabled (CAN FD only) ESI : error state indicator (CAN FD only) Signed-off-by: Oliver Hartkopp --- diff --git a/candump.c b/candump.c index d6c7c01..2981b48 100644 --- a/candump.c +++ b/candump.c @@ -99,6 +99,7 @@ const int canfd_on = 1; #define MAXANI 4 const char anichar[MAXANI] = {'|', '/', '-', '\\'}; +const char extra_m_info[4][4] = {"- -", "B -", "- E", "B E"}; extern int optind, opterr, optopt; @@ -123,6 +124,7 @@ void print_usage(char *prg) fprintf(stderr, " -r (set socket receive buffer to )\n"); fprintf(stderr, " -d (monitor dropped CAN frames)\n"); fprintf(stderr, " -e (dump CAN error frames in human-readable format)\n"); + fprintf(stderr, " -x (print extra message infos, rx/tx brs esi)\n"); fprintf(stderr, "\n"); fprintf(stderr, "Up to %d CAN interfaces with optional filter sets can be specified\n", MAXSOCK); fprintf(stderr, "on the commandline in the form: [,filter]*\n"); @@ -206,6 +208,7 @@ int main(int argc, char **argv) useconds_t bridge_delay = 0; unsigned char timestamp = 0; unsigned char dropmonitor = 0; + unsigned char extra_msg_info = 0; unsigned char silent = SILENT_INI; unsigned char silentani = 0; unsigned char color = 0; @@ -237,7 +240,7 @@ int main(int argc, char **argv) last_tv.tv_sec = 0; last_tv.tv_usec = 0; - while ((opt = getopt(argc, argv, "t:ciaSs:b:B:u:ldLn:r:he?")) != -1) { + while ((opt = getopt(argc, argv, "t:ciaSs:b:B:u:ldxLn:r:he?")) != -1) { switch (opt) { case 't': timestamp = optarg[0]; @@ -328,6 +331,10 @@ int main(int argc, char **argv) dropmonitor = 1; break; + case 'x': + extra_msg_info = 1; + break; + case 'L': logfrmt = 1; break; @@ -746,6 +753,15 @@ int main(int argc, char **argv) printf(" %s", (color && (color<3))?col_on[idx%MAXCOL]:""); printf("%*s", max_devname_len, devname[idx]); + + if (extra_msg_info) { + + if (msg.msg_flags & MSG_DONTROUTE) + printf (" TX %s", extra_m_info[frame.flags & 3]); + else + printf (" RX %s", extra_m_info[frame.flags & 3]); + } + printf("%s ", (color==1)?col_off:""); fprint_long_canframe(stdout, &frame, NULL, view, maxdlen);