config/global.in
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Mon May 14 19:59:41 2007 +0000 (2007-05-14)
changeset 95 57694569322b
parent 91 aa1d248fa51b
child 96 aa1a9fbd6eb8
permissions -rw-r--r--
Move the whole threading ;odel choice out of glibc and into the generic C library options: even uClibc may have NPTL at one point in the (hopefully near) future.
Mark the progress bar as being CPU-intensive.
Little style fix to the core C compiler build step.
yann@1
     1
# Overall toolchain configuration: paths, jobs, etc...
yann@1
     2
yann@1
     3
menu "Paths and misc options"
yann@1
     4
yann@41
     5
config EXPERIMENTAL
yann@41
     6
    bool
yann@41
     7
    prompt "Try features marked as EXPERIMENTAL"
yann@41
     8
    default n
yann@41
     9
    help
yann@41
    10
      If you set this to Y, then you will be able to try very experimental
yann@41
    11
      features.
yann@41
    12
      
yann@41
    13
      Experimental features can be one of:
yann@41
    14
        - working, in which case you should tell me it is!
yann@41
    15
        - buggy, in which case you could try patching and send me the result
yann@41
    16
        - unfinished, in which case you could try hacking it and send me the result
yann@41
    17
        - non-existant, in which case you could also try hacking it in and send the result
yann@41
    18
yann@61
    19
config OBSOLETE
yann@61
    20
    bool
yann@61
    21
    prompt "Use obsolete features"
yann@61
    22
    default n
yann@61
    23
    help
yann@61
    24
      If you set this to Y, you will be able to select obsolete features.
yann@61
    25
      
yann@61
    26
      Such obsolete features are the use of old kernel headers, old
yann@61
    27
      gcc versions, etc...
yann@61
    28
yann@1
    29
config PARALLEL_JOBS
yann@1
    30
    int
yann@1
    31
    prompt "Number of parallel jobs"
yann@1
    32
    default 1
yann@1
    33
    help
yann@1
    34
      Number of jobs make will be allowed to run concurently.
yann@1
    35
      Set this higher than the number of processors you have, but not too high.
yann@1
    36
      A good rule of thumb is twice the number of processors you have.
yann@1
    37
      
yann@1
    38
      Enter 1 (or 0) to have only one job at a time.
yann@1
    39
yann@1
    40
config LOAD
yann@1
    41
    int
yann@1
    42
    prompt "Maximum allowed load"
yann@1
    43
    default 0
yann@1
    44
    help
yann@1
    45
      Specifies that no new jobs should be started if there are others jobs
yann@1
    46
      running and the load average is at least this value.
yann@1
    47
      
yann@1
    48
      Makes sense on SMP machines only.
yann@1
    49
      
yann@1
    50
      Enter 0 to have no limit on the load average.
yann@1
    51
      
yann@1
    52
      Note: only the integer part of the load is allowed here (you can't enter
yann@1
    53
            0.75 for example).
yann@1
    54
yann@1
    55
config NICE
yann@1
    56
    int
yann@1
    57
    prompt "Nice level"
yann@1
    58
    default 0
yann@1
    59
    range 0 19
yann@1
    60
    help
yann@1
    61
      Renices the build process up.
yann@1
    62
yann@1
    63
config USE_PIPES
yann@1
    64
    bool
yann@1
    65
    prompt "Use -pipe"
yann@1
    66
    default y
yann@1
    67
    help
yann@1
    68
      Use gcc's option -pipe to use pipes rather than temp files when building
yann@1
    69
      the toolchain.
yann@1
    70
yann@1
    71
comment "Paths"
yann@1
    72
yann@85
    73
config LOCAL_TARBALLS_DIR
yann@1
    74
    string
yann@85
    75
    prompt "Local tarballs directory"
yann@85
    76
    default ""
yann@1
    77
    help
yann@85
    78
      If you have previously downloaded the tarballs, enter the PATH where
yann@85
    79
      you stored them here.
yann@31
    80
yann@1
    81
config PREFIX_DIR
yann@1
    82
    string
yann@1
    83
    prompt "Prefix directory"
yann@1
    84
    default "${HOME}/${CT_TARGET}"
yann@1
    85
    help
yann@1
    86
      This is the path the toolchain will run from.
yann@1
    87
yann@1
    88
config INSTALL_DIR
yann@1
    89
    string
yann@1
    90
#    prompt "Install directory"
yann@1
    91
    default "${CT_PREFIX_DIR}"
yann@1
    92
#    help
yann@1
    93
#      This is the path the target will be installed into.
yann@1
    94
