]> Git Repo - buildroot-mgba.git/blobdiff - Config.in
boot/uboot: bump to version 2015.01
[buildroot-mgba.git] / Config.in
index e07e52f174806a3fb87fe1dc8fd307c434a80685..f5b6c7346b6acbf7fbc20f67d685a17c5a04a9df 100644 (file)
--- a/Config.in
+++ b/Config.in
@@ -10,7 +10,42 @@ config BR2_VERSION
        string
        option env="BR2_VERSION_FULL"
 
-source "target/Config.in.arch"
+config BR2_HOSTARCH
+       string
+       option env="HOSTARCH"
+
+config BR2_EXTERNAL
+       string
+       option env="BR2_EXTERNAL"
+
+# Hidden boolean selected by packages in need of Java in order to build
+# (example: xbmc)
+config BR2_NEEDS_HOST_JAVA
+       bool
+
+# Hidden boolean selected by packages in need of javac in order to build
+# (example: classpath)
+config BR2_NEEDS_HOST_JAVAC
+       bool
+
+# Hidden boolean selected by packages in need of jar in order to build
+# (example: classpath)
+config BR2_NEEDS_HOST_JAR
+       bool
+
+# Hidden boolean selected by pre-built packages for x86, when they
+# need to run on x86-64 machines (example: pre-built external
+# toolchains, binary tools like SAM-BA, etc.).
+config BR2_HOSTARCH_NEEDS_IA32_LIBS
+       bool
+
+# Hidden boolean selected by packages that need to build 32 bits
+# binaries with the host compiler, even on 64 bits build machines (e.g
+# bootloaders).
+config BR2_HOSTARCH_NEEDS_IA32_COMPILER
+       bool
+
+source "arch/Config.in"
 
 menu "Build options"
 
@@ -32,6 +67,10 @@ config BR2_GIT
        string "Git command"
        default "git"
 
+config BR2_CVS
+       string "CVS command"
+       default "cvs"
+
 config BR2_LOCALFILES
        string "Local files retrieval command"
        default "cp"
@@ -85,12 +124,24 @@ config BR2_TAR_OPTIONS
 
 endmenu
 
+config BR2_DEFCONFIG_FROM_ENV
+       string
+       option env="BR2_DEFCONFIG"
+
+config BR2_DEFCONFIG
+       string "Location to save buildroot config"
+       default BR2_DEFCONFIG_FROM_ENV if BR2_DEFCONFIG_FROM_ENV != ""
+       default "$(CONFIG_DIR)/defconfig"
+       help
+         When running 'make savedefconfig', the defconfig file will be saved
+         in this location.
+
 config BR2_DL_DIR
        string "Download dir"
        default "$(TOPDIR)/dl"
        help
          Directory to store all the source files that we need to fetch.
-         If the Linux shell environment has defined the BUILDROOT_DL_DIR
+         If the Linux shell environment has defined the BR2_DL_DIR
          environment variable, then this overrides this configuration item.
 
          The default is $(TOPDIR)/dl
@@ -119,29 +170,33 @@ config BR2_PRIMARY_SITE
          NOTE: This works for all packages using the central package
          infrastructure (generic, autotools, cmake, ...)
 
+config BR2_PRIMARY_SITE_ONLY
+       bool "Only allow downloads from primary download site"
+       depends on BR2_PRIMARY_SITE != ""
+       help
+         If this option is enabled, downloads will only be attempted
+         from the primary download site. Other locations, like the
+         package's official download location or the backup download
+         site, will not be considered. Therefore, if the package is
+         not present on the primary site, the download fails.
+
+         This is useful for project developers who want to ensure
+         that the project can be built even if the upstream tarball
+         locations disappear.
+
+if !BR2_PRIMARY_SITE_ONLY
+
 config BR2_BACKUP_SITE
        string "Backup download site"
-       default "http://sources.buildroot.net/"
+       default "http://sources.buildroot.net"
        help
          Backup site to download from. If this option is set then buildroot
          will fall back to download package sources from here if the
          normal location fails.
 
-config BR2_SOURCEFORGE_MIRROR
-       string "Sourceforge mirror site"
-       default "kent"
-       help
-         Sourceforge has a system of mirror sites.  Some sites may be
-         closer to your location, and sometimes mirror sites go down
-         and are no longer available.  This option allows you to select
-         your preferred Sourceforge mirror site.
-
-         The list of mirrors is available here:
-         http://sourceforge.net/apps/trac/sourceforge/wiki/Mirrors
-
 config BR2_KERNEL_MIRROR
        string "Kernel.org mirror"
