scripts/build/libc/uClibc.sh
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sun Apr 19 16:17:11 2009 +0000 (2009-04-19)
branchnewlib
changeset 1365 c4d124ed9f8e
parent 1247 9759fe659b4f
child 1326 56a811a04414
permissions -rw-r--r--
Update the newlib devel branch with stuf from /trunk.

-------- diffstat follows --------
/devel/newlib/configure | 8 4 4 0
/devel/newlib/scripts/build/kernel/linux.sh | 2 1 1 0
/devel/newlib/scripts/build/cc/gcc.sh | 34 22 12 0 +
/devel/newlib/scripts/build/debug/300-gdb.sh | 52 45 7 0 +
/devel/newlib/scripts/build/libc/uClibc.sh | 6 3 3 0
/devel/newlib/scripts/build/mpfr.sh | 2 1 1 0
/devel/newlib/scripts/crosstool-NG.sh.in | 20 18 2 0 +
/devel/newlib/scripts/functions | 44 34 10 0 +
/devel/newlib/patches/glibc/2_9/500-ppc-glibc-2.9-atomic.patch | 414 0 414 0 ----------
/devel/newlib/patches/glibc/2_9/140-regex-BZ9697.patch | 111 0 111 0 ---
/devel/newlib/patches/glibc/2_9/190-queue-header-updates.patch | 89 0 89 0 --
/devel/newlib/patches/glibc/2_9/370-hppa_glibc-2.7-hppa-nptl-carlos.patch | 249 0 249 0 ------
/devel/newlib/patches/glibc/2_9/450-alpha-glibc-2.5-no-page-header.patch | 32 0 32 0 -
/devel/newlib/patches/glibc/2_9/330-2.3.3-china.patch | 35 0 35 0 -
/devel/newlib/patches/glibc/2_9/270-ldbl-nexttowardf.patch | 68 0 68 0 --
/devel/newlib/patches/glibc/2_9/410-2.9-fnmatch.patch | 64 0 64 0 --
/devel/newlib/patches/glibc/2_9/340-new-valencian-locale.patch | 120 0 120 0 ---
/devel/newlib/patches/glibc/2_9/350-2.4-undefine-__i686.patch | 47 0 47 0 -
/devel/newlib/patches/glibc/2_9/160-i386-x86_64-revert-clone-cfi.patch | 53 0 53 0 -
/devel/newlib/patches/glibc/2_9/150-regex-BZ697.patch | 28 0 28 0 -
/devel/newlib/patches/glibc/2_9/420-dont-build-timezone.patch | 19 0 19 0 -
/devel/newlib/patches/glibc/2_9/290-no-inline-gmon.patch | 38 0 38 0 -
/devel/newlib/patches/glibc/2_9/280-section-comments.patch | 29 0 29 0 -
/devel/newlib/patches/glibc/2_9/180-math-tests.patch | 72 0 72 0 --
/devel/newlib/patches/glibc/2_9/250-resolv-dynamic.patch | 44 0 44 0 -
/devel/newlib/patches/glibc/2_9/120-_nss_dns_gethostbyaddr2_r-check-and-adjust-the-buffer-alignment.patch | 35 0 35 0 -
/devel/newlib/patches/glibc/2_9/300-2.9-check_native-headers.patch | 22 0 22 0 -
/devel/newlib/patches/glibc/2_9/130-add_prio-macros.patch | 26 0 26 0 -
/devel/newlib/patches/glibc/2_9/310-2.3.6-fix-pr631.patch | 50 0 50 0 -
/devel/newlib/patches/glibc/2_9/510-sh-no-asm-user-header.patch | 70 0 70 0 --
/devel/newlib/patches/glibc/2_9/260-fadvise64_64.patch | 30 0 30 0 -
/devel/newlib/patches/glibc/2_9/440-alpha-glibc-2.4-xstat.patch | 249 0 249 0 ------
/devel/newlib/patches/glibc/2_9/170-2.10-dns-no-gethostbyname4.patch | 35 0 35 0 -
/devel/newlib/patches/glibc/2_9/230-2.3.3-localedef-fix-trampoline.patch | 74 0 74 0 --
/devel/newlib/patches/glibc/2_9/480-alpha-glibc-2.8-cache-shape.patch | 18 0 18 0 -
/devel/newlib/patches/glibc/2_9/360-2.8-nscd-one-fork.patch | 45 0 45 0 -
/devel/newlib/patches/glibc/2_9/210-2.9-strlen-hack.patch | 109 0 109 0 ---
/devel/newlib/patches/glibc/2_9/320-2.9-assume-pipe2.patch | 59 0 59 0 -
/devel/newlib/patches/glibc/2_9/100-ssp-compat.patch | 193 0 193 0 -----
/devel/newlib/patches/glibc/2_9/110-respect-env-CPPFLAGS.patch | 30 0 30 0 -
/devel/newlib/patches/glibc/2_9/220-manual-no-perl.patch | 29 0 29 0 -
/devel/newlib/patches/glibc/2_9/390-2.3.3_pre20040117-pt_pax.patch | 35 0 35 0 -
/devel/newlib/patches/glibc/2_9/460-alpha-glibc-2.5-no-asm-elf-header.patch | 38 0 38 0 -
/devel/newlib/patches/glibc/2_9/400-tests-sandbox-libdl-paths.patch | 198 0 198 0 -----
/devel/newlib/patches/glibc/2_9/520-sh-no-asm-elf-header.patch | 27 0 27 0 -
/devel/newlib/patches/glibc/2_9/240-i386-LOAD_PIC_REG.patch | 23 0 23 0 -
/devel/newlib/patches/glibc/2_9/200-awk-in-C-locale.patch | 23 0 23 0 -
/devel/newlib/patches/glibc/2_9/430-2.7-cross-compile-nptl.patch | 57 0 57 0 -
/devel/newlib/patches/glibc/2_9/380-2.3.6-dl_execstack-PaX-support.patch | 71 0 71 0 --
/devel/newlib/patches/glibc/2_9/490-ptr-mangling.patch | 114 0 114 0 ---
/devel/newlib/patches/glibc/2_9/470-alpha-glibc-2.8-creat.patch | 19 0 19 0 -
/devel/newlib/patches/glibc/ports-2_9/100-arm_linux_tls.patch | 14 0 14 0 -
/devel/newlib/patches/uClibc/0.9.30.1/140-gnu89-inline.patch | 2 1 1 0
/devel/newlib/docs/known-issues.txt | 16 15 1 0 +
/devel/newlib/docs/overview.txt | 2 1 1 0
/devel/newlib/samples/armeb-unknown-linux-uclibc/uClibc-0.9.30.config | 243 0 243 0 ------
/devel/newlib/samples/armeb-unknown-linux-uclibc/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/sh4-unknown-linux-gnu/crosstool.config | 35 18 17 0 +
/devel/newlib/samples/x86_64-unknown-linux-gnu/crosstool.config | 104 68 36 0 +--
/devel/newlib/samples/arm-unknown-elf/crosstool.config | 54 47 7 0 +
/devel/newlib/samples/armeb-unknown-eabi/crosstool.config | 54 47 7 0 +
/devel/newlib/samples/arm-unknown-linux-gnueabi/crosstool.config | 113 73 40 0 +--
/devel/newlib/samples/ia64-unknown-linux-gnu/crosstool.config | 91 61 30 0 +-
/devel/newlib/samples/x86_64-unknown-linux-uclibc/uClibc-0.9.30.config | 245 0 245 0 ------
/devel/newlib/samples/x86_64-unknown-linux-uclibc/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/armeb-unknown-linux-gnueabi/crosstool.config | 105 69 36 0 +--
/devel/newlib/samples/powerpc-e500v2-linux-gnuspe/crosstool.config | 96 63 33 0 +-
/devel/newlib/samples/i686-nptl-linux-gnu/crosstool.config | 78 48 30 0 +-
/devel/newlib/samples/arm-unknown-linux-gnu/crosstool.config | 105 69 36 0 +--
/devel/newlib/samples/powerpc-unknown-linux-gnu/crosstool.config | 103 67 36 0 +-
/devel/newlib/samples/mips-unknown-linux-uclibc/uClibc-0.9.30.config | 254 0 254 0 ------
/devel/newlib/samples/mips-unknown-linux-uclibc/crosstool.config | 77 54 23 0 +-
/devel/newlib/samples/arm-unknown-linux-uclibcgnueabi/uClibc-0.9.30.config | 253 0 253 0 ------
/devel/newlib/samples/arm-unknown-linux-uclibcgnueabi/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/arm-iphone-linux-gnueabi/crosstool.config | 84 57 27 0 +-
/devel/newlib/samples/armeb-unknown-linux-gnu/crosstool.config | 105 69 36 0 +--
/devel/newlib/samples/powerpc-unknown_nofpu-linux-gnu/crosstool.config | 104 68 36 0 +--
/devel/newlib/samples/i586-geode-linux-uclibc/uClibc-0.9.30.config | 263 0 263 0 ------
/devel/newlib/samples/i586-geode-linux-uclibc/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/arm-unknown-linux-uclibc/uClibc-0.9.30.config | 253 0 253 0 ------
/devel/newlib/samples/arm-unknown-linux-uclibc/crosstool.config | 78 55 23 0 +-
/devel/newlib/samples/powerpc-unknown-linux-uclibc/uClibc-0.9.30.config | 248 0 248 0 ------
/devel/newlib/samples/powerpc-unknown-linux-uclibc/crosstool.config | 77 54 23 0 +-
/devel/newlib/samples/mips-unknown-elf/crosstool.config | 54 47 7 0 +
/devel/newlib/samples/powerpc-405-linux-gnu/crosstool.config | 104 68 36 0 +--
/devel/newlib/samples/armeb-unknown-linux-uclibcgnueabi/crosstool.config | 26 13 13 0
/devel/newlib/samples/arm-unknown-eabi/crosstool.config | 54 47 7 0 +
/devel/newlib/samples/mipsel-unknown-linux-gnu/crosstool.config | 104 68 36 0 +--
/devel/newlib/samples/powerpc64-unknown-linux-gnu/crosstool.config | 75 49 26 0 +-
/devel/newlib/samples/alphaev56-unknown-linux-gnu/crosstool.config | 94 63 31 0 +-
/devel/newlib/samples/powerpc-860-linux-gnu/crosstool.config | 102 67 35 0 +-
/devel/newlib/config/kernel/linux.in | 87 46 41 0 +-
/devel/newlib/config/cc/gcc.in | 35 30 5 0 +
/devel/newlib/config/debug/gdb.in | 2 1 1 0
94 files changed, 1851 insertions(+), 5813 deletions(-)
yann@850
     1