#      
yann@1
    95
#      Normally, you would set this to ${CT_PREFIX_DIR}, but if for some reasons
yann@1
    96
#      you can't write there, you can install somewhere else and have a third
yann@1
    97
#      person do the install for you.
yann@1
    98
#      The reason you might also want to install elsewhere is if you are going
yann@1
    99
#      to package your shinny new toolchain for distribution.
yann@1
   100
yann@1
   101
config CUSTOM_PATCH
yann@1
   102
    bool
yann@1
   103
    prompt "Use custom patch directory"
yann@1
   104
    default n
yann@1
   105
    help
yann@1
   106
      If you have custom patches that you want to be applied, say 'Y' here and
yann@1
   107
      enter the path directory below.
yann@1
   108
      
yann@1
   109
      Note that you must ensure that the patch directory is arranged the same
yann@1
   110
      way the official directory is.
yann@1
   111
yann@1
   112
config CUSTOM_PATCH_ONLY
yann@1
   113
    bool
yann@1
   114
    prompt "Only use custom patches"
yann@1
   115
    default n
yann@1
   116
    depends on CUSTOM_PATCH
yann@1
   117
    help
yann@1
   118
      Don't apply patches coming with CT-NG, only those patches available in
yann@1
   119
      the directory below.
yann@1
   120
      
yann@1
   121
      If you say 'N' here, then the patches provided with CT-NG will be applied
yann@1
   122
      first, and then your patches.
yann@1
   123
yann@1
   124
config CUSTOM_PATCH_DIR
yann@1
   125
    string
yann@1
   126
    prompt "Custom patch directory"
yann@1
   127
    default ""
yann@1
   128
    depends on CUSTOM_PATCH
yann@1
   129
    help
yann@1
   130
      Enter the custom patch directory here.
yann@1
   131
yann@14
   132
config REMOVE_DOCS
yann@14
   133
    bool
yann@14
   134
    prompt "Remove documentation"
yann@14
   135
    default n
yann@14
   136
    help
yann@14
   137
      Remove the installed documentation (man and info pages).
yann@14
   138
      Gains around 8MiB for a uClibc-based, C and C++ compiler.
yann@14
   139
yann@63
   140
comment "Downloading"
yann@1
   141
yann@63
   142
config FORCE_DOWNLOAD
yann@1
   143
    bool
yann@63
   144
    prompt "Force downloads"
yann@1
   145
    default n
yann@1
   146
    help
yann@63
   147
      Force downloading tarballs, even if one already exists.
yann@63
   148
      
yann@63
   149
      Usefull if you suspect a tarball to be damaged.
yann@1
   150
yann@1
   151
config ONLY_DOWNLOAD
yann@1
   152
    bool
yann@63
   153
    prompt "Stop after downloading tarballs"
yann@1
   154
    default n
yann@1
   155
    help
yann@1
   156
      Only download the tarballs. Exit once it done.
yann@1
   157
      
yann@1
   158
      Usefull to pre-retrieve the tarballs before going off-line.
yann@1
   159
yann@63
   160
comment "Extracting"
yann@63
   161
    depends on ! ONLY_DOWNLOAD
yann@1
   162
yann@1
   163
config FORCE_EXTRACT
yann@1
   164
    bool
yann@1
   165
    prompt "Force extractions"
yann@1
   166
    depends on ! ONLY_DOWNLOAD
yann@1
   167
    default n
yann@1
   168
    help
yann@1
   169
      Force extraction of already exctracted tarballs.
yann@1
   170
      
yann@1
   171
      Usefull if you suspect a previous extract did not complete (eg. broken
yann@1
   172
      tarball), or you added a new set of patches for this component.
yann@1
   173
yann@63
   174
config ONLY_EXTRACT
yann@63
   175
    bool
yann@63
   176
    prompt "Stop after extracting tarballs"
yann@63
   177
    depends on ! ONLY_DOWNLOAD
yann@63
   178
    default n
yann@63
   179
    help
yann@63
   180
      Exit after unpacking and patching tarballs.
yann@63
   181
      
yann@63
   182
      Usefull to look at the code before doing the build itself.
yann@63
   183
yann@1
   184
comment "Logging"
yann@1
   185
yann@1
   186
choice
yann@1
   187
    bool
yann@1
   188
    prompt "Maximum log level to see:"
yann@1
   189
    default LOG_INFO
yann@1
   190
yann@1
   191
config LOG_ERROR
yann@1
   192
    bool
yann@1
   193
    prompt "ERROR"
yann@1
   194
    help
yann@1
   195
      The build will be silent.
