One more that I've just tested. Martin
>From 69bdfd4b8d845d2262139b4406cfd9f2d947f80d Mon Sep 17 00:00:00 2001 From: marxin <marxin@138bc75d-0d04-0410-961f-82ee72b054a4> Date: Wed, 28 Jun 2017 07:59:23 +0000 Subject: [PATCH] Backport r249728
gcc/ChangeLog: 2017-06-28 Martin Liska <mli...@suse.cz> PR sanitizer/81224 * asan.c (instrument_derefs): Bail out inner references that are hard register variables. gcc/testsuite/ChangeLog: 2017-06-28 Martin Liska <mli...@suse.cz> PR sanitizer/81224 * gcc.dg/asan/pr81224.c: New test. --- gcc/asan.c | 3 +++ gcc/testsuite/gcc.dg/asan/pr81224.c | 11 +++++++++++ 2 files changed, 14 insertions(+) create mode 100644 gcc/testsuite/gcc.dg/asan/pr81224.c diff --git a/gcc/asan.c b/gcc/asan.c index 9b35104dd43..b80df24acfd 100644 --- a/gcc/asan.c +++ b/gcc/asan.c @@ -1800,6 +1800,9 @@ instrument_derefs (gimple_stmt_iterator *iter, tree t, || bitsize != size_in_bytes * BITS_PER_UNIT) return; + if (TREE_CODE (inner) == VAR_DECL && DECL_HARD_REGISTER (inner)) + return; + if (TREE_CODE (inner) == VAR_DECL && offset == NULL_TREE && bitpos >= 0 diff --git a/gcc/testsuite/gcc.dg/asan/pr81224.c b/gcc/testsuite/gcc.dg/asan/pr81224.c new file mode 100644 index 00000000000..def5cb69aec --- /dev/null +++ b/gcc/testsuite/gcc.dg/asan/pr81224.c @@ -0,0 +1,11 @@ +/* PR sanitizer/80659 */ +/* { dg-do compile { target { i?86-*-* x86_64-*-* } } } */ +/* { dg-additional-options "-msse2" } */ + +int a; +int +b () +{ + register __attribute__ ((__vector_size__ (4 * sizeof (int)))) int c asm("xmm0"); + return c[a]; +} -- 2.14.1