From 6b2e57b07ee189bc513304232df156be68a881e3 Mon Sep 17 00:00:00 2001 From: Gianfranco Costamagna Date: Tue, 14 Nov 2023 13:34:35 +0100 Subject: [PATCH 1/5] dlt_cdh: Make sure on 64 bit we read an ELF64 structure. (#567) Make sure on 64 bit we read an ELF64 structure. Otherwise we get a read error, and the context file is missing some good to know information --- src/core_dump_handler/dlt_cdh.h | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/core_dump_handler/dlt_cdh.h b/src/core_dump_handler/dlt_cdh.h index 8608c6c4e..3dac480a8 100644 --- a/src/core_dump_handler/dlt_cdh.h +++ b/src/core_dump_handler/dlt_cdh.h @@ -45,10 +45,17 @@ #define CORE_FILE_PATTERN "%s/core.%d.%s.%d.gz" #define CONTEXT_FILE_PATTERN "%s/context.%d.%s.%d.txt" +#if ((__SIZEOF_POINTER) == 4) #define ELF_Ehdr Elf32_Ehdr #define ELF_Phdr Elf32_Phdr #define ELF_Shdr Elf32_Shdr #define ELF_Nhdr Elf32_Nhdr +#else +#define ELF_Ehdr Elf64_Ehdr +#define ELF_Phdr Elf64_Phdr +#define ELF_Shdr Elf64_Shdr +#define ELF_Nhdr Elf64_Nhdr +#endif typedef struct { From 7a5536825034feb89998811a9fe857cd7605b93b Mon Sep 17 00:00:00 2001 From: Haris Okanovic Date: Tue, 14 Nov 2023 08:49:11 -0600 Subject: [PATCH 2/5] Add ECUSoftwareVersionFileField option to dlt.conf (#554) Modify dlt_daemon_local_ecu_version_init() to read a single field from KEY=VALUE (or quoted KEY="VALUE") style files, so that dlt-daemon can report an OS version number parsed from /etc/os-release file. For example, get_software_version would return "22.04.3 LTS" under the following configuration: $ cat /etc/os-release PRETTY_NAME="Ubuntu 22.04.3 LTS" NAME="Ubuntu" VERSION="22.04.3 LTS" VERSION_CODENAME=jammy $ cat /etc/dlt.conf PathToECUSoftwareVersion = /etc/os-release ECUSoftwareVersionFileField = VERSION Signed-off-by: Haris Okanovic Co-authored-by: Haris Okanovic --- src/daemon/dlt-daemon.c | 173 ++++++++++++++++++++++++++++------------ src/daemon/dlt-daemon.h | 1 + src/daemon/dlt.conf | 3 + 3 files changed, 127 insertions(+), 50 deletions(-) diff --git a/src/daemon/dlt-daemon.c b/src/daemon/dlt-daemon.c index 8c4bdb8e1..78d5d2610 100644 --- a/src/daemon/dlt-daemon.c +++ b/src/daemon/dlt-daemon.c @@ -389,6 +389,7 @@ int option_file_parser(DltDaemonLocal *daemon_local) daemon_local->daemonFifoSize = 0; daemon_local->flags.sendECUSoftwareVersion = 0; memset(daemon_local->flags.pathToECUSoftwareVersion, 0, sizeof(daemon_local->flags.pathToECUSoftwareVersion)); + memset(daemon_local->flags.ecuSoftwareVersionFileField, 0, sizeof(daemon_local->flags.ecuSoftwareVersionFileField)); daemon_local->flags.sendTimezone = 0; daemon_local->flags.offlineLogstorageMaxDevices = 0; daemon_local->flags.offlineLogstorageDirPath[0] = 0; @@ -632,6 +633,13 @@ int option_file_parser(DltDaemonLocal *daemon_local) - 1] = 0; /*printf("Option: %s=%s\n",token,value); */ } + else if (strcmp(token, "ECUSoftwareVersionFileField") == 0) { + strncpy(daemon_local->flags.ecuSoftwareVersionFileField, value, + sizeof(daemon_local->flags.ecuSoftwareVersionFileField) - 1); + daemon_local->flags.ecuSoftwareVersionFileField[sizeof(daemon_local->flags.ecuSoftwareVersionFileField) + - 1] = 0; + /*printf("Option: %s=%s\n",token,value); */ + } else if (strcmp(token, "SendTimezone") == 0) { daemon_local->flags.sendTimezone = atoi(value); @@ -1906,78 +1914,143 @@ int dlt_daemon_local_connection_init(DltDaemon *daemon, return 0; } -int dlt_daemon_local_ecu_version_init(DltDaemon *daemon, DltDaemonLocal *daemon_local, int verbose) +static char* file_read_everything(FILE* const file, const size_t sizeLimit) { - char *version = NULL; - FILE *f = NULL; - - PRINT_FUNCTION_VERBOSE(verbose); - - /* By default, version string is null. */ - daemon->ECUVersionString = NULL; - - /* Open the file. Bail out if error occurs */ - f = fopen(daemon_local->flags.pathToECUSoftwareVersion, "r"); - - if (f == NULL) { - /* Error level notice, because this might be deliberate choice */ - dlt_log(LOG_NOTICE, "Failed to open ECU Software version file.\n"); - return -1; + if (!file) { + return NULL; } /* Get the file size. Bail out if stat fails. */ - int fd = fileno(f); - struct stat s_buf; - + const int fd = fileno(file); + struct stat s_buf = {0}; if (fstat(fd, &s_buf) < 0) { - dlt_log(LOG_WARNING, "Failed to stat ECU Software version file.\n"); - fclose(f); + dlt_log(LOG_WARNING, "failed to stat file size\n"); + fclose(file); return -1; } - /* Bail out if file is too large. Use DLT_DAEMON_TEXTBUFSIZE max. - * Reserve one byte for trailing '\0' */ - off_t size = s_buf.st_size; + /* Size limit includes NULL terminator. */ + const off_t size = s_buf.st_size; + if (size < 0 || size >= sizeLimit) { + dlt_log(LOG_WARNING, "file size invalid\n"); + fclose(file); + return NULL; + } - if (size >= DLT_DAEMON_TEXTBUFSIZE) { - dlt_log(LOG_WARNING, "Too large file for ECU version.\n"); - fclose(f); - return -1; + char* const string = malloc((size_t)size + 1); + if (!string) { + dlt_log(LOG_WARNING, "failed to allocate string for file contents\n"); + fclose(file); + return NULL; } - /* Allocate permanent buffer for version info */ - version = malloc((size_t) (size + 1)); + off_t offset = 0; + while (!feof(file)) { + offset += (off_t)fread(string + offset, 1, (size_t)size, file); - if (version == 0) { - dlt_log(LOG_WARNING, "Cannot allocate memory for ECU version.\n"); - fclose(f); - return -1; + if (ferror(file)) { + dlt_log(LOG_WARNING, "failed to read file\n"); + free(string); + fclose(file); + return NULL; + } + + if (offset > size) { + dlt_log(LOG_WARNING, "file too long for buffer\n"); + free(string); + fclose(file); + return NULL; + } } - off_t offset = 0; + string[offset] = '\0'; /* append null termination at end of string */ - while (!feof(f)) { - offset += (off_t) fread(version + offset, 1, (size_t) size, f); + return string; +} - if (ferror(f)) { - dlt_log(LOG_WARNING, "Failed to read ECU Software version file.\n"); - free(version); - fclose(f); - return -1; +static char* file_read_field(FILE* const file, const char* const fieldName) +{ + if (!file) { + return NULL; + } + + const char* const kDelimiters = "\r\n\"\'="; + const size_t fieldNameLen = strlen(fieldName); + + char* result = NULL; + + char* buffer = NULL; + ssize_t bufferSize = 0; + + while (true) { + ssize_t lineSize = getline(&buffer, &bufferSize, file); + if (lineSize < 0 || !buffer) { + /* end of file */ + break; } - if (offset > size) { - dlt_log(LOG_WARNING, "Too long file for ECU Software version info.\n"); - free(version); - fclose(f); - return -1; + char* line = buffer; + + /* trim trailing delimiters */ + while (lineSize >= 1 && strchr(kDelimiters, line[lineSize - 1]) != NULL) { + line[lineSize - 1] = '\0'; + --lineSize; + } + + /* check fieldName */ + if ( strncmp(line, fieldName, fieldNameLen) == 0 + && lineSize >= (fieldNameLen + 1) + && strchr(kDelimiters, line[fieldNameLen]) != NULL + ) { + /* trim fieldName */ + line += fieldNameLen; + + /* trim delimiter */ + ++line; + + /* trim leading delimiters */ + while (*line != '\0' && strchr(kDelimiters, *line) != NULL) { + ++line; + --lineSize; + } + + result = strdup(line); + break; } } - version[offset] = '\0';/*append null termination at end of version string */ - daemon->ECUVersionString = version; + free(buffer); + + return result; +} + +int dlt_daemon_local_ecu_version_init(DltDaemon *daemon, DltDaemonLocal *daemon_local, int verbose) +{ + FILE *f = NULL; + + PRINT_FUNCTION_VERBOSE(verbose); + + /* By default, version string is null. */ + daemon->ECUVersionString = NULL; + + /* Open the file. Bail out if error occurs */ + f = fopen(daemon_local->flags.pathToECUSoftwareVersion, "r"); + + if (f == NULL) { + /* Error level notice, because this might be deliberate choice */ + dlt_log(LOG_NOTICE, "Failed to open ECU Software version file.\n"); + return -1; + } + + if (daemon_local->flags.ecuSoftwareVersionFileField[0] != '\0') { + daemon->ECUVersionString = file_read_field(f, daemon_local->flags.ecuSoftwareVersionFileField); + } else { + daemon->ECUVersionString = file_read_everything(f, DLT_DAEMON_TEXTBUFSIZE); + } + fclose(f); - return 0; + + return (daemon->ECUVersionString != NULL) ? 0 : -1; } void dlt_daemon_local_cleanup(DltDaemon *daemon, DltDaemonLocal *daemon_local, int verbose) diff --git a/src/daemon/dlt-daemon.h b/src/daemon/dlt-daemon.h index d4962244b..a734802f4 100644 --- a/src/daemon/dlt-daemon.h +++ b/src/daemon/dlt-daemon.h @@ -116,6 +116,7 @@ typedef struct int loggingFileMaxSize; /**< (int) Maximum size in bytes of all logging files (Default: 1000000) */ int sendECUSoftwareVersion; /**< (Boolean) Send ECU software version perdiodically */ char pathToECUSoftwareVersion[DLT_DAEMON_FLAG_MAX]; /**< (String: Filename) The file from which to read the ECU version from. */ + char ecuSoftwareVersionFileField[DLT_DAEMON_FLAG_MAX]; /**< Reads a specific VALUE from a FIELD=VALUE ECU version file. */ int sendTimezone; /**< (Boolean) Send Timezone perdiodically */ int offlineLogstorageMaxDevices; /**< (int) Maximum devices to be used as offline logstorage devices */ char offlineLogstorageDirPath[DLT_MOUNT_PATH_MAX]; /**< (String: Directory) DIR path to store offline logs */ diff --git a/src/daemon/dlt.conf b/src/daemon/dlt.conf index 6035de30e..c5be1695d 100644 --- a/src/daemon/dlt.conf +++ b/src/daemon/dlt.conf @@ -172,6 +172,9 @@ ControlSocketPath = /tmp/dlt-ctrl.sock # Absolute path to file storing version info - otherwise DLT version is used # PathToECUSoftwareVersion = +# Line prefix to read from software version file. Reads entire file if unset. +# ECUSoftwareVersionFileField = VERSION + ######################################################################## # Timezone info # ######################################################################## From a4105dde8871582eaa6d7182db9afa9c2bea54ac Mon Sep 17 00:00:00 2001 From: Gianfranco Costamagna Date: Wed, 15 Nov 2023 16:28:03 +0100 Subject: [PATCH 3/5] dlt_cdh: (#568) Make sure on 64 bit we read an ELF64 structure. Otherwise we get a read error, and the context file is missing some good to know information --- src/core_dump_handler/dlt_cdh.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/core_dump_handler/dlt_cdh.h b/src/core_dump_handler/dlt_cdh.h index 3dac480a8..1ace805b4 100644 --- a/src/core_dump_handler/dlt_cdh.h +++ b/src/core_dump_handler/dlt_cdh.h @@ -45,7 +45,7 @@ #define CORE_FILE_PATTERN "%s/core.%d.%s.%d.gz" #define CONTEXT_FILE_PATTERN "%s/context.%d.%s.%d.txt" -#if ((__SIZEOF_POINTER) == 4) +#if ((__SIZEOF_POINTER__) == 4) #define ELF_Ehdr Elf32_Ehdr #define ELF_Phdr Elf32_Phdr #define ELF_Shdr Elf32_Shdr From acdb3e4144bcdff31cebe24ad127c12c679c540a Mon Sep 17 00:00:00 2001 From: Gianfranco Costamagna Date: Tue, 21 Nov 2023 15:59:23 +0100 Subject: [PATCH 4/5] Update CMakeLists.txt Fix warning such as: CMake Warning (dev) in systemd/CMakeLists.txt: A logical block opening on the line /dlt-daemon-2.18.10/systemd/CMakeLists.txt:56 (if) closes on the line /dlt-daemon-2.18.10/systemd/CMakeLists.txt:64 (endif) with mis-matching arguments. This warning is for project developers. Use -Wno-dev to suppress it. --- systemd/CMakeLists.txt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/systemd/CMakeLists.txt b/systemd/CMakeLists.txt index a44e7bc7d..16cbe86b5 100644 --- a/systemd/CMakeLists.txt +++ b/systemd/CMakeLists.txt @@ -61,13 +61,13 @@ if(WITH_SYSTEMD) message( STATUS "Configured systemd unit file:dlt-adaptor-udp.service" ) message(STATUS "DLT adaptor udp configuration: APPID=${DLT_ADAPTOR_UDP_APPID} CTID=${DLT_ADAPTOR_UDP_CTID} PORT=${DLT_ADAPTOR_UDP_PORT}" ) install(FILES ${PROJECT_BINARY_DIR}/systemd/dlt-adaptor-udp.service DESTINATION ${SYSTEMD_CONFIGURATIONS_FILES_DIR} ) - endif(WITH_DLT_ADAPTOR_UDP) + endif(WITH_DLT_ADAPTOR_UDP OR WITH_DLT_ADAPTOR) if (WITH_SYSTEMD_SOCKET_ACTIVATION) configure_file(${PROJECT_SOURCE_DIR}/systemd/dlt.socket.cmake ${PROJECT_BINARY_DIR}/systemd/dlt.socket) message( STATUS "Configured systemd socket file:dlt.socket" ) install(FILES ${PROJECT_BINARY_DIR}/systemd/dlt.socket DESTINATION ${SYSTEMD_CONFIGURATIONS_FILES_DIR} ) - endif() + endif(WITH_SYSTEMD_SOCKET_ACTIVATION) message(STATUS "Unit files will be installed to ${SYSTEMD_CONFIGURATIONS_FILES_DIR} after make install" ) From 2577c22be0a9ffb6165c263767bf5f17c67051a5 Mon Sep 17 00:00:00 2001 From: LUU QUANG MINH Date: Wed, 29 Nov 2023 16:13:15 +0700 Subject: [PATCH 5/5] console: remove duplicated function definition Signed-off-by: LUU QUANG MINH --- src/console/dlt-convert.c | 11 ----------- 1 file changed, 11 deletions(-) diff --git a/src/console/dlt-convert.c b/src/console/dlt-convert.c index 332e94ef2..4e281579a 100644 --- a/src/console/dlt-convert.c +++ b/src/console/dlt-convert.c @@ -126,17 +126,6 @@ void usage() printf(" -t Handling input compressed files (tar.gz)\n"); } -char *get_filename_ext(const char *filename) -{ - if (filename == NULL) - fprintf(stderr, "ERROR: %s: invalid arguments\n", __FUNCTION__); - - char *dot = strrchr(filename, '.'); - if(!dot || dot == filename) - return ""; - return dot + 1; -} - void empty_dir(const char *dir) { struct dirent **files = { 0 };