# This file declares functions to install the uClibc C library
yann@850
     2
# Copyright 2007 Yann E. MORIN
yann@850
     3
# Licensed under the GPL v2. See COPYING in the root of this package
yann@850
     4
yann@850
     5
# Download uClibc
yann@850
     6
do_libc_get() {
yann@850
     7
    libc_src="http://www.uclibc.org/downloads
yann@850
     8
              http://www.uclibc.org/downloads/snapshots
yann@850
     9
              http://www.uclibc.org/downloads/old-releases"
yann@850
    10
    # For uClibc, we have almost every thing: releases, and snapshots
yann@850
    11
    # for the last month or so. We'll have to deal with svn revisions
yann@850
    12
    # later...
yann@1123
    13
    CT_GetFile "uClibc-${CT_LIBC_VERSION}" ${libc_src}
yann@850
    14
    # uClibc locales
yann@1126
    15
    if [ "${CT_LIBC_UCLIBC_LOCALES}" = "y" ]; then
yann@1126
    16
        CT_GetFile "uClibc-locale-030818" ${libc_src}
yann@1126
    17
    fi
yann@850
    18
yann@850
    19
    return 0
yann@850
    20
}
yann@850
    21
yann@850
    22
# Extract uClibc
yann@850
    23
do_libc_extract() {
yann@1126
    24
    CT_Extract "uClibc-${CT_LIBC_VERSION}"
yann@1126
    25
    CT_Patch "uClibc-${CT_LIBC_VERSION}"
yann@1126
    26
yann@850
    27
    # uClibc locales
yann@1123
    28
    if [ "${CT_LIBC_UCLIBC_LOCALES}" = "y" ]; then
yann@1126
    29
        CT_Pushd "${CT_SRC_DIR}/uClibc-${CT_LIBC_VERSION}/extra/locale"
yann@1126
    30
        CT_Extract "uClibc-locale-030818" nochdir
yann@1126
    31
        CT_Patch "uClibc-locale-030818" nochdir
yann@1123
    32
        CT_Popd
yann@1123
    33
    fi
yann@850
    34
yann@850
    35
    return 0
yann@850
    36
}
yann@850
    37