-       default "http://www.kernel.org/pub/"
+       default "https://www.kernel.org/pub"
        help
          kernel.org is mirrored on a number of servers around the world.
          The following allows you to select your preferred mirror.
@@ -165,30 +220,43 @@ config BR2_GNU_MIRROR
             http://ftp.gnu.org/pub/gnu
             http://mirror.aarnet.edu.au/pub/gnu
 
-config BR2_DEBIAN_MIRROR
-       string "Debian Software mirror"
-       default "http://ftp.debian.org"
+endif
+
+config BR2_LUAROCKS_MIRROR
+       string "LuaRocks mirror"
+       default "http://rocks.moonscript.org"
        help
-         Debian has multiple software mirrors scattered around the world.
-         The following allows you to select your preferred mirror.
+         LuaRocks repository.
 
-         Usually, just add your country code like XX here:
-         http://ftp.XX.debian.org
+         See http://luarocks.org
+
+config BR2_CPAN_MIRROR
+       string "CPAN mirror (Perl packages)"
+       default "http://cpan.metacpan.org"
+       help
+         CPAN (Comprehensive Perl Archive Network) is a repository
+         of Perl packages. It has multiple software mirrors scattered
+         around the world. This option allows you to select a mirror.
+
+         The list of mirrors is available at:
+         http://search.cpan.org/mirror
 
 endmenu
 
 config BR2_JLEVEL
-       int "Number of jobs to run simultaneously"
-       default "2"
+       int "Number of jobs to run simultaneously (0 for auto)"
+       default "0"
        help
-         Number of jobs to run simultaneously
+         Number of jobs to run simultaneously.  If 0, determine
+         automatically according to number of CPUs on the host
+         system.
 
 config BR2_CCACHE
        bool "Enable compiler cache"
        help
          This option will enable the use of ccache, a compiler
          cache. It will cache the result of previous builds to speed
-         up future builds. The cache is stored in
+         up future builds. By default, the cache is stored in
          $HOME/.buildroot-ccache.
 
          Note that Buildroot does not try to invalidate the cache
@@ -198,16 +266,65 @@ config BR2_CCACHE
          ccache cache by removing the $HOME/.buildroot-ccache
          directory.
 
+if BR2_CCACHE
+
+config BR2_CCACHE_DIR
+       string "Compiler cache location"
+       default "$(HOME)/.buildroot-ccache"
+       help
+         Where ccache should store cached files.
+
+config BR2_CCACHE_INITIAL_SETUP
+       string "Compiler cache initial setup"
+       help
+         Initial ccache settings to apply, such as --max-files or --max-size.
+
+         For example, if your project is known to require more space than the
+         default max cache size, then you might want to increase the cache size
+         to a suitable amount using the -M (--max-size) option.
+
+         The string you specify here is passed verbatim to ccache.  Refer to
+         ccache documentation for more details.
+
+         These initial settings are applied after ccache has been compiled.
+
+endif
+
 config BR2_DEPRECATED
-       bool "Show packages that are deprecated or obsolete"
+       bool "Show options and packages that are deprecated or obsolete"
        help
-         This option hides outdated/obsolete versions of packages.
+         This option shows outdated/obsolete versions of packages and
+         options that are otherwise hidden.
+
+if BR2_DEPRECATED
+
+config BR2_DEPRECATED_SINCE_2014_02
+       bool
+       default y
+
+config BR2_DEPRECATED_SINCE_2014_05
+       bool
+       default y
+
+config BR2_DEPRECATED_SINCE_2014_08
+       bool
+       default y
+
+config BR2_DEPRECATED_SINCE_2015_02
+       bool
+       default y
+
+endif
 
 config BR2_ENABLE_DEBUG
        bool "build packages with debugging symbols"
        help
-         Build packages with debugging symbols
-         enabled
+         Build packages with debugging symbols enabled. All libraries
+         and binaries in the 'staging' directory will have debugging
+         symbols, which allows remote debugging even if libraries and
+         binaries are stripped on the target. Whether libraries and
+         binaries are stripped on the target is controlled by the
+         BR2_STRIP_* options below.
 
 if BR2_ENABLE_DEBUG
 choice
@@ -240,34 +357,58 @@ endchoice
 endif
 
 choice
-       prompt "strip"
+       prompt "strip command for binaries on target"
        default BR2_STRIP_strip
