Compare commits

..

2 Commits

Author SHA1 Message Date
Rikus Wessels 71e8c16178 Optional nanosecond timestamp logging 2025-03-11 10:38:51 +02:00
Rikus Wessels 76b5891765 Use timespec 2025-03-10 18:31:43 +02:00
9 changed files with 149 additions and 199 deletions

View File

@ -19,26 +19,6 @@ endif()
# Add an option to enable treating warnings as errors # Add an option to enable treating warnings as errors
option(ENABLE_WERROR "Treat all compiler warnings as errors" OFF) option(ENABLE_WERROR "Treat all compiler warnings as errors" OFF)
option(ENABLE_GPS "Enable GPS support" OFF) option(ENABLE_GPS "Enable GPS support" OFF)
option(BUILD_SHARED_LIBS "Build shared libraries" ON)
# Options for controlling targets. These groups correspond to the README.
option(ENABLE_BASIC_TOOLS "Build basic tools" ON)
option(ENABLE_IP_SERVER "Build tools providing CAN access via IP sockets" ON)
option(ENABLE_GATEWAY "Build in-kernel gateway configuration tools" ON)
option(ENABLE_MEASUREMENT "Build measurement tools" ON)
option(ENABLE_ISOTP "Build isotp tools" ON)
option(ENABLE_LOG_FILE "Build log file converter tools" ON)
option(ENABLE_SLCAN "Build slcan tools" ON)
option(ENABLE_MCP251XFD "Build MCP251XFD tools" ON)
# cmake_dependent_option is only available in CMake 3.22 and later.
if(ANDROID)
set(ENABLE_J1939 OFF)
set(ENABLE_ISOBUSFS OFF)
else()
option(ENABLE_J1939 "Build J1939 tools" ON)
option(ENABLE_ISOBUSFS "Build ISOBUS tools" ON)
endif()
find_package(PkgConfig REQUIRED) find_package(PkgConfig REQUIRED)
if(ENABLE_GPS) if(ENABLE_GPS)
@ -67,64 +47,24 @@ include_directories(./include)
check_function_exists(fork HAVE_FORK) check_function_exists(fork HAVE_FORK)
# List of all programs to be built. set(PROGRAMS_CANLIB
# Each program is expected to have a corresponding source file with the same name. asc2log
set(PROGRAMS) canbusload
# List of programs to link against can.
set(PROGRAMS_CANLIB)
# List of programs to link against j1939 and can.
set(PROGRAMS_J1939)
if(ENABLE_BASIC_TOOLS)
list(APPEND PROGRAMS cansniffer)
list(APPEND PROGRAMS_CANLIB
candump candump
cangen
canplayer canplayer
cansend cansend
cangen
cansequence cansequence
) log2asc
endif() log2long
slcanpty
if(ENABLE_IP_SERVER AND HAVE_FORK)
list(APPEND PROGRAMS bcmserver)
list(APPEND PROGRAMS_CANLIB canlogserver)
endif()
if(ENABLE_GATEWAY)
list(APPEND PROGRAMS cangw)
endif()
if(ENABLE_MEASUREMENT)
list(APPEND PROGRAMS
canfdtest
canerrsim
)
list(APPEND PROGRAMS_CANLIB canbusload)
add_executable(can-calc-bit-timing
calc-bit-timing/can-calc-bit-timing.c
)
install(TARGETS can-calc-bit-timing DESTINATION ${CMAKE_INSTALL_BINDIR})
endif()
if(ENABLE_ISOTP)
list(APPEND PROGRAMS
isotpdump
isotpperf
isotprecv
isotpsend
isotpsniffer
isotptun
) )
if(HAVE_FORK) if(HAVE_FORK)
list(APPEND PROGRAMS isotpserver) list(APPEND PROGRAMS_CANLIB canlogserver)
endif()
endif() endif()
if(ENABLE_J1939) set(PROGRAMS_J1939
list(APPEND PROGRAMS_J1939
j1939acd j1939acd
j1939cat j1939cat
j1939spy j1939spy
@ -132,46 +72,78 @@ if(ENABLE_J1939)
testj1939 testj1939
) )
add_executable(j1939-timedate-cli set(PROGRAMS_J1939_TIMEDATE
j1939_timedate/j1939_timedate_cli.c j1939-timedate-srv
j1939-timedate-cli
) )
target_link_libraries(j1939-timedate-cli
PRIVATE can j1939
)
install(TARGETS j1939-timedate-cli DESTINATION ${CMAKE_INSTALL_BINDIR})
add_executable(j1939-timedate-srv set(PROGRAMS_J1939_VEHICLE_POSITION
j1939_timedate/j1939_timedate_srv.c j1939-vehicle-position-srv
) )
target_link_libraries(j1939-timedate-srv
PRIVATE can j1939 set(PROGRAMS_ISOBUSFS
isobusfs-srv
isobusfs-cli
) )
install(TARGETS j1939-timedate-srv DESTINATION ${CMAKE_INSTALL_BINDIR})
set(PROGRAMS
${PROGRAMS_CANLIB}
canerrsim
canfdtest
cangw
cansniffer
isotpdump
isotpperf
isotprecv
isotpsend
isotpsniffer
isotptun
slcan_attach
slcand
)
if(HAVE_FORK)
list(APPEND PROGRAMS bcmserver)
list(APPEND PROGRAMS isotpserver)
endif() endif()
if(ENABLE_J1939 AND ENABLE_GPS) add_executable(can-calc-bit-timing
add_executable(j1939-vehicle-position-srv calc-bit-timing/can-calc-bit-timing.c
j1939_vehicle_position/j1939_vehicle_position_srv.c
) )
target_link_libraries(j1939-vehicle-position-srv
PRIVATE can j1939 ${GPS_LIBRARIES}
)
install(TARGETS j1939-vehicle-position-srv DESTINATION ${CMAKE_INSTALL_BINDIR})
endif()
if(ENABLE_ISOBUSFS) add_executable(mcp251xfd-dump
add_library(isobusfs EXCLUDE_FROM_ALL mcp251xfd/mcp251xfd-dev-coredump.c
mcp251xfd/mcp251xfd-dump.c
mcp251xfd/mcp251xfd-main.c
mcp251xfd/mcp251xfd-regmap.c
)
if(NOT ANDROID)
list(APPEND PROGRAMS ${PROGRAMS_J1939})
add_library(j1939 STATIC
libj1939.c
)
target_link_libraries(j1939
PRIVATE can
)
add_library(isobusfs SHARED
isobusfs/isobusfs_cmn.c isobusfs/isobusfs_cmn.c
isobusfs/isobusfs_cmn_dh.c isobusfs/isobusfs_cmn_dh.c
) )
set(PUBLIC_HEADER_ISOBUSFS set(PUBLIC_HEADER_ISOBUSFS
isobusfs/isobusfs_cmn.h isobusfs/isobusfs_cmn.h
isobusfs/isobusfs_cmn_cm.h isobusfs/isobusfs_cmn_cm.h
) )
set_target_properties(isobusfs PROPERTIES set_target_properties(isobusfs PROPERTIES
PUBLIC_HEADER "${PUBLIC_HEADER_ISOBUSFS}" PUBLIC_HEADER "${PUBLIC_HEADER_ISOBUSFS}"
SOVERSION 0 SOVERSION 0
) )
install(TARGETS isobusfs install(TARGETS isobusfs
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}
@ -185,10 +157,10 @@ if(ENABLE_ISOBUSFS)
isobusfs/isobusfs_cli_selftests.c isobusfs/isobusfs_cli_selftests.c
isobusfs/isobusfs_cli_int.c isobusfs/isobusfs_cli_int.c
) )
target_link_libraries(isobusfs-cli target_link_libraries(isobusfs-cli
PRIVATE isobusfs can j1939 PRIVATE isobusfs can j1939
) )
install(TARGETS isobusfs-cli DESTINATION ${CMAKE_INSTALL_BINDIR})
add_executable(isobusfs-srv add_executable(isobusfs-srv
isobusfs/isobusfs_srv.c isobusfs/isobusfs_srv.c
@ -199,55 +171,66 @@ if(ENABLE_ISOBUSFS)
isobusfs/isobusfs_srv_fh.c isobusfs/isobusfs_srv_fh.c
isobusfs/isobusfs_srv_vh.c isobusfs/isobusfs_srv_vh.c
) )
target_link_libraries(isobusfs-srv target_link_libraries(isobusfs-srv
PRIVATE isobusfs can j1939 PRIVATE isobusfs can j1939
) )
install(TARGETS isobusfs-srv DESTINATION ${CMAKE_INSTALL_BINDIR})
endif()
if(ENABLE_LOG_FILE) install(TARGETS
list(APPEND PROGRAMS_CANLIB isobusfs-cli
asc2log isobusfs-srv
log2asc DESTINATION ${CMAKE_INSTALL_BINDIR})
log2long
)
endif()
if(ENABLE_SLCAN) set(PUBLIC_HEADER_j1939_TIMEDATE
list(APPEND PROGRAMS j1939_timedate/j1939_timedate_cmn.h
slcan_attach
slcand
)
list(APPEND PROGRAMS_CANLIB slcanpty)
endif()
if(ENABLE_MCP251XFD)
add_executable(mcp251xfd-dump
mcp251xfd/mcp251xfd-dev-coredump.c
mcp251xfd/mcp251xfd-dump.c
mcp251xfd/mcp251xfd-main.c
mcp251xfd/mcp251xfd-regmap.c
)
install(TARGETS mcp251xfd-dump DESTINATION ${CMAKE_INSTALL_BINDIR})
endif()
list(APPEND PROGRAMS
${PROGRAMS_CANLIB}
${PROGRAMS_J1939}
) )
add_library(can STATIC EXCLUDE_FROM_ALL add_executable(j1939-timedate-cli
j1939_timedate/j1939_timedate_cli.c
)
target_link_libraries(j1939-timedate-cli
PRIVATE can j1939
)
add_executable(j1939-timedate-srv
j1939_timedate/j1939_timedate_srv.c
)
target_link_libraries(j1939-timedate-srv
PRIVATE can j1939
)
install(TARGETS
j1939-timedate-cli
j1939-timedate-srv
DESTINATION ${CMAKE_INSTALL_BINDIR})
if(ENABLE_GPS)
set(PUBLIC_HEADER_J1939_VEHICLE_POSITION
j1939_vehicle_position/j1939_vehicle_position_cmn.h
)
add_executable(j1939-vehicle-position-srv
j1939_vehicle_position/j1939_vehicle_position_srv.c
)
target_link_libraries(j1939-vehicle-position-srv
PRIVATE can j1939 ${GPS_LIBRARIES}
)
install(TARGETS
j1939-vehicle-position-srv
DESTINATION ${CMAKE_INSTALL_BINDIR})
endif()
endif()
add_library(can STATIC
lib.c lib.c
canframelen.c canframelen.c
) )
add_library(j1939 STATIC EXCLUDE_FROM_ALL
libj1939.c
)
target_link_libraries(j1939
PRIVATE can
)
foreach(name ${PROGRAMS}) foreach(name ${PROGRAMS})
add_executable(${name} ${name}.c) add_executable(${name} ${name}.c)
@ -264,6 +247,12 @@ foreach(name ${PROGRAMS})
install(TARGETS ${name} DESTINATION ${CMAKE_INSTALL_BINDIR}) install(TARGETS ${name} DESTINATION ${CMAKE_INSTALL_BINDIR})
endforeach() endforeach()
install(TARGETS
can-calc-bit-timing
mcp251xfd-dump
DESTINATION ${CMAKE_INSTALL_BINDIR}
)
add_custom_target(uninstall add_custom_target(uninstall
"${CMAKE_COMMAND}" -P "${CMAKE_SOURCE_DIR}/cmake/make_uninstall.cmake" "${CMAKE_COMMAND}" -P "${CMAKE_SOURCE_DIR}/cmake/make_uninstall.cmake"
COMMENT "Add uninstall target" COMMENT "Add uninstall target"

View File

@ -50,10 +50,6 @@ subsystem (aka SocketCAN):
Follow the link to see examples on how this tools can be used: Follow the link to see examples on how this tools can be used:
[Kickstart guide to can-j1939 on linux](https://github.com/linux-can/can-utils/blob/master/can-j1939-kickstart.md) [Kickstart guide to can-j1939 on linux](https://github.com/linux-can/can-utils/blob/master/can-j1939-kickstart.md)
#### ISOBus File server tools
* isobusfs-cli : ISOBus file client
* isobusfs-srv : ISOBus file server
#### Log file converters #### Log file converters
* asc2log : convert ASC logfile to compact CAN frame logfile * asc2log : convert ASC logfile to compact CAN frame logfile
* log2asc : convert compact CAN frame logfile to ASC logfile * log2asc : convert compact CAN frame logfile to ASC logfile

View File

@ -1121,11 +1121,6 @@ static const unsigned int common_data_bitrates[] = {
4000000, 4000000,
2000000, 2000000,
1000000, 1000000,
800000,
500000,
250000,
125000,
100000,
0 0
}; };

View File

@ -221,7 +221,7 @@ static int idx2dindex(int ifidx, int socket)
return i; return i;
} }
static int sprint_timestamp(char *ts_buffer, const char timestamp, const char use_ns, static int sprint_timestamp(char *ts_buffer, const char timestamp, unsigned char use_ns,
const struct timespec *ts, struct timespec *const last_ts) const struct timespec *ts, struct timespec *const last_ts)
{ {
int numchars = 0; int numchars = 0;
@ -857,9 +857,11 @@ int main(int argc, char **argv)
/* build common log format output */ /* build common log format output */
if ((log) || ((logfrmt) && (silent == SILENT_OFF))) { if ((log) || ((logfrmt) && (silent == SILENT_OFF))) {
alen = sprint_timestamp(afrbuf, logtimestamp, use_ns, &ts, &last_ts); alen = sprint_timestamp(afrbuf, logtimestamp, use_ns,
&ts, &last_ts);
alen += sprintf(afrbuf + alen, "%*s ", max_devname_len, devname[idx]); alen += sprintf(afrbuf + alen, "%*s ",
max_devname_len, devname[idx]);
alen += snprintf_canframe(afrbuf + alen, sizeof(afrbuf) - alen, &cu, 0); alen += snprintf_canframe(afrbuf + alen, sizeof(afrbuf) - alen, &cu, 0);
} }

View File

@ -987,12 +987,12 @@ int main(int argc, char **argv)
rnd = random(); rnd = random();
if (xl_flags_mode == MODE_RANDOM) { if (xl_flags_mode == MODE_RANDOM) {
cu.xl.flags = rnd & (CANXL_SEC | CANXL_RRS); cu.xl.flags = rnd & CANXL_SEC;
} else if (xl_flags_mode == MODE_FIX) { } else if (xl_flags_mode == MODE_FIX) {
cu.xl.flags = xl_flags; cu.xl.flags = xl_flags;
} else if (xl_flags_mode == MODE_INCREMENT) { } else if (xl_flags_mode == MODE_INCREMENT) {
xl_flags++; xl_flags ^= CANXL_SEC;
cu.xl.flags = (xl_flags & (CANXL_SEC | CANXL_RRS)); cu.xl.flags = (xl_flags & CANXL_SEC);
} }
/* mark CAN XL frame */ /* mark CAN XL frame */

View File

@ -452,20 +452,14 @@ int main(int argc, char **argv)
return 1; return 1;
} }
log_tv.tv_sec = sec; log_tv.tv_sec = sec;
log_tv.tv_usec = usec;
/* /*
* ensure the fractions of seconds are 6 or 9 decimal places long to catch * ensure the fractions of seconds are 6 decimal places long to catch
* 3rd party or handcrafted logfiles that treat the timestamp as float * 3rd party or handcrafted logfiles that treat the timestamp as float
*/ */
switch (strchr(buf, ')') - strchr(buf, '.')) { if (strchr(buf, ')') - strchr(buf, '.') != 7) {
case 7: //6 fprintf(stderr, "timestamp format in logfile requires 6 decimal places\n");
log_tv.tv_usec = usec;
break;
case 10: //9
log_tv.tv_usec = usec / 1000;
break;
default:
fprintf(stderr, "timestamp format in logfile requires 6 or 9 decimal places\n");
return 1; return 1;
} }
@ -547,25 +541,19 @@ int main(int argc, char **argv)
break; break;
} }
if (sscanf(buf, "(%llu.%llu) %21s %6299s", &sec, &usec, device, afrbuf) != 4) { if (sscanf(buf, "(%llu.%llu) %s %s", &sec, &usec, device, afrbuf) != 4) {
fprintf(stderr, "incorrect line format in logfile\n"); fprintf(stderr, "incorrect line format in logfile\n");
return 1; return 1;
} }
log_tv.tv_sec = sec; log_tv.tv_sec = sec;
log_tv.tv_usec = usec;
/* /*
* ensure the fractions of seconds are 6 or 9 decimal places long to catch * ensure the fractions of seconds are 6 decimal places long to catch
* 3rd party or handcrafted logfiles that treat the timestamp as float * 3rd party or handcrafted logfiles that treat the timestamp as float
*/ */
switch (strchr(buf, ')') - strchr(buf, '.')) { if (strchr(buf, ')') - strchr(buf, '.') != 7) {
case 7: //6 fprintf(stderr, "timestamp format in logfile requires 6 decimal places\n");
log_tv.tv_usec = usec;
break;
case 10: //9
log_tv.tv_usec = usec / 1000;
break;
default:
fprintf(stderr, "timestamp format in logfile requires 6 or 9 decimal places\n");
return 1; return 1;
} }

