config/toolchain.in
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Thu Jun 02 19:50:12 2011 +0200 (2011-06-02)
changeset 2500 ba1e71fa72a9
parent 2490 cce067f0448e
child 2503 b5541f296b92
permissions -rw-r--r--
cc/gcc: CC_STATIC_LIBSTDCXX 'depends on' CONFIGURE_has_static_libstdcpp

Hide the staticaly linked libstdc++ option if the static libstdc++ is not
present, detected at configure time.

Add a blind option that says whether static linking is possible at all.
It defaults to 'y', but depends on the needed CONFIGURE_* options. For
now, it only depends on static libtdc++, but new dependencies can be
easily added.

Hide the global static toolchain option behind this new option.

Original patch by Bryan Hundven <bryanhundven@gmail.com>

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
yann@41
     1
menu "Toolchain options"
yann@41
     2
yann@41
     3
comment "General toolchain options"
yann@41
     4
yann@2281
     5
config FORCE_SYSROOT
yann@2281
     6
    bool
yann@2281
     7
    default y if !OBSOLETE
yann@2281
     8
    select USE_SYSROOT
yann@2281
     9
yann@41
    10
config USE_SYSROOT
yann@41
    11
    bool
yann@41
    12
    prompt "Use sysroot'ed toolchain"
yann@41
    13
    default y
yann@41
    14
    help
yann@41
    15
      Use the 'shinny new' sysroot feature of gcc: libraries split between
yann@2279
    16
      prefix/target/sysroot/lib and prefix/target/sysroot/usr/lib
yann@41
    17
      
yann@41
    18
      You definitely want to say 'Y' here. Yes you do. I know you do. Say 'Y'.
yann@41
    19
yann@2279
    20
config SYSROOT_NAME
yann@2279
    21
    string
yann@2407
    22
    prompt "sysroot directory name" if ! BACKEND
yann@2279
    23
    depends on USE_SYSROOT
yann@2279
    24
    default "sysroot"
yann@2279
    25
    help
yann@2279
    26
      Enter the base name of the sysroot directory. Usually, this simply
yann@2279
    27
      is 'sysroot' (the default) or 'sys-root'.
yann@2279
    28
      
yann@2279
    29
      You are free to enter anything here, except for spaces, and '/'
yann@2279
    30
      (see SYSROOT_DIR_PREFIX, below). If you leave this empy, then the
yann@2279
    31
      default 'sysroot' is used.
yann@2279
    32
yann@1219
    33
config SYSROOT_DIR_PREFIX
yann@1219
    34
    string
yann@1865
    35
    prompt "sysroot prefix dir (READ HELP)" if ! BACKEND
yann@1219
    36
    depends on USE_SYSROOT
yann@1219
    37
    default ""
yann@1219
    38
    help
yann@1219
    39
      *
yann@1219
    40
      * Unless you realy know you need that, leave it empty!
yann@1219
    41
      *
yann@1219
    42
      
yann@1219
    43
      This string will be interpreted as a directory component to be added
yann@1219
    44
      to the sysroot path, just before the actual sysroot directory.
yann@1219
    45
      
yann@1219
    46
      In fact, the sysroot path is constructed as:
yann@2279
    47
        ${CT_PREFIX_DIR}/${CT_TARGET}/${CT_SYSROOT_DIR_PREFIX}/${CT_SYSROOT_NAME}
yann@1219
    48
yann@2500
    49
# In case we need to add more conditions to enable static
yann@2500
    50
# toolchain, we'll be adding them here
yann@2500
    51
config STATIC_TOOLCHAIN_POSSIBLE
yann@2500
    52
    bool
yann@2500
    53
    default y
yann@2500
    54
    depends on CONFIGURE_has_static_libstdcxx
yann@2500
    55
    # Add new deps here! :-)
yann@2500
    56
bryanhundven@2207
    57
config STATIC_TOOLCHAIN
bryanhundven@2207
    58
    bool
bryanhundven@2207
    59
    prompt "Build Static Toolchain (EXPERIMENTAL)"
bryanhundven@2207
    60
    depends on EXPERIMENTAL
yann@2500
    61
    depends on STATIC_TOOLCHAIN_POSSIBLE
bryanhundven@2207
    62
    help
bryanhundven@2207
    63
      Build static host binaries.
bryanhundven@2207
    64
      
bryanhundven@2207
    65
      If you wish to move the toolchain to another host, and you are not
bryanhundven@2207
    66
      confident that this host has the required versions of system libs, then
bryanhundven@2207
    67
      you can say 'Y' here, and all the host tools will be linked staticaly.
bryanhundven@2207
    68
      
yann@2209
    69
      The impacted tools are:
bryanhundven@2210
    70
        - the GNU binutils
yann@2209
    71
        - the cross-gdb
yann@2209
    72
      
