From 99f764d5094e7ee4119b199da438299a5d0f9081 Mon Sep 17 00:00:00 2001 From: Luca Guerra Date: Mon, 13 Nov 2023 15:46:23 +0000 Subject: [PATCH] fix(libsinsp): remove more ub from integer copies Signed-off-by: Luca Guerra --- userspace/libsinsp/event.cpp | 28 ++++++++++++++++------------ userspace/libsinsp/utils.cpp | 8 ++++---- 2 files changed, 20 insertions(+), 16 deletions(-) diff --git a/userspace/libsinsp/event.cpp b/userspace/libsinsp/event.cpp index e92b49eb2b..ad62dab831 100644 --- a/userspace/libsinsp/event.cpp +++ b/userspace/libsinsp/event.cpp @@ -1879,10 +1879,10 @@ const char* sinsp_evt::get_param_as_str(uint32_t id, OUT const char** resolved_s if(payload_len == 1 + 4 + 2 + 4 + 2) { ipv4tuple addr; - addr.m_fields.m_sip = *(uint32_t*)(payload + 1); - addr.m_fields.m_sport = *(uint16_t*)(payload+5); - addr.m_fields.m_dip = *(uint32_t*)(payload + 7); - addr.m_fields.m_dport = *(uint16_t*)(payload+11); + memcpy(&addr.m_fields.m_sip, payload + 1, sizeof(uint32_t)); + memcpy(&addr.m_fields.m_sport, payload + 5, sizeof(uint16_t)); + memcpy(&addr.m_fields.m_dip, payload + 7, sizeof(uint32_t)); + memcpy(&addr.m_fields.m_dport, payload + 11, sizeof(uint16_t)); addr.m_fields.m_l4proto = (m_fdinfo != NULL) ? m_fdinfo->get_l4proto() : SCAP_L4_UNKNOWN; std::string straddr = ipv4tuple_to_string(&addr, m_inspector->m_hostname_and_port_resolution_enabled); snprintf(&m_paramstr_storage[0], @@ -1910,10 +1910,10 @@ const char* sinsp_evt::get_param_as_str(uint32_t id, OUT const char** resolved_s if(sinsp_utils::is_ipv4_mapped_ipv6(sip6) && sinsp_utils::is_ipv4_mapped_ipv6(dip6)) { ipv4tuple addr; - addr.m_fields.m_sip = *(uint32_t*)sip; - addr.m_fields.m_sport = *(uint16_t*)(payload+17); - addr.m_fields.m_dip = *(uint32_t*)dip; - addr.m_fields.m_dport = *(uint16_t*)(payload+35); + memcpy(&addr.m_fields.m_sip, sip, sizeof(uint32_t)); + memcpy(&addr.m_fields.m_sport, payload + 17, sizeof(uint16_t)); + memcpy(&addr.m_fields.m_dip, dip, sizeof(uint32_t)); + memcpy(&addr.m_fields.m_dport, payload + 35, sizeof(uint16_t)); addr.m_fields.m_l4proto = (m_fdinfo != NULL) ? m_fdinfo->get_l4proto() : SCAP_L4_UNKNOWN; std::string straddr = ipv4tuple_to_string(&addr, m_inspector->m_hostname_and_port_resolution_enabled); @@ -1954,14 +1954,18 @@ const char* sinsp_evt::get_param_as_str(uint32_t id, OUT const char** resolved_s // // Sanitize the file string. // - std::string sanitized_str = payload + 17; - sanitize_string(sanitized_str); + std::string sanitized_str = payload + 17; + sanitize_string(sanitized_str); + + uint64_t src, dst; + memcpy(&src, payload + 1, sizeof(uint64_t)); + memcpy(&dst, payload + 9, sizeof(uint64_t)); snprintf(&m_paramstr_storage[0], m_paramstr_storage.size(), "%" PRIx64 "->%" PRIx64 " %s", - *(uint64_t*)(payload + 1), - *(uint64_t*)(payload + 9), + src, + dst, sanitized_str.c_str()); } else diff --git a/userspace/libsinsp/utils.cpp b/userspace/libsinsp/utils.cpp index 8577f99fa1..8055e29602 100644 --- a/userspace/libsinsp/utils.cpp +++ b/userspace/libsinsp/utils.cpp @@ -479,9 +479,9 @@ bool sinsp_utils::sockinfo_to_str(sinsp_sockinfo* sinfo, scap_fd_type stype, cha sinfo->m_ipv4info.m_fields.m_l4proto == SCAP_L4_UDP) { ipv4tuple addr; - addr.m_fields.m_sip = *(uint32_t*)sb; + addr.m_fields.m_sip = sinfo->m_ipv4info.m_fields.m_sip; addr.m_fields.m_sport = sinfo->m_ipv4info.m_fields.m_sport; - addr.m_fields.m_dip = *(uint32_t*)db; + addr.m_fields.m_dip = sinfo->m_ipv4info.m_fields.m_dip; addr.m_fields.m_dport = sinfo->m_ipv4info.m_fields.m_dport; addr.m_fields.m_l4proto = sinfo->m_ipv4info.m_fields.m_l4proto; std::string straddr = ipv4tuple_to_string(&addr, resolve); @@ -525,9 +525,9 @@ bool sinsp_utils::sockinfo_to_str(sinsp_sockinfo* sinfo, scap_fd_type stype, cha if(sinsp_utils::is_ipv4_mapped_ipv6(sip6) && sinsp_utils::is_ipv4_mapped_ipv6(dip6)) { ipv4tuple addr; - addr.m_fields.m_sip = *(uint32_t*)sip; + memcpy(&addr.m_fields.m_sip, sip, sizeof(uint32_t)); addr.m_fields.m_sport = sinfo->m_ipv4info.m_fields.m_sport; - addr.m_fields.m_dip = *(uint32_t*)dip; + memcpy(&addr.m_fields.m_dip, dip, sizeof(uint32_t)); addr.m_fields.m_dport = sinfo->m_ipv4info.m_fields.m_dport; addr.m_fields.m_l4proto = sinfo->m_ipv4info.m_fields.m_l4proto; std::string straddr = ipv4tuple_to_string(&addr, resolve);