View File

@ -407,22 +407,7 @@ int main(int argc, char **argv)
} }
} }
tv.tv_sec = sec; tv.tv_sec = sec;
/*
* ensure the fractions of seconds are 6 or 9 decimal places long to catch
* 3rd party or handcrafted logfiles that treat the timestamp as float
*/
switch (strchr(buf, ')') - strchr(buf, '.')) {
case 7: //6
tv.tv_usec = usec; tv.tv_usec = usec;
break;
case 10: //9
tv.tv_usec = usec / 1000;
break;
default:
fprintf(stderr, "timestamp format in logfile requires 6 or 9 decimal places\n");
return 1;
}
if (print_banner) { /* print banner */ if (print_banner) { /* print banner */
print_banner = 0; print_banner = 0;

View File

@ -51,7 +51,7 @@
#include "lib.h" #include "lib.h"
#define DEVSZ 22 #define DEVSZ 22
#define TIMESZ 25 /* sizeof("(1345212884.318850123) ") */ #define TIMESZ 22 /* sizeof("(1345212884.318850) ") */
#define BUFSZ (DEVSZ + AFRSZ + TIMESZ) #define BUFSZ (DEVSZ + AFRSZ + TIMESZ)
/* adapt sscanf() functions below on error */ /* adapt sscanf() functions below on error */
@ -61,7 +61,7 @@
#if (DEVSZ != 22) #if (DEVSZ != 22)
#error "DEVSZ value does not fit sscanf restrictions!" #error "DEVSZ value does not fit sscanf restrictions!"
#endif #endif
#if (TIMESZ != 25) #if (TIMESZ != 22)
#error "TIMESZ value does not fit sscanf restrictions!" #error "TIMESZ value does not fit sscanf restrictions!"
#endif #endif
@ -78,7 +78,7 @@ int main(void)
return 1; return 1;
} }
if (sscanf(buf, "%24s %21s %6299s", timestamp, device, afrbuf) != 3) if (sscanf(buf, "%21s %21s %6299s", timestamp, device, afrbuf) != 3)
return 1; return 1;
mtu = parse_canframe(afrbuf, &cu); mtu = parse_canframe(afrbuf, &cu);

View File

@ -370,13 +370,8 @@ int main(int argc, char *argv[])
/* retrieve the name of the created CAN netdevice */ /* retrieve the name of the created CAN netdevice */
if (ioctl(fd, SIOCGIFNAME, ifr.ifr_name) < 0) { if (ioctl(fd, SIOCGIFNAME, ifr.ifr_name) < 0) {
if (name) {
perror("ioctl SIOCGIFNAME"); perror("ioctl SIOCGIFNAME");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} else {
/* Graceful degradation: we only needed the name for display. */
snprintf(ifr.ifr_name, sizeof(ifr.ifr_name), "<unknown>");
}
} }
syslogger(LOG_NOTICE, "attached TTY %s to netdevice %s\n", ttypath, ifr.ifr_name); syslogger(LOG_NOTICE, "attached TTY %s to netdevice %s\n", ttypath, ifr.ifr_name);