bryanhundven@2207
    73
      The default is 'N', to build dynamicaly-linked host binaries.
bryanhundven@2207
    74
      
bryanhundven@2207
    75
      NOTE: this has no connection to whether the target libraries will be
bryanhundven@2207
    76
      dynamic or static. This only applies to the tools themselves.
bryanhundven@2207
    77
benoit@2487
    78
config TOOLCHAIN_PKGVERSION
benoit@2487
    79
    string
benoit@2487
    80
    prompt "Toolchain ID string"
benoit@2487
    81
    default "crosstool-NG-${CT_VERSION}"
benoit@2487
    82
    help
benoit@2487
    83
      Specify a string that identifies your package. You may wish to include
benoit@2487
    84
      a build number or build date. This version string will be included in
benoit@2490
    85
      the output of gcc --version, and also in binutils, eglibc, gdb and
benoit@2490
    86
      gdbserver.
benoit@2487
    87
benoit@2487
    88
      This is passed to the configure flag --with-pkgversion.
benoit@2487
    89
benoit@2487
    90
config TOOLCHAIN_BUGURL
benoit@2487
    91
    string
benoit@2487
    92
    prompt "Toolchain bug URL"
benoit@2487
    93
    default ""
benoit@2487
    94
    help
benoit@2487
    95
      Specify the URL that users should visit if they wish to report a bug.
benoit@2487
    96
yann@1220
    97
comment "Tuple completion and aliasing"
yann@1220
    98
yann@41
    99
config TARGET_VENDOR
yann@41
   100
    string
yann@1220
   101
    prompt "Tuple's vendor string"
yann@41
   102
    default "unknown"
yann@41
   103
    help
yann@335
   104
      Vendor part of the target tuple.
yann@41
   105
      
yann@335
   106
      A tuple is of the form arch-vendor-kernel-system.
yann@41
   107
      You can set the second part, vendor, to whatever you see fit.
yann@41
   108
      Use a single word, or use underscores "_" to separate words.
yann@1094
   109
      Use neither dash nor space, as it breaks things.
yann@41
   110
      
yann@1704
   111
      Keep the default (unknown) if you don't know better.
yann@41
   112
yann@321
   113
config TARGET_ALIAS_SED_EXPR
yann@321
   114
    string
yann@1220
   115
    prompt "Tuple's sed transform"
yann@321
   116
    default ""
yann@321
   117
    help
yann@321
   118
      Normaly, you'd call your toolchain components (especially gcc) by
yann@335
   119
      prefixing the target tuple followed by a dash and the component name
yann@321
   120
      (eg. armeb-unknown-linux-uclibc-gcc).
yann@321
   121
      
yann@321
   122
      You can enter here a sed expression to be applied to ${CT_TARGET} to
yann@321
   123
      create an alias for your toolchain.
yann@321
   124
      
yann@321
   125
      For example, "s/${CT_TARGET_VENDOR}/foobar/" (without the double quotes)
yann@321
   126
      will create the armeb-foobar-linux-uclibc alias to the above-mentioned
yann@321
   127
      toolchain.
yann@321
   128
      
yann@321
   129
      You shouldn't need to enter anything here, unless you plan to manually
yann@321
   130
      call the tools (autotools-based ./configure will use the standard name).
yann@321
   131
yann@41
   132
config TARGET_ALIAS
yann@41
   133
    string
yann@1220
   134
    prompt "Tuple's alias"
yann@41
   135
    default ""
yann@41
   136
    help
yann@321
   137
      Normaly, you'd call your toolchain components (especially gcc) by
yann@335
   138
      prefixing the target tuple followed by a dash and the component name
yann@41
   139
      (eg. armeb-unknown-linux-uclibc-gcc).
yann@41
   140
      
yann@41
   141
      You can enter a shortcut here. This string will be used to create
yann@41
   142
      symbolic links to the toolchain tools (eg. if you enter "foo-bar" here,
yann@41
   143
      then gcc for your toolchain will also be available as "foo-bar-gcc" along
yann@41
   144
      with the original name).
yann@41
   145
      
yann@41
   146
      You shouldn't need to enter anything here, unless you plan to manually
yann@41
   147
      call the tools (autotools-based ./configure will use the standard name).
yann@41
   148
yann@41
   149
comment "Toolchain type"
yann@41
   150
yann@41
   151
choice
yann@41
   152
    bool
yann@41
   153
    prompt "Type"
yann@41
   154
    default CROSS
yann@41
   155
yann@41
   156
config NATIVE
yann@41
   157
    bool
yann@1041
   158
    prompt "Native       (NO CODE!) (EXPERIMENTAL)"
yann@41
   159
    depends on EXPERIMENTAL
yann@41
   160
    help
yann@41
   161
      Build a native toolchain.
yann@2227
   162
      See: "docs/6 - Toolchain types.txt"
