config/libc/glibc-eglibc.in-common
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sun Jul 10 00:02:05 2011 +0200 (2011-07-10)
branch1.11
changeset 2556 1c0580ebdf9d
parent 2312 8b9938edd3d8
child 2444 896cb0d36c1a
permissions -rw-r--r--
scripts: on startup, also remove the buildtools dir

In case there's one lingering around (whether the previous build was
successful, or failed), we have to remove the buildtools directory
as well as the toochain build dir.

This should also fix the case where out makeinfo wrapper calls
itself recursively.

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
(transplanted from 0e8ff57073838afea8830fe09d1d01cdf7cb37d8)
yann@922
     1
# This file contains the common configuration options
yann@922
     2
# that apply to both glibc and eglibc.
yann@922
     3
yann@1178
     4
if LIBC_glibc || LIBC_eglibc
yann@1178
     5
yann@2377
     6
# Force using the BFD linker during the toolchain build
yann@2377
     7
config LIBC_glibc_familly
yann@2377
     8
    bool
yann@2377
     9
    default y
yann@2377
    10
    select BINUTILS_FORCE_LD_BFD
yann@2377
    11
yann@1315
    12
# Some architectures require the ports addon. List them one by one here:
yann@1337
    13
# This list must be carefully in sync with the architectures names
yann@1337
    14
# we can find in config/arch/*
yann@1337
    15
yann@1315
    16
config ARCH_arm
yann@1315
    17
    select LIBC_GLIBC_USE_PORTS
yann@1315
    18
yann@1315
    19
config ARCH_mips
yann@1315
    20
    select LIBC_GLIBC_USE_PORTS
yann@1315
    21
yann@1337
    22
# End of arch-specific ports auto-select
yann@1337
    23
yann@922
    24
comment "glibc/eglibc common options"
yann@922
    25
yann@922
    26
config LIBC_GLIBC_EXTRA_CONFIG
yann@922
    27
    string
yann@922
    28
    prompt "extra config"
yann@922
    29
    default ""
yann@922
    30
    help
yann@922
    31
      Extra flags to pass onto ./configure when configuring.
yann@922
    32
yann@922
    33
      Eg.: --enable-static-nss
yann@922
    34
yann@1232
    35
config LIBC_GLIBC_CONFIGPARMS
yann@1232
    36
    string
yann@1232
    37
    prompt "Extra config params (READ HELP)"
yann@1232
    38
    default "" if ! ARCH_sh
yann@1232
    39
    default "no-z-defs=yes" if ARCH_sh
yann@1232
    40
    help
yann@1232
    41
      Some architectures need to set options in the file configparms.
yann@1232
    42
      This is the case for sh3/4, which really need to set configparms
yann@1232
    43
      to "no-z-defs=yes" as of gcc-3.4/glibc-2.3.2.
yann@1232
    44
      
yann@1232
    45
      Unless you are building a toolchain for sh3/4, you should leave that empty.
yann@1232
    46
      
yann@1627
    47
      Note: If you need to pass more than one value, separate them with
yann@1627
    48
            '\n'. Eg.:  var1=val1\nvar2=val2
yann@1232
    49
yann@922
    50
config LIBC_GLIBC_EXTRA_CFLAGS
yann@922
    51
    string
yann@922
    52
    prompt "extra target CFLAGS"
yann@922
    53
    default ""
yann@922
    54
    help
yann@922
    55
      Extra target CFLAGS to use when building.
yann@922
    56
yann@922
    57
config LIBC_EXTRA_CC_ARGS
yann@922
    58
    string
yann@922
    59
    prompt "gcc extra flags"
yann@922
    60
    default ""
yann@922
    61
    help
yann@922
    62
      Extra flags to pass gcc when building.
yann@922
    63
yann@922
    64
      Seldom used, except for sparc64 which seems to need the flag -64
yann@922
    65
      to be passed onto gcc.
yann@922
    66
yann@2312
    67
config LIBC_ENABLE_FORTIFIED_BUILD
yann@2312
    68
    bool
yann@2312
    69
    prompt "Enable fortified build (EXPERIMENTAL)"
yann@2312
    70
    depends on EXPERIMENTAL
yann@2312
    71
    default n
yann@2312
    72
    help
yann@2312
    73
      If you say 'y' here, then glibc will be using fortified versions
yann@2312
    74
      of functions with format arguments (eg. vsyslog, printf...), and
yann@2312
    75
      do a sanity check on the format at runtime, to avoid some of the
yann@2312
    76
      common format string attacks.
yann@2312
    77
      
yann@2312
    78
      This is currently not supported, and will most probably result in
yann@2312
    79
      a broken build, with an error message like:
yann@2312
    80
        ../misc/syslog.c: In function '__vsyslog_chk':
yann@2312
    81
        ../misc/syslog.c:123: sorry, unimplemented: inlining failed in
