Config.in 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432
  1. menu "Kernel"
  2. config BR2_LINUX_KERNEL
  3. bool "Linux Kernel"
  4. help
  5. Enable this option if you want to build a Linux kernel for
  6. your embedded device
  7. if BR2_LINUX_KERNEL
  8. comment "Linux kernel in thumb mode may be broken with binutils >= 2.29"
  9. depends on BR2_arm || BR2_armeb
  10. depends on !BR2_BINUTILS_VERSION_2_28_X
  11. # Packages that need to have a kernel with support for loadable modules,
  12. # but do not use the kernel-modules infrastructure, should select that
  13. # option.
  14. config BR2_LINUX_NEEDS_MODULES
  15. bool
  16. #
  17. # Version selection. We provide the choice between:
  18. #
  19. # 1. A single fairly recent stable kernel version
  20. # 2. A custom stable version
  21. # 3. A custom tarball
  22. # 4. A set of custom repository locations
  23. #
  24. choice
  25. prompt "Kernel version"
  26. config BR2_LINUX_KERNEL_LATEST_VERSION
  27. bool "Latest version (4.15)"
  28. config BR2_LINUX_KERNEL_LATEST_CIP_VERSION
  29. bool "Latest CIP SLTS version (v4.4.171-cip30)"
  30. help
  31. CIP launched in the spring of 2016 to address the needs of
  32. organizations in industries such as power generation and
  33. distribution, water, oil and gas, transportation, building
  34. automation and more for reliable and secure Linux-based
  35. embedded systems that can be sustained over a period of
  36. 10 to as many as 60 years.
  37. The project's goal is to provide an open source base layer
  38. of industrial-grade software that permits the use and
  39. implementation of software building blocks that meet
  40. these requirements.
  41. The CIP community plans to maintain 4.4 for security and
  42. bug fixes for more than 10 years.
  43. https://www.cip-project.org
  44. config BR2_LINUX_KERNEL_CUSTOM_VERSION
  45. bool "Custom version"
  46. help
  47. This option allows to use a specific official version from
  48. kernel.org, like 2.6.x, 2.6.x.y, 3.x.y, ...
  49. Note: you cannot use this option to select a _longterm_ 2.6
  50. kernel, because these kernels are not located at the standard
  51. URL at kernel.org. Instead, select "Custom tarball" and
  52. specify the right URL directly.
  53. config BR2_LINUX_KERNEL_CUSTOM_TARBALL
  54. bool "Custom tarball"
  55. help
  56. This option allows to specify a URL pointing to a kernel source
  57. tarball. This URL can use any protocol recognized by Buildroot,
  58. like http://, ftp://, file:// or scp://.
  59. When pointing to a local tarball using file://, you may want to
  60. use a make variable like $(TOPDIR) to reference the root of the
  61. Buildroot tree.
  62. config BR2_LINUX_KERNEL_CUSTOM_GIT
  63. bool "Custom Git repository"
  64. help
  65. This option allows Buildroot to get the Linux kernel source
  66. code from a Git repository.
  67. config BR2_LINUX_KERNEL_CUSTOM_HG
  68. bool "Custom Mercurial repository"
  69. help
  70. This option allows Buildroot to get the Linux kernel source
  71. code from a Mercurial repository.
  72. config BR2_LINUX_KERNEL_CUSTOM_SVN
  73. bool "Custom Subversion repository"
  74. help
  75. This option allows Buildroot to get the Linux kernel source
  76. code from a Subversion repository.
  77. endchoice
  78. config BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE
  79. string "Kernel version"
  80. depends on BR2_LINUX_KERNEL_CUSTOM_VERSION
  81. config BR2_LINUX_KERNEL_CUSTOM_TARBALL_LOCATION
  82. string "URL of custom kernel tarball"
  83. depends on BR2_LINUX_KERNEL_CUSTOM_TARBALL
  84. if BR2_LINUX_KERNEL_CUSTOM_GIT || BR2_LINUX_KERNEL_CUSTOM_HG || BR2_LINUX_KERNEL_CUSTOM_SVN
  85. config BR2_LINUX_KERNEL_CUSTOM_REPO_URL
  86. string "URL of custom repository"
  87. default BR2_LINUX_KERNEL_CUSTOM_GIT_REPO_URL \
  88. if BR2_LINUX_KERNEL_CUSTOM_GIT_REPO_URL != "" # legacy
  89. config BR2_LINUX_KERNEL_CUSTOM_REPO_VERSION
  90. string "Custom repository version"
  91. default BR2_LINUX_KERNEL_CUSTOM_GIT_VERSION \
  92. if BR2_LINUX_KERNEL_CUSTOM_GIT_VERSION != "" # legacy
  93. help
  94. Revision to use in the typical format used by Git/Mercurial/Subversion
  95. E.G. a sha id, a tag, branch, ..
  96. endif
  97. config BR2_LINUX_KERNEL_VERSION
  98. string
  99. default "4.15.16" if BR2_LINUX_KERNEL_LATEST_VERSION
  100. default "v4.4.171-cip30" if BR2_LINUX_KERNEL_LATEST_CIP_VERSION
  101. default BR2_LINUX_KERNEL_CUSTOM_VERSION_VALUE \
  102. if BR2_LINUX_KERNEL_CUSTOM_VERSION
  103. default "custom" if BR2_LINUX_KERNEL_CUSTOM_TARBALL
  104. default BR2_LINUX_KERNEL_CUSTOM_REPO_VERSION \
  105. if BR2_LINUX_KERNEL_CUSTOM_GIT || BR2_LINUX_KERNEL_CUSTOM_HG || BR2_LINUX_KERNEL_CUSTOM_SVN
  106. #
  107. # Patch selection
  108. #
  109. config BR2_LINUX_KERNEL_PATCH
  110. string "Custom kernel patches"
  111. help
  112. A space-separated list of patches to apply to the
  113. kernel. Each patch can be described as an URL, a local file
  114. path, or a directory. In the case of a directory, all files
  115. matching *.patch in the directory will be applied.
  116. #
  117. # Configuration selection
  118. #
  119. choice
  120. prompt "Kernel configuration"
  121. default BR2_LINUX_KERNEL_USE_DEFCONFIG
  122. config BR2_LINUX_KERNEL_USE_DEFCONFIG
  123. bool "Using an in-tree defconfig file"
  124. config BR2_LINUX_KERNEL_USE_ARCH_DEFAULT_CONFIG
  125. bool "Use the architecture default configuration"
  126. help
  127. This option will use the default configuration for the
  128. selected architecture. I.e, it is equivalent to running
  129. "make ARCH=<foo> defconfig". This is useful on architectures
  130. that have a single defconfig file, such as ARM64.
  131. config BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG
  132. bool "Using a custom (def)config file"
  133. endchoice
  134. config BR2_LINUX_KERNEL_DEFCONFIG
  135. string "Defconfig name"
  136. depends on BR2_LINUX_KERNEL_USE_DEFCONFIG
  137. help
  138. Name of the kernel defconfig file to use, without the
  139. trailing _defconfig. The defconfig is located in
  140. arch/<arch>/configs in the kernel tree.
  141. config BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE
  142. string "Configuration file path"
  143. depends on BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG
  144. help
  145. Path to the kernel configuration file
  146. Note: this can be a defconfig file or a complete .config file,
  147. which can later be saved back with make linux-update-(def)config.
  148. config BR2_LINUX_KERNEL_CONFIG_FRAGMENT_FILES
  149. string "Additional configuration fragment files"
  150. help
  151. A space-separated list of kernel configuration fragment files,
  152. that will be merged to the main kernel configuration file.
  153. #
  154. # Binary format
  155. #
  156. choice
  157. prompt "Kernel binary format"
  158. default BR2_LINUX_KERNEL_ZIMAGE if BR2_arm || BR2_armeb
  159. config BR2_LINUX_KERNEL_UIMAGE
  160. bool "uImage"
  161. depends on BR2_arc || BR2_arm || BR2_armeb || BR2_bfin || \
  162. BR2_powerpc || BR2_powerpc64 || BR2_powerpc64le || \
  163. BR2_sh || BR2_mips || BR2_mipsel || \
  164. BR2_mips64 || BR2_mips64el || BR2_xtensa
  165. select BR2_PACKAGE_HOST_UBOOT_TOOLS
  166. config BR2_LINUX_KERNEL_APPENDED_UIMAGE
  167. bool "uImage with appended DT"
  168. depends on BR2_arm || BR2_armeb
  169. select BR2_LINUX_KERNEL_DTS_SUPPORT
  170. select BR2_LINUX_KERNEL_APPENDED_DTB
  171. select BR2_PACKAGE_HOST_UBOOT_TOOLS
  172. config BR2_LINUX_KERNEL_BZIMAGE
  173. bool "bzImage"
  174. depends on BR2_i386 || BR2_x86_64
  175. config BR2_LINUX_KERNEL_ZIMAGE
  176. bool "zImage"
  177. depends on BR2_arm || BR2_armeb || BR2_powerpc || \
  178. BR2_powerpc64 || BR2_powerpc64le || BR2_sparc || \
  179. BR2_sh || BR2_xtensa
  180. config BR2_LINUX_KERNEL_ZIMAGE_EPAPR
  181. bool "zImage.epapr"
  182. depends on BR2_powerpc64 || BR2_powerpc64le
  183. config BR2_LINUX_KERNEL_APPENDED_ZIMAGE
  184. bool "zImage with appended DT"
  185. depends on BR2_arm || BR2_armeb
  186. select BR2_LINUX_KERNEL_DTS_SUPPORT
  187. select BR2_LINUX_KERNEL_APPENDED_DTB
  188. config BR2_LINUX_KERNEL_CUIMAGE
  189. bool "cuImage"
  190. depends on BR2_powerpc
  191. select BR2_PACKAGE_HOST_UBOOT_TOOLS
  192. select BR2_LINUX_KERNEL_DTS_SUPPORT
  193. select BR2_LINUX_KERNEL_DTB_IS_SELF_BUILT
  194. config BR2_LINUX_KERNEL_SIMPLEIMAGE
  195. bool "simpleImage"
  196. depends on BR2_microblaze
  197. select BR2_PACKAGE_HOST_UBOOT_TOOLS
  198. select BR2_LINUX_KERNEL_DTS_SUPPORT
  199. select BR2_LINUX_KERNEL_DTB_IS_SELF_BUILT
  200. config BR2_LINUX_KERNEL_IMAGE
  201. bool "Image"
  202. depends on BR2_aarch64
  203. config BR2_LINUX_KERNEL_LINUX_BIN
  204. bool "linux.bin"
  205. depends on BR2_microblaze
  206. select BR2_PACKAGE_HOST_UBOOT_TOOLS
  207. config BR2_LINUX_KERNEL_VMLINUX_BIN
  208. bool "vmlinux.bin"
  209. depends on BR2_mips || BR2_mipsel || BR2_sh
  210. config BR2_LINUX_KERNEL_VMLINUX
  211. bool "vmlinux"
  212. config BR2_LINUX_KERNEL_VMLINUZ
  213. bool "vmlinuz"
  214. depends on BR2_mips || BR2_mipsel
  215. config BR2_LINUX_KERNEL_VMLINUZ_BIN
  216. bool "vmlinuz.bin"
  217. depends on BR2_mips || BR2_mipsel
  218. config BR2_LINUX_KERNEL_IMAGE_TARGET_CUSTOM
  219. bool "custom target"
  220. help
  221. For certain cases a board-specific target image must be
  222. used. For example, on powerPC where the OpenFirmware
  223. description is attached in a board-specific kernel image
  224. target like 'cuImage.mpc8379_rdb'.
  225. Select this option and specify the make target in "Kernel
  226. image target name".
  227. endchoice
  228. #
  229. # Kernel compression format
  230. #
  231. choice
  232. prompt "Kernel compression format"
  233. help
  234. This selection will just ensure that the correct host tools are built.
  235. The actual compression for the kernel should be selected in the
  236. kernel configuration menu.
  237. config BR2_LINUX_KERNEL_GZIP
  238. bool "gzip compression"
  239. config BR2_LINUX_KERNEL_LZ4
  240. bool "lz4 compression"
  241. config BR2_LINUX_KERNEL_LZMA
  242. bool "lzma compression"
  243. config BR2_LINUX_KERNEL_LZO
  244. bool "lzo compression"
  245. config BR2_LINUX_KERNEL_XZ
  246. bool "xz compression"
  247. endchoice
  248. config BR2_LINUX_KERNEL_IMAGE_TARGET_NAME
  249. string "Kernel image target name"
  250. depends on BR2_LINUX_KERNEL_IMAGE_TARGET_CUSTOM
  251. help
  252. Specify the kernel make target to build the kernel that you
  253. need.
  254. config BR2_LINUX_KERNEL_IMAGE_NAME
  255. string "Kernel image name"
  256. depends on BR2_LINUX_KERNEL_IMAGE_TARGET_CUSTOM
  257. help
  258. The filename of the kernel image, if it is different from the
  259. make target (above). Only Xtensa uses a filename different from
  260. the make target. Defaults to BR2_LINUX_KERNEL_IMAGE_TARGET_NAME.
  261. If unsure, leave it empty.
  262. config BR2_LINUX_KERNEL_UIMAGE_LOADADDR
  263. string "load address (for 3.7+ multi-platform image)"
  264. depends on BR2_arm || BR2_armeb
  265. depends on BR2_LINUX_KERNEL_UIMAGE || BR2_LINUX_KERNEL_APPENDED_UIMAGE
  266. help
  267. If your ARM system's Linux kernel is configured with the new (3.7+)
  268. multi-architecture support (CONFIG_ARCH_MULTIPLATFORM=y in your
  269. kernel config), then it is necessary to specify a kernel load address
  270. when building the uImage. This should be a hexadecimal string
  271. beginning with 0x, for example: 0x00008000.
  272. If unsure, let this option empty.
  273. config BR2_LINUX_KERNEL_DTS_SUPPORT
  274. bool "Build a Device Tree Blob (DTB)"
  275. help
  276. Compile one or more device tree sources into device tree blobs.
  277. Select the dts files to compile in the options below.
  278. if BR2_LINUX_KERNEL_DTS_SUPPORT
  279. # We have mainly three cases when it comes to device tree support:
  280. # 1) We don't want any support at all. Then the ..DTS_SUPPORT
  281. # variable won't be set
  282. # 2) We want device tree support, so we need the user to enter the
  283. # device tree name or the path to the custom device he uses, but
  284. # the kernel abstracts this from us and only build an image that
  285. # looks like a regular kernel image. In this case, we only need
  286. # to derive the kernel image name from the given device tree
  287. # name, and all the rest is as usual
  288. # 3) We want device tree support, but the kernel requires us to
  289. # build the device tree blob separately. In this case, some
  290. # more logic will be needed.
  291. # The variable below address the second case, were you only want
  292. # limited actions from buildroot.
  293. config BR2_LINUX_KERNEL_DTB_IS_SELF_BUILT
  294. bool
  295. config BR2_LINUX_KERNEL_APPENDED_DTB
  296. bool
  297. config BR2_LINUX_KERNEL_INTREE_DTS_NAME
  298. string "In-tree Device Tree Source file names"
  299. help
  300. Name of in-tree device tree source file, without
  301. the trailing .dts. You can provide a list of
  302. dts files to build, separated by spaces.
  303. config BR2_LINUX_KERNEL_CUSTOM_DTS_PATH
  304. string "Out-of-tree Device Tree Source file paths"
  305. help
  306. Path to to out-of-tree device tree source files.
  307. You can provide a list of dts paths to copy and
  308. build, separated by spaces.
  309. endif
  310. config BR2_LINUX_KERNEL_INSTALL_TARGET
  311. bool "Install kernel image to /boot in target"
  312. depends on !BR2_TARGET_ROOTFS_INITRAMFS
  313. help
  314. Select this option to have the kernel image installed to
  315. /boot in the target root filesystem, as is typically done on
  316. x86/x86_64 systems.
  317. Note that this option also installs the Device Tree Blobs to
  318. /boot if DTBs have been generated by the kernel build
  319. process.
  320. config BR2_LINUX_KERNEL_NEEDS_HOST_OPENSSL
  321. bool "Needs host OpenSSL"
  322. help
  323. Some Linux kernel configuration options (such as
  324. CONFIG_SYSTEM_TRUSTED_KEYRING) require building a host
  325. program called extract-cert, which itself needs
  326. OpenSSL. Enabling this option will ensure host-openssl gets
  327. built before the Linux kernel.
  328. Enable this option if you get a Linux kernel build failure
  329. such as "scripts/extract-cert.c:21:25: fatal error:
  330. openssl/bio.h: No such file or directory".
  331. config BR2_LINUX_KERNEL_NEEDS_HOST_LIBELF
  332. bool "Needs host libelf"
  333. help
  334. Some Linux kernel configuration options (such as
  335. CONFIG_UNWINDER_ORC) require building a host program that
  336. needs libelf. Enabling this option will ensure host-elfutils
  337. (which provides libelf) gets built before the Linux kernel.
  338. Enable this option if you get a Linux kernel build failure
  339. such as "Cannot generate ORC metadata for
  340. CONFIG_UNWINDER_ORC=y, please install libelf-dev,
  341. libelf-devel or elfutils-libelf-devel".
  342. # Linux extensions
  343. source "linux/Config.ext.in"
  344. # Linux tools
  345. source "package/linux-tools/Config.in"
  346. endif # BR2_LINUX_KERNEL
  347. endmenu