mirror of
https://github.com/chromium/crashpad.git
synced 2025-01-01 19:05:20 +08:00
d7467ba7e4
Not all libc implementations reliably expose pt_regs from <sys/ptrace.h>. glibc-2.25/sysdeps/generic/sys/ptrace.h, for example, does not #include <asm/ptrace.h> (which defines the structure) or anything else that would #include that file such as <linux/ptrace.h>. On the other hand, Android 7.1.1 bionic/libc/include/sys/ptrace.h does #include <linux/ptrace.h>. It is not viable to #include <asm/ptrace.h> or <linux/ptrace.h> directly: it would be natural to #include them, sorted, before <sys/ptrace.h> but this causes problems for glibc’s <sys/ptrace.h>. Constants like PTRACE_GETREGS and PTRACE_TRACEME are simple macros in <asm/ptrace.h> and <linux/ptrace.h>, respectively, but are defined in enums in glibc’s <sys/ptrace.h>, and this doesn’t mix well. It is possible to #include <asm/ptrace.h> (but not <linux/ptrace.h>) after <sys/ptrace.h>, but because this involves same-value macro redefinitions and because it reaches into internal headers, it’s not preferred. The alternative approach taken here is to use the user_regs structure from <sys/user.h>, which is reliably defined by both Bionic and glibc, and has the same layout as the kernel’s pt_regs structure. (All that matters in this code is the size of the structure.) See Android 7.1.1 bionic/libc/include/sys/user.h, glibc-2.25/sysdeps/unix/sysv/linux/arm/sys/user.h, and linux-4.9.15/arch/arm/include/asm/ptrace.h for the various equivalent definitions. Take the same approach for 64-bit ARM: use user_regs_struct from <sys/user.h> in preference to hoping for a C library’s <sys/ptrace.h> to somehow provide the kernel’s user_pt_regs. This mirrors the approach already being used for x86 and x86_64, which use the C library’s <sys/user.h> user_regs_struct. Bug: crashpad:30 Test: crashpad_util_test ProcessInfo.* Change-Id: I3067e32c7fa4d6c8f4f2d5b63df141a0f490cd13 Reviewed-on: https://chromium-review.googlesource.com/455558 Reviewed-by: Joshua Peraza <jperaza@chromium.org>