gcc/libsanitizer
hjl 5ab8a859b5 libsanitizer: Mark REAL(swapcontext) with indirect_return attribute on x86
Cherry-pick compiler-rt revision 337603:

When shadow stack from Intel CET is enabled, the first instruction of all
indirect branch targets must be a special instruction, ENDBR.

lib/asan/asan_interceptors.cc has

...
  int res = REAL(swapcontext)(oucp, ucp);
...

REAL(swapcontext) is a function pointer to swapcontext in libc.  Since
swapcontext may return via indirect branch on x86 when shadow stack is
enabled, as in this case,

int res = REAL(swapcontext)(oucp, ucp);
              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^  This function may be
returned via an indirect branch.

Here compiler must insert ENDBR after call, like

call *bar(%rip)
endbr64

I opened an LLVM bug:

https://bugs.llvm.org/show_bug.cgi?id=38207

to add the indirect_return attribute so that it can be used to inform
compiler to insert ENDBR after REAL(swapcontext) call.  We mark
REAL(swapcontext) with the indirect_return attribute if it is available.

This fixed:

https://bugs.llvm.org/show_bug.cgi?id=38249

Reviewed By: eugenis

Differential Revision: https://reviews.llvm.org/D49608

	PR target/86560
	* asan/asan_interceptors.cc (swapcontext) Cherry-pick
	compiler-rt revision 337603.
	* sanitizer_common/sanitizer_internal_defs.h (__has_attribute):
	Likewise.


git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@263009 138bc75d-0d04-0410-961f-82ee72b054a4
2018-07-26 14:48:55 +00:00
..
asan libsanitizer: Mark REAL(swapcontext) with indirect_return attribute on x86 2018-07-26 14:48:55 +00:00
builtins * ubsan.c (ubsan_expand_null_ifn): Use _v1 suffixed type mismatch 2017-10-19 11:23:59 +00:00
include * ubsan.c (ubsan_expand_null_ifn): Use _v1 suffixed type mismatch 2017-10-19 11:23:59 +00:00
interception Enable building libsanitizer with Intel CET 2017-11-17 21:34:50 +00:00
libbacktrace Enable building libsanitizer with Intel CET 2017-11-17 21:34:50 +00:00
lsan Allow for lack of VM_MEMORY_OS_ALLOC_ONCE on Mac OS X (PR sanitizer/82824) 2018-01-13 21:01:27 +00:00
sanitizer_common libsanitizer: Mark REAL(swapcontext) with indirect_return attribute on x86 2018-07-26 14:48:55 +00:00
tsan Enable building libsanitizer with Intel CET 2017-11-17 21:34:50 +00:00
ubsan Revert 2018-07-05 09:47:05 +00:00
ChangeLog libsanitizer: Mark REAL(swapcontext) with indirect_return attribute on x86 2018-07-26 14:48:55 +00:00
HOWTO_MERGE PR sanitizer/78307 2016-11-16 11:13:19 +00:00
LICENSE.TXT
LOCAL_PATCHES Add PR sanitizer/78532 patch to libsanitizer/LOCAL_PATCHES. 2016-11-30 12:32:55 +00:00
MERGE * ubsan.c (ubsan_expand_null_ifn): Use _v1 suffixed type mismatch 2017-10-19 11:23:59 +00:00
Makefile.am Revert 2018-07-05 09:47:05 +00:00
Makefile.in Revert 2018-07-05 09:47:05 +00:00
README.gcc
acinclude.m4 Enable building libsanitizer with Intel CET 2017-11-17 21:34:50 +00:00
aclocal.m4 libsanitizer: Bump to automake 1.11.6 2015-05-13 11:11:58 +00:00
config.h.in 2018-06-13 Denis Khalikov <d.khalikov@partner.samsung.com> 2018-06-13 19:51:42 +00:00
configure 2018-06-13 Denis Khalikov <d.khalikov@partner.samsung.com> 2018-06-13 19:51:42 +00:00
configure.ac 2018-06-13 Denis Khalikov <d.khalikov@partner.samsung.com> 2018-06-13 19:51:42 +00:00
configure.tgt If someone has access to a 64-bit mips-linux system to test 2018-04-26 01:16:47 +00:00
libsanitizer.spec.in
libtool-version
merge.sh PR sanitizer/79168 2017-01-24 00:18:36 +00:00

README.gcc

AddressSanitizer (http://code.google.com/p/address-sanitizer) and
ThreadSanitizer (http://code.google.com/p/thread-sanitizer/) are
projects initially developed by Google Inc.
Both tools consist of a compiler module and a run-time library.
The sources of the run-time library for these projects are hosted at
http://llvm.org/svn/llvm-project/compiler-rt in the following directories:
  include/sanitizer
  lib/sanitizer_common
  lib/interception
  lib/asan
  lib/tsan
  lib/lsan
  lib/ubsan

Trivial and urgent fixes (portability, build fixes, etc.) may go directly to the
GCC tree.  All non-trivial changes, functionality improvements, etc. should go
through the upstream tree first and then be merged back to the GCC tree.
The merges from upstream should be done with the aid of the merge.sh script;
it will also update the file MERGE to contain the upstream revision
we merged with.