]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
backport: re PR target/60991 ([avr] Stack corruption when using 24-bit integers __int...
authorSenthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
Tue, 20 May 2014 08:37:50 +0000 (08:37 +0000)
committerGeorg-Johann Lay <gjl@gcc.gnu.org>
Tue, 20 May 2014 08:37:50 +0000 (08:37 +0000)
gcc/
2014-05-20  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>

Backport from mainline r210325
2014-05-12  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>

PR target/60991
* config/avr/avr.c (avr_out_store_psi): Use correct constant
to restore Y.

gcc/testsuite/
2014-05-20  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>

Backport from mainline r210325
2014-05-12  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>

PR target/60991
* gcc.target/avr/pr60991.c: New testcase.

From-SVN: r210635

gcc/ChangeLog
gcc/config/avr/avr.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/avr/pr60991.c [new file with mode: 0644]

index 8cc35b37df590d189d0863e9b4120589af39d236..92b1ffad583a21af445627032df4790241988ca8 100644 (file)
@@ -1,3 +1,12 @@
+2014-05-20  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>
+
+       Backport from mainline r210325
+       2014-05-12  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>
+
+       PR target/60991
+       * config/avr/avr.c (avr_out_store_psi): Use correct constant
+       to restore Y.
+
 2014-05-13  Richard Biener  <rguenther@suse.de>
 
        Backport from mainline
index 0cb689ac8f24842e74a76f83c2a24475623dd404..100be1bf2a250a66daad3e7ea8b5312aa79b681c 100644 (file)
@@ -3643,7 +3643,7 @@ avr_out_store_psi (rtx insn, rtx *op, int *plen)
                                 "std Y+61,%A1"    CR_TAB
                                 "std Y+62,%B1"    CR_TAB
                                 "std Y+63,%C1"    CR_TAB
-                                "sbiw r28,%o0-60", op, plen, -5);
+                                "sbiw r28,%o0-61", op, plen, -5);
 
           return avr_asm_len ("subi r28,lo8(-%o0)" CR_TAB
                               "sbci r29,hi8(-%o0)" CR_TAB
index bf2dd75dc2e835d74575c26b180203d131144976..4609c56f7f1c5b60fb991c7dc225161cb920e995 100644 (file)
@@ -1,3 +1,11 @@
+2014-05-20  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>
+
+       Backport from mainline r210325
+       2014-05-12  Senthil Kumar Selvaraj  <senthil_kumar.selvaraj@atmel.com>
+
+       PR target/60991
+       * gcc.target/avr/pr60991.c: New testcase.
+
 2014-05-13  Richard Biener  <rguenther@suse.de>
 
        Backport from mainline
diff --git a/gcc/testsuite/gcc.target/avr/pr60991.c b/gcc/testsuite/gcc.target/avr/pr60991.c
new file mode 100644 (file)
index 0000000..a09f42a
--- /dev/null
@@ -0,0 +1,21 @@
+/* { dg-do run } */
+/* { dg-options "-O1" } */
+
+/* This testcase (simplified from the original bug report) exposes 
+   PR60991. The code generated for writing the __int24 value corrupts
+   the frame pointer if the offset is <= 63 + MAX_LD_OFFSET */
+
+#include <stdlib.h>
+
+int main(void)
+{
+    volatile char junk[62];
+    junk[0] = 5;
+    volatile __int24 staticConfig = 0;
+
+    if (junk[0] != 5)
+      abort();
+
+    exit(0);
+    return 0;
+}