re PR target/61223 (libstdc++ build fail due to pop lr register)
authorAlexey Merzlyakov <alexey.merzlyakov@samsung.com>
Tue, 20 May 2014 17:25:26 +0000 (17:25 +0000)
committerYury Gribov <ygribov@gcc.gnu.org>
Tue, 20 May 2014 17:25:26 +0000 (17:25 +0000)
2014-05-20  Alexey Merzlyakov  <alexey.merzlyakov@samsung.com>

PR libstdc++/61223
Revert:
2014-05-16  Alexey Merzlyakov  <alexey.merzlyakov@samsung.com>

PR libstdc++/60758
* libsupc++/eh_arm.cc (__cxa_end_cleanup): Change r4 to lr in save/restore
and add unwind directives.

From-SVN: r210650

libstdc++-v3/ChangeLog
libstdc++-v3/libsupc++/eh_arm.cc

index b2f8f00d38fd419d137443a6155d5023027510ec..72bf941656c3c882a7d7efdcdb896534f1205f16 100644 (file)
@@ -1,3 +1,13 @@
+2014-05-20  Alexey Merzlyakov  <alexey.merzlyakov@samsung.com>
+
+       PR libstdc++/61223
+       Revert:
+       2014-05-16  Alexey Merzlyakov  <alexey.merzlyakov@samsung.com>
+
+       PR libstdc++/60758
+       * libsupc++/eh_arm.cc (__cxa_end_cleanup): Change r4 to lr in save/restore
+       and add unwind directives.
+
 2014-05-20  Sebastian Huber  <sebastian.huber@embedded-brains.de>
 
        * testsuite/lib/libstdc++.exp (load_gcc_lib): Register loaded libs.
index 6a45af5afb10e358a3843e3918239e99d4c72958..aa453dddde9199257ac29df24783f83aa03e293f 100644 (file)
@@ -199,33 +199,27 @@ asm (".global __cxa_end_cleanup\n"
 "      nop             5\n");
 #else
 // Assembly wrapper to call __gnu_end_cleanup without clobbering r1-r3.
-// Also push lr to preserve stack alignment and to allow backtracing.
+// Also push r4 to preserve stack alignment.
 #ifdef __thumb__
 asm ("  .pushsection .text.__cxa_end_cleanup\n"
 "      .global __cxa_end_cleanup\n"
 "      .type __cxa_end_cleanup, \"function\"\n"
 "      .thumb_func\n"
 "__cxa_end_cleanup:\n"
-"      .fnstart\n"
-"      push\t{r1, r2, r3, lr}\n"
-"      .save\t{r1, r2, r3, lr}\n"
+"      push\t{r1, r2, r3, r4}\n"
 "      bl\t__gnu_end_cleanup\n"
-"      pop\t{r1, r2, r3, lr}\n"
+"      pop\t{r1, r2, r3, r4}\n"
 "      bl\t_Unwind_Resume @ Never returns\n"
-"      .fnend\n"
 "      .popsection\n");
 #else
 asm ("  .pushsection .text.__cxa_end_cleanup\n"
 "      .global __cxa_end_cleanup\n"
 "      .type __cxa_end_cleanup, \"function\"\n"
 "__cxa_end_cleanup:\n"
-"      .fnstart\n"
-"      stmfd\tsp!, {r1, r2, r3, lr}\n"
-"      .save\t{r1, r2, r3, lr}\n"
+"      stmfd\tsp!, {r1, r2, r3, r4}\n"
 "      bl\t__gnu_end_cleanup\n"
-"      ldmfd\tsp!, {r1, r2, r3, lr}\n"
+"      ldmfd\tsp!, {r1, r2, r3, r4}\n"
 "      bl\t_Unwind_Resume @ Never returns\n"
-"      .fnend\n"
 "      .popsection\n");
 #endif
 #endif