yann@2312
    82
        call to 'syslog': function body not available
yann@2312
    83
      
yann@2312
    84
      If you are brave enough and want to debug the issue, then say 'y'
yann@2312
    85
      here. Otherwise, be still and say 'n' (the default). ;-)
yann@2312
    86
yann@2312
    87
bryanhundven@2180
    88
config LIBC_DISABLE_VERSIONING
bryanhundven@2180
    89
    bool
bryanhundven@2180
    90
    prompt "Disable symbols versioning"
bryanhundven@2180
    91
    default n
bryanhundven@2180
    92
    help
bryanhundven@2180
    93
      Do not include versioning information in the library objects.
bryanhundven@2180
    94
bryanhundven@2181
    95
config LIBC_OLDEST_ABI
bryanhundven@2181
    96
    string
bryanhundven@2181
    97
    prompt "Oldest supported ABI"
bryanhundven@2181
    98
    default ""
bryanhundven@2181
    99
    help
bryanhundven@2181
   100
      Set the oldest ABI supported by the C library.
bryanhundven@2181
   101
      
bryanhundven@2181
   102
      Setting this option, for example, to 2.2 will provide ABI support
bryanhundven@2181
   103
      back to (e)glibc-2.2.
bryanhundven@2181
   104
bryanhundven@2181
   105
      If this option is not set, (e)glibc will choose for you.
bryanhundven@2181
   106
yann@2289
   107
config LIBC_GLIBC_FORCE_UNWIND
yann@2289
   108
    bool
yann@2289
   109
    prompt "Force unwind support (READ HELP!)"
yann@2289
   110
    default n
yann@2289
   111
    help
yann@2289
   112
      If your toolchain fails building while building the C library
yann@2289
   113
      start files, or the complete C library, with a message like:
yann@2289
   114
        configure: error: forced unwind support is required
yann@2289
   115
      
yann@2289
   116
      then you may try setting this to 'y'. Otherwise, leave it to 'n'.
yann@2289
   117
      
yann@2289
   118
      The issue seems to be related to building NPTL on old versions
yann@2289
   119
      of glibc (and possibly eglibc as well) on some architectures
yann@2289
   120
      (seen on s390, s390x and x86_64).
yann@2289
   121
yann@922
   122
config LIBC_GLIBC_USE_PORTS
yann@922
   123
    bool
yann@922
   124
    prompt "Use the ports addon"
yann@922
   125
    default n
yann@922
   126
    help
yann@922
   127
      The ports addon contains some architecture ports that are not available
yann@922
   128
      in the official distribution.
yann@922
   129
yann@1315
   130
      For example, this is the case for ARM with glibc-2.4 and above.
yann@922
   131
yann@922
   132
      Say n only if you're sure that your architecture is in the official
yann@922
   133
      distribution for your chosen version.
yann@922
   134
yann@922
   135
config LIBC_ADDONS_LIST
yann@922
   136
    string
yann@922
   137
    prompt "Extra addons"
yann@922
   138
    default ""
yann@922
   139
    help
yann@922
   140
      Extra addons to include. Space separated list.
yann@922
   141
yann@922
   142
      You need to specify neither linuxthreads nor nptl, as they are added
yann@922
   143
      automagically for you depending on the threading model you choosed
yann@922
   144
      earlier.
yann@922
   145
yann@922
   146
      Eg.: crypt        (for very old libces)
yann@922
   147
yann@1759
   148
if LIBC_GLIBC_USE_PORTS || ( LIBC_ADDONS_LIST != "" )
yann@1759
   149
comment "WARNING !!!                                            "
yann@1759
   150
comment "|  For glibc >= 2.8, it can happen that the tarballs    "
yann@1759
   151
comment "|  for the addons are not available for download.       "
yann@1759
   152
comment "|  If that happens, bad luck... Try a previous version  "
yann@1759
   153
comment "|  or try again later... :-(                            "
yann@1314
   154
endif
yann@1314
   155
yann@922
   156
if KERNEL_linux
yann@922
   157
yann@922
   158
choice
yann@922
   159
    bool
yann@922
   160
    prompt "Minimum supported kernel version"
yann@922
   161
    default LIBC_GLIBC_KERNEL_VERSION_AS_HEADERS
yann@922
   162
yann@922
   163
config LIBC_GLIBC_KERNEL_VERSION_NONE
yann@922
   164
    bool
yann@922
   165
    prompt "Let ./configure decide"
yann@922
   166
    help
yann@922
   167
      Let ./configure decide what minimum kernel version glibc/eglibc
yann@922
   168
      will be able to run against.
yann@922
   169
      
yann@922
   170
      This will inclde legacy compatibility code for older kernels in
yann@922
   171
      the C library, thus ensuring that it will run on a large number
yann@922
   172
      of old kernels.
yann@922
   173
      