yann@850
    38
# Check that uClibc has been previously configured
yann@850
    39
do_libc_check_config() {
yann@850
    40
    CT_DoStep INFO "Checking C library configuration"
yann@850
    41
yann@850
    42
    CT_TestOrAbort "You did not provide a uClibc config file!" -n "${CT_LIBC_UCLIBC_CONFIG_FILE}" -a -f "${CT_LIBC_UCLIBC_CONFIG_FILE}"
yann@850
    43
yann@1247
    44
    if grep -E '^KERNEL_SOURCE=' "${CT_LIBC_UCLIBC_CONFIG_FILE}" >/dev/null 2>&1; then
yann@850
    45
        CT_DoLog WARN "Your uClibc version refers to the kernel _sources_, which is bad."
yann@850
    46
        CT_DoLog WARN "I can't guarantee that our little hack will work. Please try to upgrade."
yann@850
    47
    fi
yann@850
    48
yann@850
    49
    CT_DoLog EXTRA "Munging uClibc configuration"
yann@1272
    50
    mungeuClibcConfig "${CT_LIBC_UCLIBC_CONFIG_FILE}" "${CT_CONFIG_DIR}/uClibc.config"
yann@850
    51
yann@850
    52
    CT_EndStep
yann@850
    53
}
yann@850
    54