yann@41
   163
yann@41
   164
config CROSS
yann@41
   165
    bool
yann@41
   166
    prompt "Cross"
yann@41
   167
    help
yann@41
   168
      Build a cross-toolchain.
yann@2227
   169
      See: "docs/6 - Toolchain types.txt"
yann@41
   170
yann@41
   171
config CROSS_NATIVE
yann@41
   172
    bool
yann@1041
   173
    prompt "Cross-native (NO CODE!) (EXPERIMENTAL)"
yann@41
   174
    depends on EXPERIMENTAL
yann@41
   175
    help
yann@41
   176
      Build a cross-native toolchain.
yann@2227
   177
      See: "docs/6 - Toolchain types.txt"
yann@41
   178
yann@41
   179
config CANADIAN
yann@41
   180
    bool
yann@1425
   181
    prompt "Canadian     (EXPERIMENTAL)"
yann@41
   182
    depends on EXPERIMENTAL
yann@41
   183
    help
yann@41
   184
      Build a canadian-toolchain.
yann@2227
   185
      See: "docs/6 - Toolchain types.txt"
yann@41
   186
yann@41
   187
endchoice
yann@41
   188
yann@96
   189
config TOOLCHAIN_TYPE
yann@96
   190
    string
yann@96
   191
    default "native"        if NATIVE
yann@96
   192
    default "cross"         if CROSS
yann@96
   193
    default "cross-native"  if CROSS_NATIVE
yann@96
   194
    default "canadian"      if CANADIAN
yann@96
   195
yann@1041
   196
comment "Build system"
yann@1041
   197
benoit@2484
   198
config BUILD
yann@41
   199
    string
yann@1041
   200
    prompt "|  Tuple        (READ HELP!)"
yann@41
   201
    default ""
yann@41
   202
    help
yann@41
   203
      Canonical name of the machine building the toolchain.
yann@41
   204
      You should leave empty, unless you really now what you're doing.
yann@41
   205
yann@1041
   206
config BUILD_PREFIX
yann@41
   207
    string
yann@1041
   208
    prompt "|  Tools prefix (READ HELP!)"
yann@1041
   209
    default ""
yann@41
   210
    help
yann@1041
   211
      If you have your *build system* tools in a weird location, and/or
yann@1041
   212
      they have an unusual prefix, enter it here.
yann@41
   213
      
yann@1041
   214
      Usually, you should leave that empty!
yann@41
   215
      
yann@1041
   216
      Eg.:
yann@1041
   217
        If your *build* gcc is /opt/build-tools/bin/weird-gcc then you
yann@1041
   218
        should enter:
yann@1041
   219
            /opt/build-tools/bin/weird-
yann@1041
   220
        
yann@1041
   221
        If your *build* gcc is /opt/build-tools/bin/weird-gcc and
yann@1041
   222
        /opt/build-tools/bin is in your PATH, you should enter:
yann@1041
   223
            weird-
yann@1041
   224
        
yann@1041
   225
        If your *build* gcc is /opt/build-tools/bin/gcc then you
yann@1041
   226
        should enter (do not forget to add the trailing '/'):
yann@1041
   227
            /opt/build-tools/bin/
yann@1041
   228
yann@1041
   229
config BUILD_SUFFIX
yann@1041
   230
    string
yann@1041
   231
    prompt "|  Tools suffix (READ HELP!)"
yann@1041
   232
    default ""
yann@1041
   233
    help
yann@1041
   234
      If your *build system* tools have an unusual suffix, enter it
yann@1041
   235
      here.
yann@1041
   236
      
yann@1041
   237
      Usually, you should leave that empty!
yann@1041
   238
      
yann@1041
   239
      Eg.:
yann@1041
   240
        If your 'default' gcc is gcc 4.3.1, but you also have gcc-3.4.2
yann@1041
   241
        installed as gcc-3.4, then you should enter:
yann@1041
   242
            -3.4
yann@1041
   243
      
yann@1041
   244
      It can happen that some of the tools have a suffix, when others
yann@1041
   245
      don't, eg. you can have 'gcc-3.4' and 'ar'. crosstool-NG accounts
yann@1041
   246
      for that by checking the tools without the suffix in case it can
yann@1041
   247
      not find some of the tool.
yann@1041
   248
yann@1041
   249
if CANADIAN
yann@1041
   250
yann@1041
   251
comment "Host system"
yann@41
   252
yann@41
   253
config HOST
yann@41
   254
    string
yann@1041
   255
    prompt "|  Tuple        (READ HELP!)"
yann@41
   256
    default ""
yann@41
   257
    help
yann@41
   258
      Canonical name of the machine running the toolchain.
yann@41
   259
yann@1041
   260
config HOST_PREFIX
yann@41
   261
    string
yann@1041
   262
    prompt "|  Tools prefix (READ HELP!)"
