From 021d5f7f741c92479640ffce1ddfcbbab1d4e105 Mon Sep 17 00:00:00 2001 From: Aki Immonen Date: Thu, 8 Feb 2024 11:01:22 +0200 Subject: [PATCH] Not all modules were added to the modules list resulting in stack traces. The problem was that in order to a module to get added to the list, the next module needed to have a valid elf header, which is not always the case. The fixed code checks if the module names are different. --- src/modulefinder/sentry_modulefinder_linux.c | 25 +++++++++----------- 1 file changed, 11 insertions(+), 14 deletions(-) diff --git a/src/modulefinder/sentry_modulefinder_linux.c b/src/modulefinder/sentry_modulefinder_linux.c index 1d459c12f..613bc93bd 100644 --- a/src/modulefinder/sentry_modulefinder_linux.c +++ b/src/modulefinder/sentry_modulefinder_linux.c @@ -602,17 +602,6 @@ get_linux_vdso(void) return 0; } -static bool -is_valid_elf_header(void *start) -{ - unsigned char e_ident[EI_NIDENT]; - if (!read_safely(e_ident, start, EI_NIDENT)) { - return false; - } - return e_ident[EI_MAG0] == ELFMAG0 && e_ident[EI_MAG1] == ELFMAG1 - && e_ident[EI_MAG2] == ELFMAG2 && e_ident[EI_MAG3] == ELFMAG3; -} - static void load_modules(sentry_value_t modules) { @@ -669,8 +658,9 @@ load_modules(sentry_value_t modules) break; } - // skip mappings that are not readable - if (!module.start || module.permissions[0] != 'r') { + // skip mappings that are not readable/executable + if (!module.start + || (module.permissions[0] != 'r' && module.permissions[2] != 'x')) { continue; } // skip mappings in `/dev/` or mappings that have no filename @@ -687,7 +677,14 @@ load_modules(sentry_value_t modules) continue; } - if (is_valid_elf_header((void *)(size_t)module.start)) { + // Module is appended if next module has different file name + if ((!last_module.file.len + && (!module.file.len || last_module.file.len != module.file.len + || memcmp(last_module.file.ptr, module.file.ptr, + module.file.len))) + || (!module.file.len || last_module.file.len != module.file.len + || memcmp( + last_module.file.ptr, module.file.ptr, module.file.len))) { // clang-format off // On android, we sometimes have multiple mappings for the // same inode at the same offset, such as this: