Config.in 15 KB

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