yann@922
   174
      The minimum kernel version supported will be dependent upon the
yann@922
   175
      target you build for. For example:
yann@922
   176
        alpha*-*-linux-gnu      Requires Linux 2.6.9 for NPTL
yann@922
   177
        sh[34]-*-linux-gnu      Requires Linux 2.6.11
yann@922
   178
        powerpc*                Requires Linux 2.4.19
yann@922
   179
        arm*-*-linux-*gnueabi   Requires Linux 2.6.16
yann@922
   180
yann@922
   181
config LIBC_GLIBC_KERNEL_VERSION_AS_HEADERS
yann@922
   182
    bool
yann@922
   183
    prompt "Same as kernel headers (default)"
yann@922
   184
    help
yann@922
   185
      Normaly, you'll want glibc/eglibc to run against the same kernel
yann@922
   186
      version as the one used for the headers.
yann@922
   187
      
yann@922
   188
      This is the default.
yann@922
   189
      
yann@922
   190
      If enabled, crosstool-ng will use the chosen version of kernel
yann@922
   191
      headers for the glibc minimum kernel version supported, which is
yann@922
   192
      what gets passed to "--enable-kernel=" when configuring glibc.
yann@922
   193
      
yann@922
   194
      Enabling this will ensure that no legacy compatibility code for
yann@922
   195
      older kernels is built into your C libraries, but it will
yann@922
   196
      be unable to run on kernel versions older than whichever kernel
yann@922
   197
      headers version you've built the toolchain for.
yann@922
   198
      
yann@922
   199
      If you know for sure that your toolchain will never need to build
yann@922
   200
      applications that will run under a kernel version older than your
yann@922
   201
      chosen kernel headers version (CT_KERNEL_VERSION), you can choose
yann@922
   202
      "y" here.
yann@922
   203
yann@922
   204
config LIBC_GLIBC_KERNEL_VERSION_CHOSEN
yann@922
   205
    bool
yann@922
   206
    prompt "Specific kernel version"
yann@922
   207
    help
yann@922
   208
      Specify the earliest Linux kernel version you want glibc to
yann@922
   209
      include support for.  This does not have to match the kernel
yann@922
   210
      headers version used for your toolchain.  This controls what is
yann@922
   211
      passed to the "--enable-kernel=" option to the glibc configure
yann@922
   212
      script.
yann@922
   213
yann@922
   214
      If you want to be able to statically link programs with your
yann@922
   215
      toolchain's C library, make sure this kernel version is lower than
yann@922
   216
      all kernels you wish to support to avoid "FATAL: kernel too old"
yann@922
   217
      errors.  The higher the version you specify, the less legacy code
yann@922
   218
      will be built into libc.
yann@922
   219
yann@922
   220
      Most people can leave this at the default value of "2.6.9".
yann@922
   221
yann@922
   222
if LIBC_GLIBC_KERNEL_VERSION_CHOSEN
yann@922
   223
yann@922
   224
config LIBC_GLIBC_MIN_KERNEL_VERSION
yann@922
   225
    string
yann@922
   226
    prompt "Minimum kernel version to support"
yann@922
   227
    default "2.6.9"
yann@922
   228
    help
yann@922
   229
      Enter here the lowest kernel version glibc/eglibc will be able to
yann@922
   230
      run against.
yann@922
   231
      
yann@922
   232
      The minimum kernel version supported will be dependent upon the
yann@922
   233
      target you build for. For example:
yann@922
   234
        alpha*-*-linux-gnu      Requires Linux 2.6.9 for NPTL
yann@922
   235
        sh[34]-*-linux-gnu      Requires Linux 2.6.11
yann@922
   236
        powerpc*                Requires Linux 2.4.19
yann@922
   237
        arm*-*-linux-*gnueabi   Requires Linux 2.6.16
yann@922
   238
      
yann@922
   239
      Note that no sanity check is performed by crosstool-NG to ensure
yann@922
   240
      that the value you enter here is appropriate for your target.
yann@922
   241
yann@922
   242
endif # LIBC_GLIBC_KERNEL_VERSION_CHOSEN
yann@922
   243
yann@922
   244
endchoice
yann@922
   245
yann@922
   246
config LIBC_GLIBC_MIN_KERNEL
yann@922
   247
    string
yann@922
   248
    default ""                            if LIBC_GLIBC_KERNEL_VERSION_NONE
yann@922
   249
    default KERNEL_VERSION                if LIBC_GLIBC_KERNEL_VERSION_AS_HEADERS
yann@1211
   250
    default LIBC_GLIBC_MIN_KERNEL_VERSION if LIBC_GLIBC_KERNEL_VERSION_CHOSEN
yann@922
   251
yann@922
   252
endif # KERNEL_linux
yann@1178
   253
yann@1178
   254
endif # LIBC_glibc || LIBC_eglibc