-       help
-         Select whether to strip binaries and libraries for the target
-         or not.
-         strip   is the normal strip command
-         sstrip  is a strip that discards more than the normal strip
-         none    do not strip (only for debugging!)
 
 config BR2_STRIP_strip
        bool "strip"
-       depends on !BR2_ELF2FLT
+       depends on !BR2_PACKAGE_HOST_ELF2FLT
        help
-         strip   is the normal strip command
+         Binaries and libraries in the target filesystem will be
+         stripped using the normal 'strip' command. This allows to
+         save space, mainly by removing debugging symbols. Debugging
+         symbols on the target are needed for native debugging, but
+         not when remote debugging is used.
 
 config BR2_STRIP_sstrip
        bool "sstrip"
        select BR2_PACKAGE_SSTRIP_HOST
-       depends on !BR2_ELF2FLT
+       depends on !BR2_PACKAGE_HOST_ELF2FLT
+       depends on BR2_DEPRECATED_SINCE_2014_05
        help
-         sstrip  is a strip that discards more than the normal strip
+         Binaries and libraries in the target filesystem will be
+         stripped using the 'sstrip' command, which strips a little
+         bit more than the traditional 'strip' command. This allows to
+         save space, mainly by removing debugging symbols. Debugging
+         symbols on the target are needed for native debugging, but
+         not when remote debugging is used.
 
 config BR2_STRIP_none
        bool "none"
        help
-         none    do not strip (only for debugging!)
+         Do not strip binaries and libraries in the target
+         filesystem.
 endchoice
 
+config BR2_STRIP_EXCLUDE_FILES
+       string "executables that should not be stripped"
+       depends on !BR2_STRIP_none
+       default ""
+       help
+         You may specify a space-separated list of binaries and libraries
+         here that should not be stripped on the target.
+
+config BR2_STRIP_EXCLUDE_DIRS
+       string "directories that should be skipped when stripping"
+       depends on !BR2_STRIP_none
+       default ""
+       help
+         You may specify a space-separated list of directories that should
+         be skipped when stripping. Binaries and libraries in these
+         directories will not be touched.
+         The directories should be specified relative to the target directory,
+         without leading slash.
+
 choice
        prompt "gcc optimization level"
        default BR2_OPTIMIZE_S
@@ -334,34 +475,100 @@ config BR2_OPTIMIZE_S
 
 endchoice
 
-config BR2_PREFER_STATIC_LIB
-       bool "prefer static libraries"
+config BR2_GOOGLE_BREAKPAD_ENABLE
+       bool "Enable google-breakpad support"
+       select BR2_PACKAGE_GOOGLE_BREAKPAD
+       depends on BR2_INSTALL_LIBSTDCPP
+       depends on BR2_TOOLCHAIN_USES_GLIBC
+       depends on BR2_PACKAGE_GOOGLE_BREAKPAD_ARCH_SUPPORTS
+       help
+         This option will enable the use of google breakpad, a
+         library and tool suite that allows you to distribute an
+         application to users with compiler-provided debugging
+         information removed, record crashes in compact "minidump"
+         files, send them back to your server and produce C and C++
+         stack traces from these minidumps.  Breakpad can also write
+         minidumps on request for programs that have not crashed.
+
+if BR2_GOOGLE_BREAKPAD_ENABLE
+
+config BR2_GOOGLE_BREAKPAD_INCLUDE_FILES
+       string "List of executables and libraries to extract symbols from"
+       default ""
+       help
+         You may specify a space-separated list of binaries and
+         libraries with full paths relative to $(TARGET_DIR) of which
+         debug symbols will be dumped for further use with google
+         breakpad.
+
+         A directory structure that can be used by minidump-stackwalk
+         will be created at:
+
+         $(STAGING_DIR)/usr/share/google-breakpad-symbols
+
+endif
+
+config BR2_ENABLE_SSP
+       bool "build code with Stack Smashing Protection"
+       depends on BR2_TOOLCHAIN_HAS_SSP
        help
-         Where possible, build and use static libraries for the target.
-         This potentially increases your code size and should only be
-         used if you know what you do.
+         Enable stack smashing protection support using GCCs
+         -fstack-protector-all option.
+
+         See http://www.linuxfromscratch.org/hints/downloads/files/ssp.txt
+         for details.
+
+         Note that this requires the toolchain to have SSP
+         support. This is always the case for glibc and eglibc
+         toolchain, but is optional in uClibc toolchains.
+
+comment "enabling Stack Smashing Protection requires support in the toolchain"
+       depends on !BR2_TOOLCHAIN_HAS_SSP
+
+choice
+       bool "libraries"
+       default BR2_SHARED_LIBS if BR2_BINFMT_SUPPORTS_SHARED
+       default BR2_STATIC_LIBS if !BR2_BINFMT_SUPPORTS_SHARED
+       help
+         Select the type of libraries you want to use on the target.
+
          The default is to build dynamic libraries and use those on
