7dc2b7b30d
* LP32 should use sa_restorer too. gdb expects this, and future (>= 3.15) x86 kernels will apparently stop supporting the case where SA_RESTORER isn't set. * gdb and libunwind care about the exact instruction sequences, so we need to modify the code slightly in a few cases to match what they're looking for. * gdb also cares about the exact function names (for some architectures), so we need to use __restore and __restore_rt rather than __sigreturn and __rt_sigreturn. * It's possible that we don't have a VDSO; dl_iterate_phdr shouldn't assume that getauxval(AT_SYSINFO_EHDR) will return a non-null pointer. This fixes unwinding through a signal handler in gdb for all architectures. It doesn't fix libunwind for arm and arm64. I'll keep investigating that... (cherry picked from commit 36f451a6d93b6807944d99fa23396e039c47e845) Bug: 17436734 Change-Id: Ic1ea1184db6655c5d96180dc07bcc09628e647cb
62 lines
2.2 KiB
Makefile
62 lines
2.2 KiB
Makefile
# arm64 specific configs
|
|
|
|
libc_common_src_files_arm64 := \
|
|
bionic/memrchr.c \
|
|
bionic/strrchr.cpp \
|
|
upstream-freebsd/lib/libc/string/wcscat.c \
|
|
upstream-freebsd/lib/libc/string/wcschr.c \
|
|
upstream-freebsd/lib/libc/string/wcscmp.c \
|
|
upstream-freebsd/lib/libc/string/wcscpy.c \
|
|
upstream-freebsd/lib/libc/string/wcslen.c \
|
|
upstream-freebsd/lib/libc/string/wcsrchr.c \
|
|
upstream-freebsd/lib/libc/string/wmemcmp.c \
|
|
upstream-openbsd/lib/libc/string/stpncpy.c \
|
|
upstream-openbsd/lib/libc/string/strcat.c \
|
|
upstream-openbsd/lib/libc/string/strlcat.c \
|
|
upstream-openbsd/lib/libc/string/strlcpy.c \
|
|
upstream-openbsd/lib/libc/string/strncat.c \
|
|
upstream-openbsd/lib/libc/string/strncpy.c \
|
|
|
|
# Fortify implementations of libc functions.
|
|
libc_common_src_files_arm64 += \
|
|
bionic/__memcpy_chk.cpp \
|
|
bionic/__memset_chk.cpp \
|
|
bionic/__strcpy_chk.cpp \
|
|
bionic/__strcat_chk.cpp \
|
|
|
|
##########################################
|
|
### CPU specific source files
|
|
libc_bionic_src_files_arm64 := \
|
|
arch-arm64/bionic/__bionic_clone.S \
|
|
arch-arm64/bionic/_exit_with_stack_teardown.S \
|
|
arch-arm64/bionic/__restore_rt.S \
|
|
arch-arm64/bionic/_setjmp.S \
|
|
arch-arm64/bionic/setjmp.S \
|
|
arch-arm64/bionic/__set_tls.c \
|
|
arch-arm64/bionic/sigsetjmp.S \
|
|
arch-arm64/bionic/syscall.S \
|
|
arch-arm64/bionic/vfork.S \
|
|
|
|
|
|
libc_crt_target_cflags_arm64 := \
|
|
-I$(LOCAL_PATH)/arch-arm64/include
|
|
|
|
libc_crt_target_crtbegin_file_arm64 := \
|
|
$(LOCAL_PATH)/arch-arm64/bionic/crtbegin.c
|
|
|
|
libc_crt_target_crtbegin_so_file_arm64 := \
|
|
$(LOCAL_PATH)/arch-common/bionic/crtbegin_so.c
|
|
|
|
## CPU variant specific source files
|
|
ifeq ($(strip $(TARGET_CPU_VARIANT)),)
|
|
$(warning TARGET_ARCH is arm64, but TARGET_CPU_VARIANT is not defined)
|
|
endif
|
|
cpu_variant_mk := $(LOCAL_PATH)/arch-arm64/$(TARGET_CPU_VARIANT)/$(TARGET_CPU_VARIANT).mk
|
|
ifeq ($(wildcard $(cpu_variant_mk)),)
|
|
$(error "TARGET_CPU_VARIANT not set or set to an unknown value. Possible values are generic, generic-neon, denver64. Use generic for devices that do not have a CPU similar to any of the supported cpu variants.")
|
|
endif
|
|
include $(cpu_variant_mk)
|
|
libc_common_additional_dependencies += $(cpu_variank_mk)
|
|
|
|
cpu_variant_mk :=
|