scripts/build/arch/powerpc.sh
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
parent 2675 7c288c777455
child 3169 9d0b37f08a10
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@520
     1
# Compute powerpc-specific values
yann@520
     2
yann@1634
     3
CT_DoArchTupleValues () {
yann@1634
     4
    # The architecture part of the tuple, override only for 64-bit
yann@1634
     5
    if [ "${CT_ARCH_64}" = "y" ]; then
yann@1634
     6
        CT_TARGET_ARCH="powerpc64"
yann@1634
     7
    fi
yann@1634
     8
yann@2723
     9
    # Only override values when ABI is not the default
mgherzan@2675
    10
    case "${CT_ARCH_powerpc_ABI}" in
yann@2723
    11
        eabi)
yann@2723
    12
            # EABI is only for bare-metal, so libc ∈ [none,newlib]
yann@2723
    13
            CT_TARGET_SYS="eabi"
yann@2723
    14
            ;;
mgherzan@2675
    15
        spe)
mgherzan@2675
    16
            case "${CT_LIBC}" in
yann@2723
    17
                none|newlib)    CT_TARGET_SYS="spe";;
yann@2723
    18
                *glibc)         CT_TARGET_SYS="gnuspe";;
yann@2723
    19
                uClibc)         CT_TARGET_SYS="uclibcgnuspe";;
mgherzan@2675
    20
            esac
mgherzan@2675
    21
            ;;
yann@1634
    22
    esac
yann@1634
    23
yann@1634
    24
    # Add extra flags for SPE if needed
mgherzan@2675
    25
    if [ "${CT_ARCH_powerpc_ABI_SPE}" = "y" ]; then
yann@1634
    26
        CT_ARCH_TARGET_CFLAGS="-mabi=spe -mspe"
yann@1634
    27
        CT_ARCH_CC_CORE_EXTRA_CONFIG="--enable-e500_double"
yann@1634
    28
        CT_ARCH_CC_EXTRA_CONFIG="--enable-e500_double"
yann@1634
    29
    fi
yann@1634
    30
}