yann@850
    55
# This functions installs uClibc's headers
yann@850
    56
do_libc_headers() {
yann@850
    57
    CT_DoStep INFO "Installing C library headers"
yann@850
    58
yann@850
    59
    mkdir -p "${CT_BUILD_DIR}/build-libc-headers"
yann@850
    60
    cd "${CT_BUILD_DIR}/build-libc-headers"
yann@850
    61
yann@850
    62
    # Simply copy files until uClibc has the ablity to build out-of-tree
yann@850
    63
    CT_DoLog EXTRA "Copying sources to build dir"
yann@1123
    64
    { cd "${CT_SRC_DIR}/uClibc-${CT_LIBC_VERSION}"; tar cf - .; } |tar xf -
yann@850
    65
yann@850
    66
    # Retrieve the config file
yann@1272
    67
    cp "${CT_CONFIG_DIR}/uClibc.config" .config
yann@850
    68
yann@850
    69
    # uClibc uses the CROSS environment variable as a prefix to the
yann@850
    70
    # compiler tools to use.  Setting it to the empty string forces
yann@850
    71
    # use of the native build host tools, which we need at this
yann@850
    72
    # stage, as we don't have target tools yet.
yann@850
    73
    CT_DoLog EXTRA "Applying configuration"
yann@850
    74
    CT_DoYes "" |CT_DoExecLog ALL make CROSS= PREFIX="${CT_SYSROOT_DIR}/" oldconfig
yann@850
    75
yann@850
    76
    CT_DoLog EXTRA "Building headers"
yann@850
    77
    CT_DoExecLog ALL make ${CT_LIBC_UCLIBC_VERBOSITY} CROSS= PREFIX="${CT_SYSROOT_DIR}/" headers
yann@850
    78
yann@850
    79
    CT_DoLog EXTRA "Installing headers"
yann@1027
    80
    CT_DoExecLog ALL make ${CT_LIBC_UCLIBC_VERBOSITY} CROSS= PREFIX="${CT_SYSROOT_DIR}/" install_headers
yann@850
    81
yann@850
    82
    CT_EndStep
yann@850
    83
}
yann@850
    84
yann@850
    85
# Build and install start files
yann@850
    86
do_libc_start_files() {
yann@850
    87
    :
yann@850
    88
}
yann@850
    89
yann@850
    90
# This function build and install the full uClibc
yann@850
    91