yann@1
   196
      Only if there is an error will you see a mesage.
yann@1
   197
yann@1
   198
config LOG_WARN
yann@1
   199
    bool
yann@1
   200
    prompt "WARN"
yann@1
   201
    help
yann@1
   202
      The same as above, plus warnings.
yann@1
   203
yann@1
   204
config LOG_INFO
yann@1
   205
    bool
yann@1
   206
    prompt "INFO"
yann@1
   207
    help
yann@1
   208
      The same as above, plus informational messages (main steps).
yann@1
   209
yann@1
   210
config LOG_EXTRA
yann@1
   211
    bool
yann@1
   212
    prompt "EXTRA"
yann@1
   213
    help
yann@1
   214
      The same as above, plus extra messages (sub-steps).
yann@1
   215
yann@1
   216
config LOG_DEBUG
yann@1
   217
    bool
yann@1
   218
    prompt "DEBUG"
yann@1
   219
    help
yann@78
   220
      The same as above, plus lots of crosstool-NG debug information.
yann@78
   221
yann@78
   222
config LOG_ALL
yann@78
   223
    bool
yann@78
   224
    prompt "ALL"
yann@78
   225
    help
yann@78
   226
      The same as above, plus all components build messages (very noisy!).
yann@1
   227
yann@1
   228
endchoice
yann@1
   229
yann@1
   230
config LOG_LEVEL_MAX
yann@1
   231
    string
yann@1
   232
    default "ERROR"   if LOG_ERROR
yann@1
   233
    default "WARN"    if LOG_WARN
yann@1
   234
    default "INFO"    if LOG_INFO
yann@1
   235
    default "EXTRA"   if LOG_EXTRA
yann@1
   236
    default "DEBUG"   if LOG_DEBUG
yann@78
   237
    default "ALL"     if LOG_ALL
yann@1
   238
yann@47
   239
config LOG_SEE_TOOLS_WARN
yann@47
   240
    bool
yann@47
   241
    prompt "See warnings from the tool builds"
yann@47
   242
    default n
yann@47
   243
    depends on ! LOG_ERROR
yann@47
   244
    help
yann@91
   245
      If you say Y here, then you will see the warning lines from the
yann@91
   246
      components builds.
yann@47
   247
yann@47
   248
      It should suffice to say N here, as those will anyway be visible
yann@47
   249
      in the log file (if you want one).
yann@47
   250
yann@1
   251
config LOG_PROGRESS_BAR
yann@1
   252
    bool
yann@1
   253
    prompt "Progress bar"
yann@1
   254
    default n
yann@78
   255
    depends on ! LOG_ALL
yann@1
   256
    help
yann@1
   257
      This option will print a "rotating bar" (/-\|) below the last log line
yann@1
   258
      to show work is not stalled.
yann@1
   259
      
yann@1
   260
      Available when not in DEBUG log level.
yann@95
   261
      
yann@95
   262
      WARNING! Very CPU intensive! If you have spare CPU, then you can use it,
yann@95
   263
      otherwise, refrain from using it.
yann@1
   264
yann@1
   265
config LOG_USE_COLORS
yann@1
   266
    bool
yann@1
   267
    prompt "Use colors for logging to console"
yann@1
   268
    default n
yann@1
   269
    help
yann@1
   270
      Use colors to highlight important messages.
yann@1
   271
      ERROR: bright red
yann@1
   272
      WARN : bright yellow
yann@1
   273
      INFO : bright green
yann@1
   274
      EXTRA: dim green
yann@1
   275
      DEBUG: dim white
yann@1
   276
yann@1
   277
config LOG_TO_FILE
yann@1
   278
    bool
yann@1
   279
    prompt "Log to a file"
yann@1
   280
    default y
yann@1
   281
    help
yann@1
   282
      Save *full* logs to a file. Even log levels you didn't specify above
yann@1
   283
      will be available in this file.
yann@1
   284
yann@47
   285
      As a bonus, there is a script in tools/extractConfig.sh that is able
yann@47
   286
      to extract the configuration of crosstool-NG from the log file.
yann@47
   287
yann@47
   288
      Definitely, say Y.
yann@47
   289
yann@1
   290
config LOG_FILE
yann@1
   291
    string
yann@1
   292
    prompt "Log file"
yann@1
   293
    default "${CT_PREFIX_DIR}/${CT_TARGET}.log"
yann@1
   294
    depends on LOG_TO_FILE
yann@1
   295
    help
yann@1
   296
      File name into which to put logs.
yann@1
   297
yann@1
   298
endmenu