patches/gcc/4.2.4/241-arm-bigendian2.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Tue Dec 13 23:32:39 2011 +0100 (2011-12-13)
branch1.13
changeset 2847 c0bf2319af08
permissions -rw-r--r--
scripts: fix dumping execution backtrace

Dumping the backtrace has been broken since changeset #652e56d6d35a:
scripts: execute each steps in a subshell

We can spawn sub-sub-shells in some cases.

The way the fault handler works is to dump the backtrace, but to avoid
printing it once for every sub-shell (which could get quite confusing),
it simply exits when it detects that it is being run in a sub-shell,
leaving to the top-level shell the work to dump the backtrace.

Because each step is executed in its own sub-shell, the variable arrays
that contain the step name, the source file and line number, are lost
when exiting the per-step sub-shell.

Hence, the backtrace is currently limited to printing only the top-level
main procedure of the shell.

Fix this thus:
- when dumping the bckatraces for the steps & the functions, remember
it was dumped, and only dump it if it was not already dumped
- at the top-level shell, print the hints

Also, rename the top-level step label.

Reported-by: Benoît Thébaudeau <benoit.thebaudeau@advansee.com>
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
(transplanted from 4193d6e6a17430a177fa88c287879c2c35e319f3)
yann@1128
     1
Gilles Chanteperdrix <gilles.chanteperdrix@xenomai.org> wrote:
yann@1128
     2
yann@1128
     3
I tried to use crosstool-ng to generate a toolchain for Linux on big
yann@1128
     4
endian arm with recent versions of gcc, glibc, etc... but had a few
yann@1128
     5
problems.
yann@1128
     6
yann@1128
     7
It appears that the gcc patch (for gcc 4.2.x)
yann@1128
     8
for big-endian arm (240-arm-bigendian.patch) lacks the change attached
yann@1128
     9
to this mail as 240-arm-bigendian2.patch.
yann@1128
    10
yann@1128
    11
--- gcc-4.2.4/gcc/config/arm/bpabi.h~	2007-09-01 17:28:30.000000000 +0200
yann@1128
    12
+++ gcc-4.2.4/gcc/config/arm/bpabi.h	2009-01-05 19:19:10.000000000 +0100
yann@1128
    13
@@ -32,9 +32,19 @@
yann@1128
    14
 #undef FPUTYPE_DEFAULT
yann@1128
    15
 #define FPUTYPE_DEFAULT FPUTYPE_VFP
yann@1128
    16
 
yann@1128
    17
+/*
yann@1128
    18
+ * 'config.gcc' defines TARGET_BIG_ENDIAN_DEFAULT as 1 for arm*b-*
yann@1128
    19
+ * (big endian) configurations.
yann@1128
    20
+ */
yann@1128
    21
+#if TARGET_BIG_ENDIAN_DEFAULT
yann@1128
    22
+#define TARGET_ENDIAN_DEFAULT MASK_BIG_END
yann@1128
    23
+#else
yann@1128
    24
+#define TARGET_ENDIAN_DEFAULT 0
yann@1128
    25
+#endif
yann@1128
    26
+
yann@1128
    27
 /* EABI targets should enable interworking by default.  */
yann@1128
    28
 #undef TARGET_DEFAULT
yann@1128
    29
-#define TARGET_DEFAULT MASK_INTERWORK
yann@1128
    30
+#define TARGET_DEFAULT (MASK_INTERWORK | TARGET_ENDIAN_DEFAULT)
yann@1128
    31
 
yann@1128
    32
 /* The ARM BPABI functions return a boolean; they use no special
yann@1128
    33
    calling convention.  */