diff options
author | Kugan Vivekanandarajah <kuganv@linaro.org> | 2014-03-30 22:41:59 +0000 |
---|---|---|
committer | Kugan Vivekanandarajah <kugan@gcc.gnu.org> | 2014-03-30 22:41:59 +0000 |
commit | 6c031d8dfd895dbd41492a87d2546b4960e793bd (patch) | |
tree | bb32c437cbef4e4c3b5324bc8996fc80466418eb | |
parent | 429749e23bd81edfcefca574647f65e45e903819 (diff) | |
download | gcc-6c031d8dfd895dbd41492a87d2546b4960e793bd.zip gcc-6c031d8dfd895dbd41492a87d2546b4960e793bd.tar.gz gcc-6c031d8dfd895dbd41492a87d2546b4960e793bd.tar.bz2 |
re PR target/60034 ("invalid expression as operand" in aarch64 inline asm)
PR target/60034
* aarch64/aarch64.c (aarch64_classify_address): Fix alignment for
section anchor.
PR target/60034
* gcc.target/aarch64/pr60034.c: New file.
From-SVN: r208949
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/config/aarch64/aarch64.c | 3 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/aarch64/pr60034.c | 10 |
4 files changed, 24 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b7b6bca..bf7c591 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2014-03-31 Kugan Vivekanandarajah <kuganv@linaro.org> + + PR target/60034 + * aarch64/aarch64.c (aarch64_classify_address): Fix alignment for + section anchor. + 2014-03-30 Uros Bizjak <ubizjak@gmail.com> * config/i386/sse.md (FMAMODE_NOVF512): New mode iterator. diff --git a/gcc/config/aarch64/aarch64.c b/gcc/config/aarch64/aarch64.c index e2812d2..a3147ee 100644 --- a/gcc/config/aarch64/aarch64.c +++ b/gcc/config/aarch64/aarch64.c @@ -3196,6 +3196,9 @@ aarch64_classify_address (struct aarch64_address_info *info, } else if (SYMBOL_REF_DECL (sym)) align = DECL_ALIGN (SYMBOL_REF_DECL (sym)); + else if (SYMBOL_REF_HAS_BLOCK_INFO_P (sym) + && SYMBOL_REF_BLOCK (sym) != NULL) + align = SYMBOL_REF_BLOCK (sym)->alignment; else align = BITS_PER_UNIT; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 49000c3..08b1431 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2014-03-31 Kugan Vivekanandarajah <kuganv@linaro.org> + + PR target/60034 + * gcc.target/aarch64/pr60034.c: New file. + 2014-03-29 Adam Butcher <adam@jessamine.co.uk> PR c++/60626 diff --git a/gcc/testsuite/gcc.target/aarch64/pr60034.c b/gcc/testsuite/gcc.target/aarch64/pr60034.c new file mode 100644 index 0000000..ab7e7f4 --- /dev/null +++ b/gcc/testsuite/gcc.target/aarch64/pr60034.c @@ -0,0 +1,10 @@ +/* { dg-do compile } */ +/* { dg-options "-std=gnu99 -O" } */ + +static unsigned long global_max_fast; + +void __libc_mallopt (int param_number, int value) +{ + __asm__ __volatile__ ("# %[_SDT_A21]" :: [_SDT_A21] "nor" ((global_max_fast))); + global_max_fast = 1; +} |