Config.in 13 KB

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