yann@1041
   263
    default ""
yann@41
   264
    help
yann@1041
   265
      If you have your *host system* tools in a weird location, and/or
yann@1041
   266
      they have an unusual prefix, enter it here.
yann@1041
   267
      
yann@1041
   268
      Usually, you should leave that empty!
yann@1041
   269
      
yann@1041
   270
      Eg.:
yann@1041
   271
        If your *host* gcc is /opt/host-tools/bin/weird-gcc then you
yann@1041
   272
        should enter:
yann@1041
   273
            /opt/host-tools/bin/weird-
yann@1041
   274
        
yann@1041
   275
        If your *host* gcc is /opt/host-tools/bin/weird-gcc and
yann@1041
   276
        /opt/host-tools/bin is in your PATH, you should enter:
yann@1041
   277
            weird-
yann@1041
   278
        
yann@1041
   279
        If your *host* gcc is /opt/host-tools/bin/gcc then you
yann@1041
   280
        should enter (do not forget to add the trailing '/'):
yann@1041
   281
            /opt/host-tools/bin/
yann@41
   282
yann@1041
   283
config HOST_SUFFIX
yann@41
   284
    string
yann@1041
   285
    prompt "|  Tools suffix (READ HELP!)"
yann@1041
   286
    default ""
yann@41
   287
    help
yann@1041
   288
      If your *host system* tools have an unusual suffix, enter it
yann@1041
   289
      here.
yann@1041
   290
      
yann@1041
   291
      Usually, you should leave that empty!
yann@1041
   292
      
yann@1041
   293
      Eg.:
yann@1041
   294
        If your 'default' gcc is gcc 4.3.1, but you also have gcc-3.4.2
yann@1041
   295
        installed as gcc-3.4, then you should enter:
yann@1041
   296
            -3.4
yann@1041
   297
      
yann@1041
   298
      It can happen that some of the tools have a suffix, when others
yann@1041
   299
      don't, eg. you can have 'gcc-3.4' and 'ar'. crosstool-NG accounts
yann@1041
   300
      for that by checking the tools without the suffix in case it can
yann@1041
   301
      not find some of the tool.
yann@1041
   302
yann@1041
   303
endif # CANADIAN
yann@1041
   304
yann@1041
   305
if CROSS_NATIVE || CANADIAN
yann@1041
   306
yann@1041
   307
comment "Target system"
yann@1041
   308
yann@1041
   309
config TARGET_PREFIX
yann@1041
   310
    string
yann@1041
   311
    prompt "|  Tools prefix (READ HELP!)"
yann@1041
   312
    default ""
yann@1041
   313
    help
yann@1041
   314
      If you have your *target system* tools in a weird location, and/or
yann@1041
   315
      they have an unusual prefix, enter it here.
yann@1041
   316
      
yann@1041
   317
      Usually, you should leave that empty!
yann@1041
   318
      
yann@1041
   319
      Eg.:
yann@1041
   320
        If your *target* gcc is /opt/target-tools/bin/weird-gcc then you
yann@1041
   321
        should enter:
yann@1041
   322
            /opt/target-tools/bin/weird-
yann@1041
   323
        
yann@1041
   324
        If your *target* gcc is /opt/target-tools/bin/weird-gcc and
yann@1041
   325
        /opt/target-tools/bin is in your PATH, you should enter:
yann@1041
   326
            weird-
yann@1041
   327
        
yann@1041
   328
        If your *target* gcc is /opt/target-tools/bin/gcc then you
yann@1041
   329
        should enter (do not forget to add the trailing '/'):
yann@1041
   330
            /opt/target-tools/bin/
yann@1041
   331
yann@1041
   332
config TARGET_SUFFIX
yann@1041
   333
    string
yann@1041
   334
    prompt "|  Tools suffix (READ HELP!)"
yann@1041
   335
    default ""
yann@1041
   336
    help
yann@1041
   337
      If your *target system* tools have an unusual suffix, enter it
yann@1041
   338
      here.
yann@1041
   339
      
yann@1041
   340
      Usually, you should leave that empty!
yann@1041
   341
      
yann@1041
   342
      Eg.:
yann@1041
   343
        If your 'default' gcc is gcc 4.3.1, but you also have gcc-3.4.2
yann@1041
   344
        installed as gcc-3.4, then you should enter:
yann@1041
   345
            -3.4
yann@1041
   346
      
yann@1041
   347
      It can happen that some of the tools have a suffix, when others
yann@1041
   348
      don't, eg. you can have 'gcc-3.4' and 'ar'. crosstool-NG accounts
yann@1041
   349
      for that by checking the tools without the suffix in case it can
yann@1041
   350
      not find some of the tool.
yann@1041
   351
yann@1041
   352
endif # CROSS_NATIVE || CANADIAN
yann@41
   353
yann@41
   354
endmenu