do_libc() {
yann@850
    92
    CT_DoStep INFO "Installing C library"
yann@850
    93
yann@850
    94
    mkdir -p "${CT_BUILD_DIR}/build-libc"
yann@850
    95
    cd "${CT_BUILD_DIR}/build-libc"
yann@850
    96
yann@850
    97
    # Simply copy files until uClibc has the ablity to build out-of-tree
yann@850
    98
    CT_DoLog EXTRA "Copying sources to build dir"
yann@1123
    99
    { cd "${CT_SRC_DIR}/uClibc-${CT_LIBC_VERSION}"; tar cf - .; } |tar xf -
yann@850
   100
yann@850
   101
    # Retrieve the config file
yann@1272
   102
    cp "${CT_CONFIG_DIR}/uClibc.config" .config
yann@850
   103
yann@850
   104
    # uClibc uses the CROSS environment variable as a prefix to the compiler
yann@850
   105
    # tools to use.  The newly built tools should be in our path, so we need
yann@850
   106
    # only give the correct name for them.
yann@850
   107
    # Note about CFLAGS: In uClibc, CFLAGS are generated by Rules.mak,
yann@850
   108
    # depending  on the configuration of the library. That is, they are tailored
yann@850
   109
    # to best fit the target. So it is useless and seems to be a bad thing to
yann@850
   110
    # use LIBC_EXTRA_CFLAGS here.
yann@850
   111
    CT_DoLog EXTRA "Applying configuration"
yann@850
   112
    CT_DoYes "" |CT_DoExecLog ALL               \
yann@850
   113
                 make CROSS=${CT_TARGET}-       \
yann@850
   114
                 PREFIX="${CT_SYSROOT_DIR}/"    \
yann@850
   115
                 oldconfig
yann@850
   116
yann@850
   117
    # We do _not_ want to strip anything for now, in case we specifically
yann@850
   118
    # asked for a debug toolchain, thus the STRIPTOOL= assignment
yann@1029
   119
    # /Old/ versions can not build in //
yann@850
   120
    CT_DoLog EXTRA "Building C library"
yann@1029
   121
    CT_DoExecLog ALL                                    \
yann@1029
   122
    make ${CT_LIBC_UCLIBC_PARALLEL:+${PARALLELMFLAGS}}  \
yann@1029
   123
         CROSS=${CT_TARGET}-                            \
yann@1029
   124
         PREFIX="${CT_SYSROOT_DIR}/"                    \
yann@1029
   125
         STRIPTOOL=true                                 \
yann@1029
   126
         ${CT_LIBC_UCLIBC_VERBOSITY}                    \
yann@850
   127
         all
yann@850
   128
yann@850
   129
    # YEM-FIXME: we want to install libraries in $SYSROOT/lib, but we don't want
yann@850
   130
    # to install headers in $SYSROOT/include, thus making only install_runtime.
yann@1027
   131
    # Plus, the headers were previously installed earlier with install_headers,
yann@1027
   132
    # so all should be well. Unfortunately, the install_headers target does not
yann@1027
   133
    # install crti.o and consorts... :-( So reverting to target 'install'.
yann@850
   134
    # Note: PARALLELMFLAGS is not usefull for installation.
yann@850
   135
    # We do _not_ want to strip anything for now, in case we specifically
yann@1027
   136
    # asked for a debug toolchain, hence the STRIPTOOL= assignment
yann@850
   137
    CT_DoLog EXTRA "Installing C library"
yann@850
   138
    CT_DoExecLog ALL                    \
yann@850
   139
    make CROSS=${CT_TARGET}-            \
yann@850
   140
         PREFIX="${CT_SYSROOT_DIR}/"    \
yann@850
   141
         STRIPTOOL=true                 \
yann@850
   142
         ${CT_LIBC_UCLIBC_VERBOSITY}    \
yann@850
   143
         install
yann@850
   144
yann@1209
   145
    if [ "${CT_LIBC_UCLIBC_BUILD_CROSS_LDD}" = "y" ]; then
yann@1209
   146
        CT_DoLog EXTRA "Building C library cross-ldd"
yann@1209
   147
        CT_DoExecLog ALL                    \
yann@1209
   148
        make PREFIX="${CT_SYSROOT_DIR}/"    \
yann@1209
   149
             ${CT_LIBC_UCLIBC_VERBOSITY}    \
yann@1209
   150
             -C utils hostutils
yann@1209
   151
yann@1209
   152
        CT_DoLog EXTRA "Installing C library cross-ldd"
yann@1209
   153
        CT_DoExecLog ALL install -m 0755 utils/ldd.host "${CT_PREFIX_DIR}/bin/${CT_TARGET}-ldd"
yann@1209
   154
    fi
yann@1209
   155
yann@850
   156
    CT_EndStep
yann@850
   157
}
yann@850
   158
yann@850
   159
# This function is used to install those components needing the final C compiler
yann@850
   160
do_libc_finish() {
yann@1209
   161
    :
yann@850
   162
}
yann@850
   163
yann@850
   164
# Initialises the .config file to sensible values
yann@850
   165
# $1: original file
yann@850
   166
# $2: munged file
yann@850
   167
