config/cc/gcc.in.2
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Fri Oct 08 23:53:41 2010 +0200 (2010-10-08)
changeset 2144 80f088eb0608
parent 2143 c7126e94e286
child 2145 efea409ff8be
permissions -rw-r--r--
cc/gcc: shuffle config knobs

It makes sense to have all library-related config knobs in
the same place; and it makes sense to have all other misc
config knobs in the same other place.

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
yann@2144
     1
# Misc library-related options
yann@2144
     2
yann@2041
     3
config CC_GCC_ENABLE_TARGET_OPTSPACE
yann@2041
     4
    bool
yann@2041
     5
    prompt "Optimize gcc libs for size"
yann@2041
     6
    default y
yann@2041
     7
    help
yann@2041
     8
      Pass --enable-target-optspace to crossgcc's configure.
yann@2041
     9
      
yann@2041
    10
      This will compile crossgcc's libs with -Os.
yann@2041
    11
yann@2122
    12
config CC_GCC_USE_GRAPHITE
yann@2122
    13
    bool
yann@2122
    14
    prompt "Enable GRAPHITE loop optimisations"
yann@2122
    15
    default y
yann@2122
    16
    depends on CC_GCC_HAS_GRAPHITE
yann@2122
    17
    select CC_GCC_USE_PPL_CLOOG
yann@2122
    18
    help
yann@2122
    19
      Enable the GRAPHITE loop optimsations.
yann@2122
    20
      
yann@2122
    21
      This requires the PPL and CLooG companion libraries, and
yann@2122
    22
      those will be automatically build for you.
yann@2122
    23
      
yann@2122
    24
      On some systems (eg. Cygwin), PPL and/or CLooG may not
yann@2122
    25
      build properly (yet), so you'll have to say 'N' here.
yann@2122
    26
yann@2122
    27
config CC_GCC_USE_LTO
yann@2122
    28
    bool
yann@2122
    29
    prompt "Enable LTO"
yann@2122
    30
    default y
yann@2122
    31
    depends on CC_GCC_HAS_LTO
yann@2122
    32
    select CC_GCC_USE_LIBELF
yann@2122
    33
    help
yann@2122
    34
      Enable the Link Time Optimisations.
yann@2122
    35
      
yann@2122
    36
      This will require the libelf companion library, and it
yann@2122
    37
      wil be build automatically for you.
yann@2122
    38
js@2045
    39
config CC_STATIC_LIBSTDCXX
js@2045
    40
    bool
js@2045
    41
    prompt "Link libstdc++ statically into the gcc binary"
js@2045
    42
    default y
js@2045
    43
    depends on CC_GCC_4_4_or_later
js@2045
    44
    help
js@2045
    45
      Newer gcc versions use the PPL library which is C++ code.  Statically
js@2045
    46
      linking libstdc++ increases the likeliness that the gcc binary will
js@2045
    47
      run on machines other than the one which it was built on, without
js@2045
    48
      having to worry about distributing the matching version of libstdc++
js@2045
    49
      along with it.
js@2045
    50
yann@2144
    51
config CC_GCC_LIBMUDFLAP
yann@2144
    52
    bool
yann@2144
    53
    prompt "Compile libmudflap"
yann@2144
    54
    default n
yann@2144
    55
    help
yann@2144
    56
      libmudflap is a pointer-use checking tool, which can detect
yann@2144
    57
      various mis-usages of pointers in C and (to some extents) C++.
yann@2144
    58
      
yann@2144
    59
      You should say 'N' here, as libmduflap generates instrumented
yann@2144
    60
      code (thus it is a bit bigger and a bit slower) and requires
yann@2144
    61
      re-compilation and re-link, while it exists better run-time
yann@2144
    62
      alternatives (eg. DUMA, dmalloc...) that need neither re-
yann@2144
    63
      compilation nor re-link.
yann@2144
    64
yann@2144
    65
#-----------------------------------------------------------------------------
yann@2144
    66
yann@2041
    67
comment "Misc. obscure options."
yann@2041
    68
yann@2041
    69
config CC_CXA_ATEXIT
yann@2041
    70
    bool
yann@2041
    71
    prompt "Use __cxa_atexit"
yann@2041
    72
    default y
yann@2041
    73
    depends on ! BARE_METAL
yann@2041
    74
    help
yann@2041
    75
      If you get the missing symbol "__cxa_atexit" when building C++ programs,
yann@2041
    76
      you might want to try disabling this option.
yann@2041
    77
yann@2041
    78
config CC_GCC_DISABLE_PCH
yann@2041
    79
    bool
yann@2041
    80
    prompt "Do not build PCH"
yann@2041
    81
    default n
yann@2041
    82
    help
yann@2041
    83
      Say 'y' here to not use Pre-Compiled Headers in the resulting toolchain.
yann@2041
    84
      at the expense of speed when compiling C++ code.
yann@2041
    85
      
yann@2041
    86
      For some configurations (most notably canadian?), PCH are broken, and
yann@2041
    87
      need to be disabled. Please see:
yann@2041
    88
        http://gcc.gnu.org/bugzilla/show_bug.cgi?id=40974
yann@2041
    89
yann@2042
    90
config CC_GCC_SJLJ_EXCEPTIONS
yann@2042
    91
    tristate
yann@2041
    92
    prompt "Use sjlj for exceptions"
yann@2054
    93
    depends on ! BARE_METAL
yann@2042
    94
    default m
yann@2041
    95
    help
yann@2042
    96
      'sjlj' is short for setjmp/longjmp.
yann@2041
    97
      
yann@2042
    98
      On some architectures, stack unwinding during exception handling
yann@2042
    99
      works perfectly well without using sjlj, while on some others,
yann@2042
   100
      use of sjlj is required for proper stack unwinding.
yann@2041
   101
      
yann@2042
   102
       Option  | sjlj use           | Associated ./configure switch
yann@2042
   103
      ---------+--------------------+--------------------------------
yann@2042
   104
         Y     | forcibly used      | --enable-sjlj-exceptions
yann@2042
   105
         M     | auto               | (none, ./configure decides)
yann@2042
   106
         N     | forcibly not used  | --disable-sjlj-exceptions
yann@2041
   107
      
yann@2042
   108
      It should be safe to say 'M' or 'N'.
yann@2042
   109
      
yann@2042
   110
      It can happen that ./configure is wrong in some cases. Known
yann@2042
   111
      case is for ARM big endian, where you should say 'N'.
yann@2043
   112
yann@2143
   113
config CC_GCC_LDBL_128
yann@2143
   114
    tristate
yann@2143
   115
    prompt "Enable 128-bit long doubles"
yann@2143
   116
    default m
yann@2143
   117
    depends on CC_GCC_4_2_or_later
yann@2143
   118
    help
yann@2143
   119
      Saying 'Y' will force gcc to use 128-bit wide long doubles
yann@2143
   120
      Saying 'N' will force gcc to use 64-bit wide long doubles
yann@2143
   121
      Saying 'M' will let gcc choose (default is 128-bit for
yann@2143
   122
                 glibc >= 2.4, 64-bit otherwise)
yann@2143
   123
      
yann@2143
   124
      If in doubt, keep the default, ie. 'M'.