scripts/build/arch/powerpc.sh
author "Yann E. MORIN" <yann.morin.1998@free.fr>
Sat Oct 06 23:48:07 2012 +0200 (2012-10-06)
changeset 3083 3a7b2eee9dcd
parent 2675 7c288c777455
child 3169 9d0b37f08a10
permissions -rw-r--r--
scripts: add option to start an interactive debug shell

Add an option that, when a command fails:
- starts an interactive shell with the failed command's environment
- attempts re-execution of the failed command, continues, or aborts
at user's whim.

Before starting the debug-shell, the backtrace is printed.
When exiting for an abort, the standard error message is printed.

Based on an idea and a patch from: Johannes Stezenbach <js@sig21.net>
http://sourceware.org/ml/crossgcc/2012-09/msg00144.html

Signed-off-by: Johannes Stezenbach <js@sig21.net>
[yann.morin.1998@free.fr: integrate in the fault handler]
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
Acked-by: Johannes Stezenbach <js@sig21.net>
Patchwork-Id: 191571
Patchwork-Id: 191668
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
}