mungeuClibcConfig() {
yann@850
   168
    src_config_file="$1"
yann@850
   169
    dst_config_file="$2"
yann@850
   170
    munge_file="${CT_BUILD_DIR}/munge-uClibc-config.sed"
yann@850
   171
yann@850
   172
    # Start with a fresh file
yann@850
   173
    rm -f "${munge_file}"
yann@850
   174
    touch "${munge_file}"
yann@850
   175
yann@850
   176
    # Hack our target in the config file.
yann@850
   177
    # Also remove stripping: its the responsibility of the
yann@850
   178
    # firmware builder to strip or not.
yann@850
   179
    cat >>"${munge_file}" <<-ENDSED
yann@850
   180
s/^(TARGET_.*)=y$/# \\1 is not set/
yann@850
   181
s/^# TARGET_${CT_KERNEL_ARCH} is not set/TARGET_${CT_KERNEL_ARCH}=y/
yann@850
   182
s/^TARGET_ARCH=".*"/TARGET_ARCH="${CT_KERNEL_ARCH}"/
yann@850
   183
s/.*(DOSTRIP).*/# \\1 is not set/
yann@850
   184
ENDSED
yann@850
   185
yann@850
   186
    # Ah. We may one day need architecture-specific handler here...
yann@850
   187
    # Hack the ARM {E,O}ABI into the config file
yann@850
   188
    if [ "${CT_ARCH_ARM_EABI}" = "y" ]; then
yann@850
   189
        cat >>"${munge_file}" <<-ENDSED
yann@850
   190
s/.*(CONFIG_ARM_OABI).*/# \\1 is not set/
yann@850
   191
s/.*(CONFIG_ARM_EABI).*/\\1=y/
yann@850
   192
ENDSED
yann@850
   193
    else
yann@850
   194
        cat >>"${munge_file}" <<-ENDSED
yann@850
   195
s/.*(CONFIG_ARM_OABI).*/\\1=y/
yann@850
   196
s/.*(CONFIG_ARM_EABI).*/# \\1 is not set/
yann@850
   197
ENDSED
yann@850
   198
    fi
yann@850
   199
yann@850
   200
    # Accomodate for old and new uClibc versions, where the
yann@850
   201
    # way to select between big/little endian has changed
yann@850
   202
    case "${CT_ARCH_BE},${CT_ARCH_LE}" in
yann@850
   203
        y,) cat >>"${munge_file}" <<-ENDSED
yann@850
   204
s/.*(ARCH_LITTLE_ENDIAN).*/# \\1 is not set/
yann@850
   205
s/.*(ARCH_BIG_ENDIAN).*/\\1=y/
yann@850
   206
s/.*(ARCH_WANTS_LITTLE_ENDIAN).*/# \\1 is not set/
yann@850
   207
s/.*(ARCH_WANTS_BIG_ENDIAN).*/\\1=y/
yann@850
   208
ENDSED
yann@850
   209
        ;;
yann@850
   210
        ,y) cat >>"${munge_file}" <<-ENDSED
yann@850
   211
s/.*(ARCH_LITTLE_ENDIAN).*/\\1=y/
yann@850
   212
s/.*(ARCH_BIG_ENDIAN).*/# \\1 is not set/
yann@850
   213
s/.*(ARCH_WANTS_LITTLE_ENDIAN).*/\\1=y/
yann@850
   214
s/.*(ARCH_WANTS_BIG_ENDIAN).*/# \\1 is not set/
yann@850
   215
ENDSED
yann@850
   216
        ;;
yann@850
   217
    esac
yann@850
   218
yann@850
   219
    # Accomodate for old and new uClibc version, where the
yann@850
   220
    # way to select between hard/soft float has changed
yann@850
   221
    case "${CT_ARCH_FLOAT_HW},${CT_ARCH_FLOAT_SW}" in
yann@850
   222
        y,) cat >>"${munge_file}" <<-ENDSED
yann@850
   223
s/^[^_]*(HAS_FPU).*/\\1=y/
yann@850
   224
s/.*(UCLIBC_HAS_FPU).*/\\1=y/
yann@850
   225
ENDSED
yann@850
   226
            ;;
yann@850
   227
        ,y) cat >>"${munge_file}" <<-ENDSED
yann@850
   228
s/^[^_]*(HAS_FPU).*/\\# \\1 is not set/
yann@850
   229
s/.*(UCLIBC_HAS_FPU).*/# \\1 is not set/
yann@850
   230
ENDSED
yann@850
   231
            ;;
yann@850
   232
    esac
yann@850
   233
yann@850
   234
    # Change paths to work with crosstool-NG
yann@850
   235
    # From http://www.uclibc.org/cgi-bin/viewcvs.cgi?rev=16846&view=rev