-         the target filesystem.
+         the target filesystem, except when the architecture and/or
+         the selected binary format does not support shared
+         libraries.
 
-         WARNING: This is highly experimental at the moment.
+config BR2_STATIC_LIBS
+       bool "static only"
+       help
+         Build and use only static libraries. No shared libraries
+         will be instaled on the target. This potentially increases
+         your code size and should only be used if you know what you
+         are doing. Note that some packages may not be available when
+         this option is enabled, due to their need for dynamic
+         library support.
 
-config BR2_HAVE_DOCUMENTATION
-       bool "documentation on the target"
+config BR2_SHARED_LIBS
+       bool "shared only"
+       depends on BR2_BINFMT_SUPPORTS_SHARED
        help
-         Install the documentation, including manual pages and info
-         pages, on the target.
-         If you say n here, your target will not contain any
-         documentation.
+         Build and use only shared libraries. This is the recommended
+         solution as it saves space and build time.
 
-config BR2_HAVE_DEVFILES
-       bool "development files in target filesystem"
+config BR2_SHARED_STATIC_LIBS
+       bool "both static and shared"
+       depends on BR2_BINFMT_SUPPORTS_SHARED
        help
-         Install headers and static libraries in the
-         target filesystem
+         Build both shared and static libraries, but link executables
+         dynamically. While building both shared and static libraries
+         take more time and more disk space, having static libraries
+         may be useful to link some of the applications statically.
+
+endchoice
+
 
 config BR2_PACKAGE_OVERRIDE_FILE
        string "location of a package override file"
-       default "$(TOPDIR)/local.mk"
+       default "$(CONFIG_DIR)/local.mk"
        help
          A package override file is a short makefile that contains
          variable definitions of the form <pkg>_OVERRIDE_SRCDIR,
@@ -369,18 +576,66 @@ config BR2_PACKAGE_OVERRIDE_FILE
          as the source directory for a particular package. See the
          Buildroot documentation for more details on this feature.
 
+config BR2_GLOBAL_PATCH_DIR
+       string "global patch directories"
+       help
+         You may specify a space separated list of one or more directories
+         containing global package patches. For a specific version
+         <packageversion> of a specific package <packagename>, patches are
+         applied as follows:
+
+         First, the default Buildroot patch set for the package is applied
+         from the package's directory in Buildroot.
+
+         Then for every directory - <global-patch-dir> - that exists in
+         BR2_GLOBAL_PATCH_DIR, if the directory
+         <global-patch-dir>/<packagename>/<packageversion>/ exists, then all
+         *.patch files in this directory will be applied.
+
+         Otherwise, if the directory <global-patch-dir>/<packagename> exists,
+         then all *.patch files in the directory will be applied.
+
+menu "Advanced"
+
+config BR2_COMPILER_PARANOID_UNSAFE_PATH
+       bool "paranoid check of library/header paths"
+       help
+         By default, when this option is disabled, when the Buildroot
+         cross-compiler will encounter an unsafe library or header
+         path (such as /usr/include, or /usr/lib), the compiler will
+         display a warning.
+
+         By enabling this option, this warning is turned into an
+         error, which will completely abort the build when such
+         unsafe paths are encountered.
+
+         Note that this mechanism is available for both the internal
+         toolchain (through gcc and binutils patches) and external
+         toolchain backends (through the external toolchain wrapper).
+
+endmenu
+
 endmenu
 
 source "toolchain/Config.in"
 
-source "target/generic/Config.in"
+source "system/Config.in"
 
-source "package/Config.in"
+source "linux/Config.in"
 
-source "package/Config.in.host"
+source "package/Config.in"
 
 source "fs/Config.in"
 
 source "boot/Config.in"
 
-source "linux/Config.in"
+source "package/Config.in.host"
+
+source "Config.in.legacy"
+
+menu "User-provided options"
+       depends on BR2_EXTERNAL != "support/dummy-external"
+
+source "$BR2_EXTERNAL/Config.in"
+
+endmenu
This page took 0.038752 seconds and 4 git commands to generate.