Config.in 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526
  1. # Copyright (C) 2006-2010 OpenWrt.org
  2. #
  3. # This is free software, licensed under the GNU General Public License v2.
  4. # See /LICENSE for more information.
  5. #
  6. mainmenu "OpenWrt Configuration"
  7. config HAVE_DOT_CONFIG
  8. bool
  9. default y
  10. source "target/Config.in"
  11. menu "Target Images"
  12. menuconfig TARGET_ROOTFS_INITRAMFS
  13. bool "ramdisk"
  14. default y if USES_INITRAMFS
  15. help
  16. Embed the rootfs into the kernel (initramfs)
  17. choice
  18. prompt "Compression"
  19. default TARGET_INITRAMFS_COMPRESSION_LZMA if TARGET_ar71xx
  20. default TARGET_INITRAMFS_COMPRESSION_LZMA if TARGET_ramips
  21. default TARGET_INITRAMFS_COMPRESSION_NONE
  22. depends TARGET_ROOTFS_INITRAMFS
  23. help
  24. Select ramdisk compression.
  25. config TARGET_INITRAMFS_COMPRESSION_NONE
  26. bool "none"
  27. config TARGET_INITRAMFS_COMPRESSION_GZIP
  28. bool "gzip"
  29. config TARGET_INITRAMFS_COMPRESSION_BZIP2
  30. bool "bzip2"
  31. config TARGET_INITRAMFS_COMPRESSION_LZMA
  32. bool "lzma"
  33. config TARGET_INITRAMFS_COMPRESSION_LZO
  34. bool "lzo"
  35. config TARGET_INITRAMFS_COMPRESSION_XZ
  36. bool "xz"
  37. endchoice
  38. config EXTERNAL_CPIO
  39. string
  40. prompt "Use external cpio" if TARGET_ROOTFS_INITRAMFS
  41. default ""
  42. help
  43. Kernel uses specified external cpio as INITRAMFS_SOURCE
  44. comment "Root filesystem archives"
  45. config TARGET_ROOTFS_CPIOGZ
  46. bool "cpio.gz"
  47. default y if USES_CPIOGZ
  48. help
  49. Build a compressed cpio archive of the the root filesystem
  50. config TARGET_ROOTFS_TARGZ
  51. bool "tar.gz"
  52. default y if USES_TARGZ
  53. help
  54. Build a compressed tar archive of the the root filesystem
  55. comment "Root filesystem images"
  56. config TARGET_ROOTFS_EXT4FS
  57. bool "ext4"
  58. default y if USES_EXT4
  59. depends !TARGET_ROOTFS_INITRAMFS
  60. help
  61. Ext4 file system with some free space for uml images
  62. config TARGET_ROOTFS_ISO
  63. bool "iso"
  64. default n
  65. depends TARGET_ROOTFS_INITRAMFS && TARGET_x86
  66. help
  67. Create some bootable ISO image
  68. config TARGET_ROOTFS_JFFS2
  69. bool "jffs2"
  70. default y if USES_JFFS2
  71. depends !TARGET_ROOTFS_INITRAMFS
  72. help
  73. Build a jffs2 root filesystem
  74. config TARGET_ROOTFS_SQUASHFS
  75. bool "squashfs"
  76. default y if USES_SQUASHFS
  77. depends !TARGET_ROOTFS_INITRAMFS
  78. help
  79. Build a squashfs-lzma root filesystem
  80. config TARGET_ROOTFS_UBIFS
  81. bool "ubifs"
  82. default y if USES_UBIFS
  83. depends !TARGET_ROOTFS_INITRAMFS && USES_UBIFS
  84. help
  85. Build a ubifs root filesystem
  86. comment "Image Options"
  87. source "target/linux/*/image/Config.in"
  88. config TARGET_ROOTFS_PARTSIZE
  89. int "Root filesystem partition size (in MB)"
  90. depends X86_GRUB_IMAGES || TARGET_ROOTFS_EXT4FS || TARGET_rb532
  91. default 48
  92. help
  93. Allows you to change the root filesystem partition size
  94. config TARGET_ROOTFS_MAXINODE
  95. int "Maximum number of inodes in root filesystem"
  96. depends TARGET_ROOTFS_EXT4FS
  97. default 6000
  98. help
  99. Allows you to change the maximum number of inodes in the root filesystem
  100. endmenu
  101. menu "Global build settings"
  102. config ALL
  103. bool "Select all packages by default"
  104. default n
  105. comment "General build options"
  106. config DISPLAY_SUPPORT
  107. bool "Show packages that require graphics support (local or remote)"
  108. default n
  109. config BUILD_PATENTED
  110. default y
  111. bool "Compile with support for patented functionality"
  112. help
  113. When this option is disabled, software which provides patented functionality will not be built.
  114. In case software provides optional support for patented functionality,
  115. this optional support will get disabled for this package.
  116. config BUILD_NLS
  117. default n
  118. bool "Compile with full language support"
  119. help
  120. When this option is enabled, packages are built with the full versions of iconv and GNU gettext
  121. instead of the default OpenWrt stubs. If uClibc is used, it is also built with locale support.
  122. config BUILD_STATIC_TOOLS
  123. default n
  124. bool "Attempt to link host utilities statically"
  125. help
  126. Linking host utilities like sed or firmware-utils statically increases the portability of the
  127. generated ImageBuilder and SDK tarballs, however it may fail on some Linux distributions.
  128. config SHADOW_PASSWORDS
  129. bool
  130. prompt "Enable shadow password support"
  131. default y
  132. help
  133. Enable shadow password support.
  134. config CLEAN_IPKG
  135. bool
  136. prompt "Remove ipkg/opkg status data files in final images"
  137. default n
  138. help
  139. This removes all ipkg/opkg status data files from the target directory before building the root fs
  140. config COLLECT_KERNEL_DEBUG
  141. bool
  142. prompt "Collect kernel debug information"
  143. select KERNEL_DEBUG_INFO
  144. default n
  145. help
  146. This collects debugging symbols from the kernel and all compiled modules.
  147. Useful for release builds, so that kernel issues can be debugged offline later.
  148. comment "Kernel build options"
  149. config KERNEL_DEBUG_FS
  150. bool "Compile the kernel with Debug FileSystem enabled"
  151. default y
  152. help
  153. debugfs is a virtual file system that kernel developers use to put
  154. debugging files into. Enable this option to be able to read and
  155. write to these files.
  156. config KERNEL_PROFILING
  157. bool "Compile the kernel with profiling enabled"
  158. default n
  159. help
  160. Enable the extended profiling support mechanisms used by profilers such
  161. as OProfile.
  162. config KERNEL_KALLSYMS
  163. bool "Compile the kernel with symbol table information"
  164. default n
  165. help
  166. This will give you more information in stack traces from kernel oopses
  167. config KERNEL_FTRACE
  168. bool "Compile the kernel with tracing support"
  169. default n
  170. config KERNEL_ENABLE_DEFAULT_TRACERS
  171. bool "Trace process context switches and events"
  172. depends on KERNEL_FTRACE
  173. default n
  174. config KERNEL_DEBUG_KERNEL
  175. bool
  176. default n
  177. config KERNEL_DEBUG_INFO
  178. bool "Compile the kernel with debug information"
  179. default n
  180. select KERNEL_DEBUG_KERNEL
  181. help
  182. This will compile your kernel and modules with debug information.
  183. config KERNEL_DEBUG_LL_UART_NONE
  184. bool
  185. default n
  186. depends on arm
  187. config KERNEL_DEBUG_LL
  188. bool
  189. default n
  190. depends on arm
  191. select KERNEL_DEBUG_LL_UART_NONE
  192. help
  193. ARM low level debugging
  194. config KERNEL_EARLY_PRINTK
  195. bool "Compile the kernel with early printk"
  196. default n
  197. depends on arm
  198. select KERNEL_DEBUG_KERNEL
  199. select KERNEL_DEBUG_LL if arm
  200. help
  201. Compile the kernel with early printk support.
  202. This is only useful for debugging purposes to send messages
  203. over the serial console in early boot.
  204. Enable this to debug early boot problems.
  205. config KERNEL_AIO
  206. bool "Compile the kernel with asynchronous IO support"
  207. default n
  208. config KERNEL_MAGIC_SYSRQ
  209. bool "Compile the kernel with SysRq support"
  210. default y
  211. config KERNEL_ELF_CORE
  212. bool "Enable process core dump support"
  213. default y
  214. config KERNEL_PROVE_LOCKING
  215. bool "Enable kernel lock checking"
  216. select KERNEL_DEBUG_KERNEL
  217. default n
  218. config KERNEL_PRINTK_TIME
  219. bool "Enable printk timestamps"
  220. default y
  221. comment "Package build options"
  222. config DEBUG
  223. bool
  224. prompt "Compile packages with debugging info"
  225. default n
  226. help
  227. Adds -g3 to the CFLAGS
  228. config IPV6
  229. bool
  230. prompt "Enable IPv6 support in packages"
  231. default y
  232. help
  233. Enable IPV6 support in packages (passes --enable-ipv6 to configure scripts).
  234. config PKG_BUILD_PARALLEL
  235. bool
  236. prompt "Compile certain packages parallelized"
  237. default n
  238. help
  239. This adds a -jX option to certain packages that are known to
  240. behave well for parallel build.
  241. Note that this may overcommit CPU resources depending on the
  242. -j level of the main make process, the number of package
  243. submake jobs selected below and the number of actual CPUs present.
  244. Example: If the main make is passed a -j4 and the submake -j
  245. is also set to 4, we may end up with 16 parallel make processes
  246. in the worst case.
  247. You get maximum build performance, if you set the package build
  248. jobs to the number of CPUs (cores) available and also start the main
  249. make process with -jX, where X is the number of CPUs (cores).
  250. However, make sure you have enough RAM available for
  251. NR_CPUS to the power of two (NR_CPUS^2) make jobs.
  252. If you are unsure, select N.
  253. config PKG_BUILD_JOBS
  254. int
  255. prompt "Number of package submake jobs (2-512)"
  256. range 2 512
  257. default 2
  258. depends on PKG_BUILD_PARALLEL
  259. help
  260. The number of jobs (-jX) to pass to packages submake.
  261. config PKG_DEFAULT_PARALLEL
  262. bool
  263. prompt "Parallelize the default package build rule (May break build)"
  264. depends on PKG_BUILD_PARALLEL
  265. depends on BROKEN
  266. default n
  267. help
  268. Always set the default package build rules to parallel build.
  269. WARNING: This may break build or kill your cat, as it builds
  270. packages with multiple jobs that are probably not tested in
  271. a parallel build environment.
  272. Only say Y, if you don't mind fixing broken packages.
  273. Before reporting build bugs, set this to N and re-run the build.
  274. config TOOLCHAIN_PARALLEL
  275. bool
  276. prompt "Parallelize the toolchain build (May break build)"
  277. depends on PKG_BUILD_PARALLEL
  278. depends on BROKEN
  279. default n
  280. help
  281. Build the toolchain with parallel make jobs.
  282. This speeds up the toolchain build on SMP machines, but may
  283. break the build for certain toolchain versions.
  284. If you say Y, toolchain build might break.
  285. Before reporting build bugs, set this to N and re-run the build.
  286. comment "Stripping options"
  287. choice
  288. prompt "Binary stripping method"
  289. default USE_STRIP if EXTERNAL_TOOLCHAIN
  290. default USE_STRIP if USE_GLIBC || USE_EGLIBC
  291. default USE_SSTRIP
  292. help
  293. Select the binary stripping method you wish to use.
  294. config NO_STRIP
  295. bool "none"
  296. help
  297. This will install unstripped binaries (useful for native compiling/debugging)
  298. config USE_STRIP
  299. bool "strip"
  300. help
  301. This will install binaries stripped using strip from binutils
  302. config USE_SSTRIP
  303. bool "sstrip"
  304. depends !DEBUG
  305. depends !USE_GLIBC
  306. depends !USE_EGLIBC
  307. help
  308. This will install binaries stripped using sstrip
  309. endchoice
  310. config STRIP_ARGS
  311. string
  312. prompt "Strip arguments"
  313. depends USE_STRIP
  314. default "--strip-unneeded --remove-section=.comment --remove-section=.note" if DEBUG
  315. default "--strip-all"
  316. help
  317. Specifies arguments passed to the strip command when stripping binaries
  318. config STRIP_KERNEL_EXPORTS
  319. bool "Strip unnecessary exports from the kernel image"
  320. help
  321. Reduces kernel size by stripping unused kernel exports from the kernel image
  322. Note that this might make the kernel incompatible with any kernel modules that
  323. were not selected at the time the kernel image was created
  324. config USE_MKLIBS
  325. bool "Strip unnecessary functions from libraries"
  326. help
  327. Reduces libraries to only those functions that are necessary for using all
  328. selected packages (including those selected as <M>)
  329. Note that this will make the system libraries incompatible with most of the packages
  330. that are not selected during the build process
  331. choice
  332. prompt "Preferred standard C++ library"
  333. default USE_LIBSTDCXX if USE_EGLIBC
  334. default USE_UCLIBCXX
  335. help
  336. Select the preferred standard C++ library for all packages that support this.
  337. config USE_UCLIBCXX
  338. bool "uClibc++"
  339. config USE_LIBSTDCXX
  340. bool "libstdc++"
  341. endchoice
  342. endmenu
  343. menuconfig DEVEL
  344. bool "Advanced configuration options (for developers)"
  345. default n
  346. config BROKEN
  347. bool "Show broken platforms / packages" if DEVEL
  348. default n
  349. config DOWNLOAD_FOLDER
  350. string "Download folder" if DEVEL
  351. default ""
  352. config LOCALMIRROR
  353. string "Local mirror for source packages" if DEVEL
  354. default ""
  355. config AUTOREBUILD
  356. bool "Automatic rebuild of packages" if DEVEL
  357. default y
  358. help
  359. Automatically rebuild packages when their files change
  360. config BUILD_SUFFIX
  361. string "Build suffix to append to the BUILD_DIR variable" if DEVEL
  362. default ""
  363. help
  364. Build suffix to append to the BUILD_DIR variable, i.e: build_dir_suffix
  365. config TARGET_ROOTFS_DIR
  366. string "Override the default TARGET_ROOTFS_DIR variable" if DEVEL
  367. default ""
  368. help
  369. Override the default TARGET_ROOTFS_DIR variable content $(BUILD_DIR) with custom path.
  370. Use this option to re-define the location of the target root file system directory.
  371. config CCACHE
  372. bool "Use ccache" if DEVEL
  373. default n
  374. help
  375. Compiler cache; see http://ccache.samba.org/
  376. config EXTERNAL_KERNEL_TREE
  377. string "Use external kernel tree" if DEVEL
  378. default ""
  379. config KERNEL_GIT_CLONE_URI
  380. string "Enter git repository to clone" if DEVEL
  381. default ""
  382. help
  383. Enter the full git repository path i.e.:
  384. git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
  385. This will create a git clone of the kernel in your build
  386. directory.
  387. config KERNEL_GIT_LOCAL_REPOSITORY
  388. string "Enter path to local reference repository" if DEVEL
  389. default ""
  390. help
  391. Enter a full pathname to a local reference git repository.
  392. In this instance, the --refererence option of git clone will
  393. be used thus creating a quick local clone of your repo.
  394. config BUILD_LOG
  395. bool "Enable log files during build process" if DEVEL
  396. help
  397. If enabled log files will be written to the ./log directory
  398. config SRC_TREE_OVERRIDE
  399. bool "Enable package source tree override" if DEVEL
  400. help
  401. If enabled, you can force a package to use a git tree as source
  402. code instead of the normal tarball. Create a symlink 'git-src'
  403. in the package directory, pointing to the .git tree that you want
  404. to pull the source code from
  405. menuconfig TARGET_OPTIONS
  406. bool "Target Options" if DEVEL
  407. config TARGET_OPTIMIZATION
  408. string "Target Optimizations" if TARGET_OPTIONS
  409. default DEFAULT_TARGET_OPTIMIZATION
  410. help
  411. Optimizations to use when building for the target host.
  412. config SOFT_FLOAT
  413. bool "Use software floating point by default" if TARGET_OPTIONS
  414. default y
  415. depends on (arm || armeb || powerpc || mipsel || mips) && !HAS_FPU
  416. help
  417. If your target CPU does not have a Floating Point Unit (FPU) or a
  418. kernel FPU emulator, but you still wish to support floating point
  419. functions, then everything will need to be compiled with soft floating
  420. point support (-msoft-float).
  421. Most people will answer N.
  422. source "toolchain/Config.in"
  423. source "target/imagebuilder/Config.in"
  424. source "target/sdk/Config.in"
  425. source "target/toolchain/Config.in"
  426. source "tmp/.config-package.in"