yann@850
   236
    #  " we just want the kernel headers, not the whole kernel source ...
yann@850
   237
    #  " so people may need to update their paths slightly
yann@850
   238
    quoted_kernel_source=$(echo "${CT_HEADERS_DIR}" | sed -r -e 's,/include/?$,,; s,/,\\/,g;')
yann@850
   239
    quoted_headers_dir=$(echo "${CT_HEADERS_DIR}" | sed -r -e 's,/,\\/,g;')
yann@850
   240
    # CROSS_COMPILER_PREFIX is left as is, as the CROSS parameter is forced on the command line
yann@850
   241
    # DEVEL_PREFIX is left as '/usr/' because it is post-pended to $PREFIX, wich is the correct value of ${PREFIX}/${TARGET}
yann@850
   242
    # Some (old) versions of uClibc use KERNEL_SOURCE (which is _wrong_), and
yann@850
   243
    # newer versions use KERNEL_HEADERS (which is right). See:
yann@850
   244
    cat >>"${munge_file}" <<-ENDSED
yann@850
   245
s/^DEVEL_PREFIX=".*"/DEVEL_PREFIX="\\/usr\\/"/
yann@850
   246
s/^RUNTIME_PREFIX=".*"/RUNTIME_PREFIX="\\/"/
yann@850
   247
s/^SHARED_LIB_LOADER_PREFIX=.*/SHARED_LIB_LOADER_PREFIX="\\/lib\\/"/
yann@850
   248
s/^KERNEL_SOURCE=".*"/KERNEL_SOURCE="${quoted_kernel_source}"/
yann@850
   249
s/^KERNEL_HEADERS=".*"/KERNEL_HEADERS="${quoted_headers_dir}"/
yann@850
   250
s/^UCLIBC_DOWNLOAD_PREGENERATED_LOCALE=y/\\# UCLIBC_DOWNLOAD_PREGENERATED_LOCALE is not set/
yann@850
   251
ENDSED
yann@850
   252
yann@850
   253
    if [ "${CT_USE_PIPES}" = "y" ]; then
yann@850
   254
        if grep UCLIBC_EXTRA_CFLAGS extra/Configs/Config.in >/dev/null 2>&1; then
yann@850
   255
            # Good, there is special provision for such things as -pipe!
yann@850
   256
            cat >>"${munge_file}" <<-ENDSED
yann@850
   257
