[PATCH] D40134: [asan] Add support for AArch64 ILP32

Adhemerval Zanella via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Nov 16 08:47:43 PST 2017


zatrazz created this revision.
zatrazz added a project: Sanitizers.
Herald added subscribers: kristof.beyls, kubamracek, rengolin, aemerson.

This patch adds asan support for AArch64 ILP32 abi. ILP32 [1] is a new abi
for AArch64 similar to x32 where AArch64 instruction set are coupled with a
data model where int, long and pointer are 32-bit.

Unfortunately current support is not upstream for all projects. Binutils
and GCC are already covered, but GLIBC [2] and Linux [3] are maintained in
out of tree branches.

Also current LLVM also does not have support for ILP32, so current idea
of this patch is to eventually sync with gcc libsanitizer.  In fact runtime
testing were done on gcc.

Main changes for compiler-rt is support the kernel ABI for internal
syscalls. Different than x32, ILP32 tries to leverage 32-bits syscalls
so kernel ABI for 64 bit argument passing (for ftruncate for instance)
are passed using the new Linux generic way for 32 bits (by splitting
high and low in two registers).

So instead of adding more adhoc defines to ILP32 I extende the
SANITIZER_USES_CANONICAL_LINUX_SYSCALLS to represent both 64 bits
argument syscalls (value of 1) and 32 bits (value of 2).

It also fixes an AArch64 issue with upcoming GLIBC 2.27 (the one which
also ILP32 is currently based) with mcontext_t definition (GLIBC now does
not based it on kernel sigcontext_t anymore, but rather redefines it with
slight different members name).

I did a sanity check against AArch64 ILP64 and x86_64 on Linux without
any regressions.

[1] http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dai0490a/ar01s01.html
[2] https://sourceware.org/git/?p=glibc.git;a=shortlog;h=refs/heads/arm/ilp32
[3] git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux.git


https://reviews.llvm.org/D40134

Files:
  lib/sanitizer_common/sanitizer_internal_defs.h
  lib/sanitizer_common/sanitizer_linux.cc
  lib/sanitizer_common/sanitizer_platform.h
  lib/sanitizer_common/sanitizer_platform_limits_posix.cc
  lib/sanitizer_common/sanitizer_platform_limits_posix.h

-------------- next part --------------
A non-text attachment was scrubbed...
Name: D40134.123195.patch
Type: text/x-patch
Size: 9952 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20171116/39f51988/attachment.bin>


More information about the llvm-commits mailing list