Config.in 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451
  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. comment "Package build options"
  186. config DEBUG
  187. bool
  188. prompt "Compile packages with debugging info"
  189. default n
  190. help
  191. Adds -g3 to the CFLAGS
  192. config IPV6
  193. bool
  194. prompt "Enable IPv6 support in packages"
  195. default y
  196. help
  197. Enable IPV6 support in packages (passes --enable-ipv6 to configure scripts).
  198. config PKG_BUILD_PARALLEL
  199. bool
  200. prompt "Compile certain packages parallelized"
  201. default n
  202. help
  203. This adds a -jX option to certain packages that are known to
  204. behave well for parallel build.
  205. Note that this may overcommit CPU resources depending on the
  206. -j level of the main make process, the number of package
  207. submake jobs selected below and the number of actual CPUs present.
  208. Example: If the main make is passed a -j4 and the submake -j
  209. is also set to 4, we may end up with 16 parallel make processes
  210. in the worst case.
  211. You get maximum build performance, if you set the package build
  212. jobs to the number of CPUs (cores) available and also start the main
  213. make process with -jX, where X is the number of CPUs (cores).
  214. However, make sure you have enough RAM available for
  215. NR_CPUS to the power of two (NR_CPUS^2) make jobs.
  216. If you are unsure, select N.
  217. config PKG_BUILD_JOBS
  218. int
  219. prompt "Number of package submake jobs (2-512)"
  220. range 2 512
  221. default 2
  222. depends on PKG_BUILD_PARALLEL
  223. help
  224. The number of jobs (-jX) to pass to packages submake.
  225. config PKG_DEFAULT_PARALLEL
  226. bool
  227. prompt "Parallelize the default package build rule (May break build)"
  228. depends on PKG_BUILD_PARALLEL
  229. default n
  230. help
  231. Always set the default package build rules to parallel build.
  232. WARNING: This may break build or kill your cat, as it builds
  233. packages with multiple jobs that are probably not tested in
  234. a parallel build environment.
  235. Only say Y, if you don't mind fixing broken packages.
  236. Before reporting build bugs, set this to N and re-run the build.
  237. config TOOLCHAIN_PARALLEL
  238. bool
  239. prompt "Parallelize the toolchain build (May break build)"
  240. depends on PKG_BUILD_PARALLEL
  241. default n
  242. help
  243. Build the toolchain with parallel make jobs.
  244. This speeds up the toolchain build on SMP machines, but may
  245. break the build for certain toolchain versions.
  246. If you say Y, toolchain build might break.
  247. Before reporting build bugs, set this to N and re-run the build.
  248. comment "Stripping options"
  249. choice
  250. prompt "Binary stripping method"
  251. default USE_STRIP if EXTERNAL_TOOLCHAIN
  252. default USE_STRIP if USE_GLIBC || USE_EGLIBC
  253. default USE_SSTRIP
  254. help
  255. Select the binary stripping method you wish to use.
  256. config NO_STRIP
  257. bool "none"
  258. help
  259. This will install unstripped binaries (useful for native compiling/debugging)
  260. config USE_STRIP
  261. bool "strip"
  262. help
  263. This will install binaries stripped using strip from binutils
  264. config USE_SSTRIP
  265. bool "sstrip"
  266. depends !DEBUG
  267. depends !USE_GLIBC
  268. depends !USE_EGLIBC
  269. help
  270. This will install binaries stripped using sstrip
  271. endchoice
  272. config STRIP_ARGS
  273. string
  274. prompt "Strip arguments"
  275. depends USE_STRIP
  276. default "--strip-unneeded --remove-section=.comment --remove-section=.note" if DEBUG
  277. default "--strip-all"
  278. help
  279. Specifies arguments passed to the strip command when stripping binaries
  280. config STRIP_KERNEL_EXPORTS
  281. bool "Strip unnecessary exports from the kernel image"
  282. help
  283. Reduces kernel size by stripping unused kernel exports from the kernel image
  284. Note that this might make the kernel incompatible with any kernel modules that
  285. were not selected at the time the kernel image was created
  286. config USE_MKLIBS
  287. bool "Strip unnecessary functions from libraries"
  288. help
  289. Reduces libraries to only those functions that are necessary for using all
  290. selected packages (including those selected as <M>)
  291. Note that this will make the system libraries incompatible with most of the packages
  292. that are not selected during the build process
  293. endmenu
  294. menuconfig DEVEL
  295. bool "Advanced configuration options (for developers)"
  296. default n
  297. config BROKEN
  298. bool "Show broken platforms / packages" if DEVEL
  299. default n
  300. config DOWNLOAD_FOLDER
  301. string "Download folder" if DEVEL
  302. default ""
  303. config LOCALMIRROR
  304. string "Local mirror for source packages" if DEVEL
  305. default ""
  306. config AUTOREBUILD
  307. bool "Automatic rebuild of packages" if DEVEL
  308. default y
  309. help
  310. Automatically rebuild packages when their files change
  311. config BUILD_SUFFIX
  312. string "Build suffix to append to the BUILD_DIR variable" if DEVEL
  313. default ""
  314. help
  315. Build suffix to append to the BUILD_DIR variable, i.e: build_dir_suffix
  316. config TARGET_ROOTFS_DIR
  317. string "Override the default TARGET_ROOTFS_DIR variable" if DEVEL
  318. default ""
  319. help
  320. Override the default TARGET_ROOTFS_DIR variable content $(BUILD_DIR) with custom path.
  321. Use this option to re-define the location of the target root file system directory.
  322. config CCACHE
  323. bool "Use ccache" if DEVEL
  324. default n
  325. help
  326. Compiler cache; see http://ccache.samba.org/
  327. config EXTERNAL_KERNEL_TREE
  328. string "Use external kernel tree" if DEVEL
  329. default ""
  330. config KERNEL_GIT_CLONE_URI
  331. string "Enter git repository to clone" if DEVEL
  332. default ""
  333. help
  334. Enter the full git repository path i.e.:
  335. git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
  336. This will create a git clone of the kernel in your build
  337. directory.
  338. config KERNEL_GIT_LOCAL_REPOSITORY
  339. string "Enter path to local reference repository" if DEVEL
  340. default ""
  341. help
  342. Enter a full pathname to a local reference git repository.
  343. In this instance, the --refererence option of git clone will
  344. be used thus creating a quick local clone of your repo.
  345. menuconfig TARGET_OPTIONS
  346. bool "Target Options" if DEVEL
  347. config TARGET_OPTIMIZATION
  348. string "Target Optimizations" if TARGET_OPTIONS
  349. default DEFAULT_TARGET_OPTIMIZATION
  350. help
  351. Optimizations to use when building for the target host.
  352. config SOFT_FLOAT
  353. bool "Use software floating point by default" if TARGET_OPTIONS
  354. default y
  355. depends on (arm || armeb || powerpc || mipsel || mips) && !HAS_FPU
  356. help
  357. If your target CPU does not have a Floating Point Unit (FPU) or a
  358. kernel FPU emulator, but you still wish to support floating point
  359. functions, then everything will need to be compiled with soft floating
  360. point support (-msoft-float).
  361. Most people will answer N.
  362. source "toolchain/Config.in"
  363. source "target/imagebuilder/Config.in"
  364. source "target/sdk/Config.in"
  365. source "target/toolchain/Config.in"
  366. source "tmp/.config-package.in"