summaryrefslogtreecommitdiff
path: root/scripts/build/arch/arm.sh
blob: eeffc7d1f310d7ba304db4a88ff1aae5aee88bd6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
# Compute ARM-specific values

CT_DoArchTupleValues() {
    # The architecture part of the tuple:
    case "${CT_ARCH_BITNESS}" in
        32)
            CT_TARGET_ARCH="${CT_ARCH}${CT_ARCH_SUFFIX:-${target_endian_eb}}"
            ;;
        64)
            # ARM 64 (aka AArch64) is special
            [ "${CT_ARCH_BE}" = "y" ] && target_endian_eb="_be"
            CT_TARGET_ARCH="aarch64${CT_ARCH_SUFFIX:-${target_endian_eb}}"
            ;;
    esac

    # The system part of the tuple:
    case "${CT_LIBC},${CT_ARCH_ARM_EABI}" in
        *glibc,y)   CT_TARGET_SYS=gnueabi;;
        uClibc,y)   CT_TARGET_SYS=uclibc${CT_LIBC_UCLIBC_USE_GNU_SUFFIX:+gnu}eabi;;
        musl,y)     CT_TARGET_SYS=musleabi;;
        *,y)        CT_TARGET_SYS=eabi;;
    esac

    # Set the default instruction set mode
    case "${CT_ARCH_ARM_MODE}" in
        arm)    ;;
        thumb)
            CT_ARCH_CC_CORE_EXTRA_CONFIG="--with-mode=thumb"
            CT_ARCH_CC_EXTRA_CONFIG="--with-mode=thumb"
            ;;
    esac

    if [ "${CT_ARCH_ARM_INTERWORKING}" = "y" ]; then
        CT_ARCH_TARGET_CFLAGS+=" -mthumb-interwork"
    fi

    if [ "${CT_ARCH_ARM_TUPLE_USE_EABIHF}" = "y" ]; then
        CT_TARGET_SYS="${CT_TARGET_SYS}hf"
    fi

    # If building multilib, zero out any WITH_*/*_CFLAG - GCC on ARM does not allow
    # any of them with multilib.
    if [ "${CT_MULTILIB}" = "y" ]; then
        CT_ARCH_WITH_ARCH=
        CT_ARCH_WITH_ABI=
        CT_ARCH_WITH_CPU=
        CT_ARCH_WITH_TUNE=
        CT_ARCH_WITH_FPU=
        CT_ARCH_WITH_FLOAT=
        CT_ARCH_ARCH_CFLAG=
        CT_ARCH_ABI_CFLAG=
        CT_ARCH_CPU_CFLAG=
        CT_ARCH_TUNE_CFLAG=
        CT_ARCH_FPU_CFLAG=
        CT_ARCH_FLOAT_CFLAG=
    fi
}

CT_DoArchUClibcConfig() {
    local cfg="${1}"

    if [ "${CT_ARCH_BITNESS}" = 64 ]; then
        CT_DoArchUClibcSelectArch "${cfg}" "aarch64"
    else
        CT_DoArchUClibcSelectArch "${cfg}" "arm"
        case "${CT_ARCH_ARM_MODE}" in
            arm)
                CT_KconfigDisableOption "COMPILE_IN_THUMB_MODE" "${cfg}"
                ;;
            thumb)
                CT_KconfigEnableOption "COMPILE_IN_THUMB_MODE" "${cfg}"
                ;;
        esac
        # FIXME: CONFIG_ARM_OABI does not exist in neither uClibc/uClibc-ng
        # FIXME: CONFIG_ARM_EABI does not seem to affect anything in either of them, too
        # (both check the compiler's built-in define, __ARM_EABI__ instead) except for
        # a check for match between toolchain configuration and uClibc-ng in
        # uClibc_arch_features.h
        if [ "${CT_ARCH_ARM_EABI}" = "y" ]; then
            CT_KconfigDisableOption "CONFIG_ARM_OABI" "${cfg}"
            CT_KconfigEnableOption "CONFIG_ARM_EABI" "${cfg}"
        else
            CT_KconfigDisableOption "CONFIG_ARM_EABI" "${cfg}"
            CT_KconfigEnableOption "CONFIG_ARM_OABI" "${cfg}"
        fi
    fi
}

CT_DoArchUClibcCflags() {
    local cfg="${1}"
    local cflags="${2}"
    local f

    for f in ${cflags}; do
        case "${f}" in
            -mthumb)
                CT_KconfigEnableOption "COMPILE_IN_THUMB_MODE" "${cfg}"
                ;;
            -marm)
                CT_KconfigDisableOption "COMPILE_IN_THUMB_MODE" "${cfg}"
                ;;
            -mlittle-endian)
                CT_KconfigDisableOption "ARCH_BIG_ENDIAN" "${cfg}"
                CT_KconfigDisableOption "ARCH_WANTS_BIG_ENDIAN" "${cfg}"
                CT_KconfigEnableOption "ARCH_LITTLE_ENDIAN" "${cfg}"
                CT_KconfigEnableOption "ARCH_WANTS_LITTLE_ENDIAN" "${cfg}"
                ;;
            -mbig-endian)
                CT_KconfigEnableOption "ARCH_BIG_ENDIAN" "${cfg}"
                CT_KconfigEnableOption "ARCH_WANTS_BIG_ENDIAN" "${cfg}"
                CT_KconfigDisableOption "ARCH_LITTLE_ENDIAN" "${cfg}"
                CT_KconfigDisableOption "ARCH_WANTS_LITTLE_ENDIAN" "${cfg}"
                ;;
            -mhard-float|-mfloat-abi=hard|-mfloat-abi=softfp)
                CT_KconfigEnableOption "UCLIBC_HAS_FPU" "${cfg}"
                ;;
            -msoft-float|-mfloat-abi=soft)
                CT_KconfigDisableOption "UCLIBC_HAS_FPU" "${cfg}"
                ;;
        esac
    done
}