s/^(UCLIBC_EXTRA_CFLAGS=".*)"$/\\1 -pipe"/
yann@850
   258
ENDSED
yann@850
   259
        else
yann@850
   260
            # Hack our -pipe into WARNINGS, which will be internally incorporated to
yann@850
   261
            # CFLAGS. This a dirty hack, but yet needed
yann@850
   262
            cat >> "${munge_file}" <<-ENDSED
yann@850
   263
s/^(WARNINGS=".*)"$/\\1 -pipe"/
yann@850
   264
ENDSED
yann@850
   265
        fi
yann@850
   266
    fi
yann@850
   267
yann@1028
   268
    # Locales support
yann@850
   269
    # Note that the two PREGEN_LOCALE and the XLOCALE lines may be missing
yann@850
   270
    # entirely if LOCALE is not set.  If LOCALE was already set, we'll
yann@850
   271
    # assume the user has already made all the appropriate generation
yann@850
   272
    # arrangements.  Note that having the uClibc Makefile download the
yann@850
   273
    # pregenerated locales is not compatible with crosstool; besides,
yann@850
   274
    # crosstool downloads them as part of getandpatch.sh.
yann@1028
   275
    if [ "${CT_LIBC_UCLIBC_LOCALES}" = "y" ] ; then
yann@1028
   276
       cat >>"${munge_file}" <<-ENDSED
yann@1028
   277
s/^# UCLIBC_HAS_LOCALE is not set/UCLIBC_HAS_LOCALE=y\\nUCLIBC_PREGENERATED_LOCALE_DATA=y\\n\\# UCLIBC_DOWNLOAD_PREGENERATED_LOCALE_DATA is not set\\n\\# UCLIBC_HAS_XLOCALE is not
yann@1028
   278
ENDSED
yann@1028
   279
    fi
yann@1028
   280
yann@1028
   281
    # Force on options needed for C++ if we'll be making a C++ compiler.
yann@1028
   282
    # I'm not sure locales are a requirement for doing C++... Are they?
yann@850
   283
    if [ "${CT_CC_LANG_CXX}" = "y" ]; then
yann@850
   284
        cat >>"${munge_file}" <<-ENDSED
yann@850
   285
s/^# DO_C99_MATH is not set/DO_C99_MATH=y/
yann@850
   286
s/^# UCLIBC_CTOR_DTOR is not set/UCLIBC_CTOR_DTOR=y/
yann@850
   287
# Add these three lines when doing C++?
yann@850
   288
s/^# UCLIBC_HAS_WCHAR is not set/UCLIBC_HAS_WCHAR=y/
yann@850
   289
#s/^# UCLIBC_HAS_LOCALE is not set/UCLIBC_HAS_LOCALE=y\\nUCLIBC_PREGENERATED_LOCALE_DATA=y\\n\\# UCLIBC_DOWNLOAD_PREGENERATED_LOCALE_DATA is not set\\n\\# UCLIBC_HAS_XLOCALE is not set/
yann@850
   290
s/^# UCLIBC_HAS_GNU_GETOPT is not set/UCLIBC_HAS_GNU_GETOPT=y/
yann@850
   291
ENDSED
yann@850
   292
    fi
yann@850
   293
yann@850
   294
    # Always build the libpthread_db
yann@850
   295
    cat >>"${munge_file}" <<-ENDSED
yann@850
   296
s/^# PTHREADS_DEBUG_SUPPORT is not set.*/PTHREADS_DEBUG_SUPPORT=y/
yann@850
   297
ENDSED
yann@850
   298
yann@850
   299
    # Force on debug options if asked for
yann@850
   300
    case "${CT_LIBC_UCLIBC_DEBUG_LEVEL}" in
yann@850
   301
      0)
yann@850
   302
        cat >>"${munge_file}" <<-ENDSED
yann@850
   303
s/^DODEBUG=y/# DODEBUG is not set/
yann@850
   304
s/^DODEBUG_PT=y/# DODEBUG_PT is not set/
yann@850
   305
s/^DOASSERTS=y/# DOASSERTS is not set/
yann@850
   306
s/^SUPPORT_LD_DEBUG=y/# SUPPORT_LD_DEBUG is not set/
yann@850
   307
s/^SUPPORT_LD_DEBUG_EARLY=y/# SUPPORT_LD_DEBUG_EARLY is not set/
yann@850
   308
s/^UCLIBC_MALLOC_DEBUGGING=y/# UCLIBC_MALLOC_DEBUGGING is not set/
yann@850
   309
ENDSED
yann@850
   310
        ;;
yann@850
   311
      1)
yann@850
   312
        cat >>"${munge_file}" <<-ENDSED
yann@850
   313
s/^# DODEBUG is not set.*/DODEBUG=y/
yann@850
   314
s/^DODEBUG_PT=y/# DODEBUG_PT is not set/
yann@850
   315
s/^DOASSERTS=y/# DOASSERTS is not set/
yann@850
   316
s/^SUPPORT_LD_DEBUG=y/# SUPPORT_LD_DEBUG is not set/
yann@850
   317
s/^SUPPORT_LD_DEBUG_EARLY=y/# SUPPORT_LD_DEBUG_EARLY is not set/
yann@850
   318
s/^UCLIBC_MALLOC_DEBUGGING=y/# UCLIBC_MALLOC_DEBUGGING is not set/
yann@850
   319
ENDSED
yann@850
   320
        ;;
yann@850
   321
      2)
yann@850
   322
        cat >>"${munge_file}" <<-ENDSED
yann@850
   323
s/^# DODEBUG is not set.*/DODEBUG=y/
yann@850
   324
s/^# DODEBUG_PT is not set.*/DODEBUG_PT=y/
yann@850
   325
s/^# DOASSERTS is not set.*/DOASSERTS=y/
yann@850
   326
s/^# SUPPORT_LD_DEBUG is not set.*/SUPPORT_LD_DEBUG=y/
yann@850
   327
s/^# SUPPORT_LD_DEBUG_EARLY is not set.*/SUPPORT_LD_DEBUG_EARLY=y/
yann@850
   328
s/^# UCLIBC_MALLOC_DEBUGGING is not set/UCLIBC_MALLOC_DEBUGGING=y/
yann@850
   329
ENDSED
yann@850
   330
        ;;
yann@850
   331
    esac
yann@850
   332
    sed -r -f "${munge_file}" "${src_config_file}" >"${dst_config_file}"
yann@850
   333
}