2
1

linux.mk 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  1. ################################################################################
  2. #
  3. # Linux kernel target
  4. #
  5. ################################################################################
  6. LINUX_VERSION = $(call qstrip,$(BR2_LINUX_KERNEL_VERSION))
  7. LINUX_LICENSE = GPLv2
  8. LINUX_LICENSE_FILES = COPYING
  9. # Compute LINUX_SOURCE and LINUX_SITE from the configuration
  10. ifeq ($(BR2_LINUX_KERNEL_CUSTOM_TARBALL),y)
  11. LINUX_TARBALL = $(call qstrip,$(BR2_LINUX_KERNEL_CUSTOM_TARBALL_LOCATION))
  12. LINUX_SITE = $(patsubst %/,%,$(dir $(LINUX_TARBALL)))
  13. LINUX_SOURCE = $(notdir $(LINUX_TARBALL))
  14. else ifeq ($(BR2_LINUX_KERNEL_CUSTOM_LOCAL),y)
  15. LINUX_SITE = $(call qstrip,$(BR2_LINUX_KERNEL_CUSTOM_LOCAL_PATH))
  16. LINUX_SITE_METHOD = local
  17. else ifeq ($(BR2_LINUX_KERNEL_CUSTOM_GIT),y)
  18. LINUX_SITE = $(call qstrip,$(BR2_LINUX_KERNEL_CUSTOM_REPO_URL))
  19. LINUX_SITE_METHOD = git
  20. else ifeq ($(BR2_LINUX_KERNEL_CUSTOM_HG),y)
  21. LINUX_SITE = $(call qstrip,$(BR2_LINUX_KERNEL_CUSTOM_REPO_URL))
  22. LINUX_SITE_METHOD = hg
  23. else
  24. LINUX_SOURCE = linux-$(LINUX_VERSION).tar.xz
  25. # In X.Y.Z, get X and Y. We replace dots and dashes by spaces in order
  26. # to use the $(word) function. We support versions such as 3.1,
  27. # 2.6.32, 2.6.32-rc1, 3.0-rc6, etc.
  28. ifeq ($(findstring x2.6.,x$(LINUX_VERSION)),x2.6.)
  29. LINUX_SITE = $(BR2_KERNEL_MIRROR)/linux/kernel/v2.6/
  30. else
  31. LINUX_SITE = $(BR2_KERNEL_MIRROR)/linux/kernel/v3.x/
  32. endif
  33. # release candidates are in testing/ subdir
  34. ifneq ($(findstring -rc,$(LINUX_VERSION)),)
  35. LINUX_SITE := $(LINUX_SITE)testing/
  36. endif # -rc
  37. endif
  38. LINUX_PATCHES = $(call qstrip,$(BR2_LINUX_KERNEL_PATCH))
  39. LINUX_INSTALL_IMAGES = YES
  40. LINUX_DEPENDENCIES += host-kmod host-lzop
  41. ifeq ($(BR2_LINUX_KERNEL_UBOOT_IMAGE),y)
  42. LINUX_DEPENDENCIES += host-uboot-tools
  43. endif
  44. LINUX_MAKE_FLAGS = \
  45. HOSTCC="$(HOSTCC)" \
  46. HOSTCFLAGS="$(HOSTCFLAGS)" \
  47. ARCH=$(KERNEL_ARCH) \
  48. INSTALL_MOD_PATH=$(TARGET_DIR) \
  49. CROSS_COMPILE="$(CCACHE) $(TARGET_CROSS)" \
  50. DEPMOD=$(HOST_DIR)/sbin/depmod
  51. # Get the real Linux version, which tells us where kernel modules are
  52. # going to be installed in the target filesystem.
  53. LINUX_VERSION_PROBED = $(shell $(MAKE) $(LINUX_MAKE_FLAGS) -C $(LINUX_DIR) --no-print-directory -s kernelrelease)
  54. ifeq ($(BR2_LINUX_KERNEL_USE_INTREE_DTS),y)
  55. KERNEL_DTS_NAME = $(call qstrip,$(BR2_LINUX_KERNEL_INTREE_DTS_NAME))
  56. else ifeq ($(BR2_LINUX_KERNEL_USE_CUSTOM_DTS),y)
  57. KERNEL_DTS_NAME = $(basename $(notdir $(call qstrip,$(BR2_LINUX_KERNEL_CUSTOM_DTS_PATH))))
  58. endif
  59. ifeq ($(BR2_LINUX_KERNEL_DTS_SUPPORT)$(KERNEL_DTS_NAME),y)
  60. $(error No kernel device tree source specified, check your \
  61. BR2_LINUX_KERNEL_USE_INTREE_DTS / BR2_LINUX_KERNEL_USE_CUSTOM_DTS settings)
  62. endif
  63. ifeq ($(BR2_LINUX_KERNEL_APPENDED_DTB),y)
  64. ifneq ($(words $(KERNEL_DTS_NAME)),1)
  65. $(error Kernel with appended device tree needs exactly one DTS source.\
  66. Check BR2_LINUX_KERNEL_INTREE_DTS_NAME or BR2_LINUX_KERNEL_CUSTOM_DTS_PATH.)
  67. endif
  68. endif
  69. KERNEL_DTBS = $(addsuffix .dtb,$(KERNEL_DTS_NAME))
  70. ifeq ($(BR2_LINUX_KERNEL_IMAGE_TARGET_CUSTOM),y)
  71. LINUX_IMAGE_NAME=$(call qstrip,$(BR2_LINUX_KERNEL_IMAGE_TARGET_NAME))
  72. else
  73. ifeq ($(BR2_LINUX_KERNEL_UIMAGE),y)
  74. LINUX_IMAGE_NAME=uImage
  75. else ifeq ($(BR2_LINUX_KERNEL_APPENDED_UIMAGE),y)
  76. LINUX_IMAGE_NAME=uImage
  77. else ifeq ($(BR2_LINUX_KERNEL_BZIMAGE),y)
  78. LINUX_IMAGE_NAME=bzImage
  79. else ifeq ($(BR2_LINUX_KERNEL_ZIMAGE),y)
  80. LINUX_IMAGE_NAME=zImage
  81. else ifeq ($(BR2_LINUX_KERNEL_APPENDED_ZIMAGE),y)
  82. LINUX_IMAGE_NAME=zImage
  83. else ifeq ($(BR2_LINUX_KERNEL_CUIMAGE),y)
  84. LINUX_IMAGE_NAME=cuImage.$(KERNEL_DTS_NAME)
  85. else ifeq ($(BR2_LINUX_KERNEL_SIMPLEIMAGE),y)
  86. LINUX_IMAGE_NAME=simpleImage.$(KERNEL_DTS_NAME)
  87. else ifeq ($(BR2_LINUX_KERNEL_LINUX_BIN),y)
  88. LINUX_IMAGE_NAME=linux.bin
  89. else ifeq ($(BR2_LINUX_KERNEL_VMLINUX_BIN),y)
  90. LINUX_IMAGE_NAME=vmlinux.bin
  91. else ifeq ($(BR2_LINUX_KERNEL_VMLINUX),y)
  92. LINUX_IMAGE_NAME=vmlinux
  93. else ifeq ($(BR2_LINUX_KERNEL_VMLINUZ),y)
  94. LINUX_IMAGE_NAME=vmlinuz
  95. endif
  96. endif
  97. LINUX_KERNEL_UIMAGE_LOADADDR=$(call qstrip,$(BR2_LINUX_KERNEL_UIMAGE_LOADADDR))
  98. ifneq ($(LINUX_KERNEL_UIMAGE_LOADADDR),)
  99. LINUX_MAKE_FLAGS+=LOADADDR="$(LINUX_KERNEL_UIMAGE_LOADADDR)"
  100. endif
  101. # Compute the arch path, since i386 and x86_64 are in arch/x86 and not
  102. # in arch/$(KERNEL_ARCH). Even if the kernel creates symbolic links
  103. # for bzImage, arch/i386 and arch/x86_64 do not exist when copying the
  104. # defconfig file.
  105. ifeq ($(KERNEL_ARCH),i386)
  106. KERNEL_ARCH_PATH=$(LINUX_DIR)/arch/x86
  107. else ifeq ($(KERNEL_ARCH),x86_64)
  108. KERNEL_ARCH_PATH=$(LINUX_DIR)/arch/x86
  109. else
  110. KERNEL_ARCH_PATH=$(LINUX_DIR)/arch/$(KERNEL_ARCH)
  111. endif
  112. ifeq ($(BR2_LINUX_KERNEL_VMLINUX),y)
  113. LINUX_IMAGE_PATH=$(LINUX_DIR)/$(LINUX_IMAGE_NAME)
  114. else ifeq ($(BR2_LINUX_KERNEL_VMLINUZ),y)
  115. LINUX_IMAGE_PATH=$(LINUX_DIR)/$(LINUX_IMAGE_NAME)
  116. else
  117. ifeq ($(KERNEL_ARCH),avr32)
  118. LINUX_IMAGE_PATH=$(KERNEL_ARCH_PATH)/boot/images/$(LINUX_IMAGE_NAME)
  119. else
  120. LINUX_IMAGE_PATH=$(KERNEL_ARCH_PATH)/boot/$(LINUX_IMAGE_NAME)
  121. endif
  122. endif # BR2_LINUX_KERNEL_VMLINUX
  123. define LINUX_DOWNLOAD_PATCHES
  124. $(if $(LINUX_PATCHES),
  125. @$(call MESSAGE,"Download additional patches"))
  126. $(foreach patch,$(filter ftp://% http://%,$(LINUX_PATCHES)),\
  127. $(call DOWNLOAD,$(patch))$(sep))
  128. endef
  129. LINUX_POST_DOWNLOAD_HOOKS += LINUX_DOWNLOAD_PATCHES
  130. define LINUX_APPLY_PATCHES
  131. for p in $(LINUX_PATCHES) ; do \
  132. if echo $$p | grep -q -E "^ftp://|^http://" ; then \
  133. support/scripts/apply-patches.sh $(@D) $(DL_DIR) `basename $$p` ; \
  134. elif test -d $$p ; then \
  135. support/scripts/apply-patches.sh $(@D) $$p linux-\*.patch ; \
  136. else \
  137. support/scripts/apply-patches.sh $(@D) `dirname $$p` `basename $$p` ; \
  138. fi \
  139. done
  140. endef
  141. LINUX_POST_PATCH_HOOKS += LINUX_APPLY_PATCHES
  142. ifeq ($(BR2_LINUX_KERNEL_USE_DEFCONFIG),y)
  143. KERNEL_SOURCE_CONFIG = $(KERNEL_ARCH_PATH)/configs/$(call qstrip,$(BR2_LINUX_KERNEL_DEFCONFIG))_defconfig
  144. else ifeq ($(BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG),y)
  145. KERNEL_SOURCE_CONFIG = $(BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE)
  146. endif
  147. define LINUX_CONFIGURE_CMDS
  148. $(INSTALL) -m 0644 $(KERNEL_SOURCE_CONFIG) $(KERNEL_ARCH_PATH)/configs/buildroot_defconfig
  149. $(TARGET_MAKE_ENV) $(MAKE1) $(LINUX_MAKE_FLAGS) -C $(@D) buildroot_defconfig
  150. rm $(KERNEL_ARCH_PATH)/configs/buildroot_defconfig
  151. $(if $(BR2_arm)$(BR2_armeb),
  152. $(call KCONFIG_ENABLE_OPT,CONFIG_AEABI,$(@D)/.config))
  153. $(if $(BR2_TARGET_ROOTFS_CPIO),
  154. $(call KCONFIG_ENABLE_OPT,CONFIG_BLK_DEV_INITRD,$(@D)/.config))
  155. # As the kernel gets compiled before root filesystems are
  156. # built, we create a fake cpio file. It'll be
  157. # replaced later by the real cpio archive, and the kernel will be
  158. # rebuilt using the linux26-rebuild-with-initramfs target.
  159. $(if $(BR2_TARGET_ROOTFS_INITRAMFS),
  160. touch $(BINARIES_DIR)/rootfs.cpio
  161. $(call KCONFIG_SET_OPT,CONFIG_INITRAMFS_SOURCE,\"$(BINARIES_DIR)/rootfs.cpio\",$(@D)/.config)
  162. $(call KCONFIG_SET_OPT,CONFIG_INITRAMFS_ROOT_UID,0,$(@D)/.config)
  163. $(call KCONFIG_SET_OPT,CONFIG_INITRAMFS_ROOT_GID,0,$(@D)/.config))
  164. $(if $(BR2_ROOTFS_DEVICE_CREATION_STATIC),,
  165. $(call KCONFIG_ENABLE_OPT,CONFIG_DEVTMPFS,$(@D)/.config)
  166. $(call KCONFIG_ENABLE_OPT,CONFIG_DEVTMPFS_MOUNT,$(@D)/.config))
  167. $(if $(BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_MDEV),
  168. $(call KCONFIG_SET_OPT,CONFIG_UEVENT_HELPER_PATH,\"/sbin/mdev\",$(@D)/.config))
  169. $(if $(BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_UDEV),
  170. $(call KCONFIG_ENABLE_OPT,CONFIG_INOTIFY_USER,$(@D)/.config))
  171. $(if $(BR2_PACKAGE_KTAP),
  172. $(call KCONFIG_ENABLE_OPT,CONFIG_DEBUG_FS,$(@D)/.config)
  173. $(call KCONFIG_ENABLE_OPT,CONFIG_EVENT_TRACING,$(@D)/.config)
  174. $(call KCONFIG_ENABLE_OPT,CONFIG_PERF_EVENTS,$(@D)/.config)
  175. $(call KCONFIG_ENABLE_OPT,CONFIG_FUNCTION_TRACER,$(@D)/.config))
  176. $(if $(BR2_PACKAGE_SYSTEMD),
  177. $(call KCONFIG_ENABLE_OPT,CONFIG_CGROUPS,$(@D)/.config))
  178. $(if $(BR2_LINUX_KERNEL_APPENDED_DTB),
  179. $(call KCONFIG_ENABLE_OPT,CONFIG_ARM_APPENDED_DTB,$(@D)/.config))
  180. yes '' | $(TARGET_MAKE_ENV) $(MAKE1) $(LINUX_MAKE_FLAGS) -C $(@D) oldconfig
  181. endef
  182. ifeq ($(BR2_LINUX_KERNEL_DTS_SUPPORT),y)
  183. ifeq ($(BR2_LINUX_KERNEL_DTB_IS_SELF_BUILT),)
  184. define LINUX_BUILD_DTB
  185. $(TARGET_MAKE_ENV) $(MAKE) $(LINUX_MAKE_FLAGS) -C $(@D) $(KERNEL_DTBS)
  186. endef
  187. define LINUX_INSTALL_DTB
  188. # dtbs moved from arch/<ARCH>/boot to arch/<ARCH>/boot/dts since 3.8-rc1
  189. cp $(addprefix \
  190. $(KERNEL_ARCH_PATH)/boot/$(if $(wildcard \
  191. $(addprefix $(KERNEL_ARCH_PATH)/boot/dts/,$(KERNEL_DTBS))),dts/),$(KERNEL_DTBS)) \
  192. $(BINARIES_DIR)/
  193. endef
  194. define LINUX_INSTALL_DTB_TARGET
  195. # dtbs moved from arch/<ARCH>/boot to arch/<ARCH>/boot/dts since 3.8-rc1
  196. cp $(addprefix \
  197. $(KERNEL_ARCH_PATH)/boot/$(if $(wildcard \
  198. $(addprefix $(KERNEL_ARCH_PATH)/boot/dts/,$(KERNEL_DTBS))),dts/),$(KERNEL_DTBS)) \
  199. $(TARGET_DIR)/boot/
  200. endef
  201. endif
  202. endif
  203. ifeq ($(BR2_LINUX_KERNEL_APPENDED_DTB),y)
  204. # dtbs moved from arch/$ARCH/boot to arch/$ARCH/boot/dts since 3.8-rc1
  205. define LINUX_APPEND_DTB
  206. if [ -e $(KERNEL_ARCH_PATH)/boot/$(KERNEL_DTS_NAME).dtb ]; then \
  207. cat $(KERNEL_ARCH_PATH)/boot/$(KERNEL_DTS_NAME).dtb; \
  208. else \
  209. cat $(KERNEL_ARCH_PATH)/boot/dts/$(KERNEL_DTS_NAME).dtb; \
  210. fi >> $(KERNEL_ARCH_PATH)/boot/zImage
  211. endef
  212. ifeq ($(BR2_LINUX_KERNEL_APPENDED_UIMAGE),y)
  213. # We need to generate a new u-boot image that takes into
  214. # account the extra-size added by the device tree at the end
  215. # of the image. To do so, we first need to retrieve both load
  216. # address and entry point for the kernel from the already
  217. # generate uboot image before using mkimage -l.
  218. LINUX_APPEND_DTB += $(sep) MKIMAGE_ARGS=`$(MKIMAGE) -l $(LINUX_IMAGE_PATH) |\
  219. sed -n -e 's/Image Name:[ ]*\(.*\)/-n \1/p' -e 's/Load Address:/-a/p' -e 's/Entry Point:/-e/p'`; \
  220. $(MKIMAGE) -A $(MKIMAGE_ARCH) -O linux \
  221. -T kernel -C none $${MKIMAGE_ARGS} \
  222. -d $(KERNEL_ARCH_PATH)/boot/zImage $(LINUX_IMAGE_PATH);
  223. endif
  224. endif
  225. # Compilation. We make sure the kernel gets rebuilt when the
  226. # configuration has changed.
  227. define LINUX_BUILD_CMDS
  228. $(if $(BR2_LINUX_KERNEL_USE_CUSTOM_DTS),
  229. cp $(BR2_LINUX_KERNEL_CUSTOM_DTS_PATH) $(KERNEL_ARCH_PATH)/boot/dts/)
  230. $(TARGET_MAKE_ENV) $(MAKE) $(LINUX_MAKE_FLAGS) -C $(@D) $(LINUX_IMAGE_NAME)
  231. @if grep -q "CONFIG_MODULES=y" $(@D)/.config; then \
  232. $(TARGET_MAKE_ENV) $(MAKE) $(LINUX_MAKE_FLAGS) -C $(@D) modules ; \
  233. fi
  234. $(LINUX_BUILD_DTB)
  235. $(LINUX_APPEND_DTB)
  236. endef
  237. ifeq ($(BR2_LINUX_KERNEL_INSTALL_TARGET),y)
  238. define LINUX_INSTALL_KERNEL_IMAGE_TO_TARGET
  239. install -m 0644 -D $(LINUX_IMAGE_PATH) $(TARGET_DIR)/boot/$(LINUX_IMAGE_NAME)
  240. $(LINUX_INSTALL_DTB_TARGET)
  241. endef
  242. endif
  243. define LINUX_INSTALL_HOST_TOOLS
  244. # Installing dtc (device tree compiler) as host tool, if selected
  245. if grep -q "CONFIG_DTC=y" $(@D)/.config; then \
  246. $(INSTALL) -D -m 0755 $(@D)/scripts/dtc/dtc $(HOST_DIR)/usr/bin/dtc ; \
  247. fi
  248. endef
  249. define LINUX_INSTALL_IMAGES_CMDS
  250. cp $(LINUX_IMAGE_PATH) $(BINARIES_DIR)
  251. $(LINUX_INSTALL_DTB)
  252. endef
  253. define LINUX_INSTALL_TARGET_CMDS
  254. $(LINUX_INSTALL_KERNEL_IMAGE_TO_TARGET)
  255. # Install modules and remove symbolic links pointing to build
  256. # directories, not relevant on the target
  257. @if grep -q "CONFIG_MODULES=y" $(@D)/.config; then \
  258. $(TARGET_MAKE_ENV) $(MAKE1) $(LINUX_MAKE_FLAGS) -C $(@D) modules_install; \
  259. rm -f $(TARGET_DIR)/lib/modules/$(LINUX_VERSION_PROBED)/build ; \
  260. rm -f $(TARGET_DIR)/lib/modules/$(LINUX_VERSION_PROBED)/source ; \
  261. fi
  262. $(LINUX_INSTALL_HOST_TOOLS)
  263. endef
  264. include $(sort $(wildcard linux/linux-ext-*.mk))
  265. $(eval $(generic-package))
  266. ifeq ($(BR2_LINUX_KERNEL),y)
  267. linux-menuconfig linux-xconfig linux-gconfig linux-nconfig linux26-menuconfig linux26-xconfig linux26-gconfig linux26-nconfig: dirs linux-configure
  268. $(MAKE) $(LINUX_MAKE_FLAGS) -C $(LINUX_DIR) \
  269. $(subst linux-,,$(subst linux26-,,$@))
  270. rm -f $(LINUX_DIR)/.stamp_{built,target_installed,images_installed}
  271. linux-savedefconfig linux26-savedefconfig: dirs linux-configure
  272. $(MAKE) $(LINUX_MAKE_FLAGS) -C $(LINUX_DIR) \
  273. $(subst linux-,,$(subst linux26-,,$@))
  274. ifeq ($(BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG),y)
  275. linux-update-config linux26-update-config: linux-configure $(LINUX_DIR)/.config
  276. cp -f $(LINUX_DIR)/.config $(BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE)
  277. linux-update-defconfig linux26-update-defconfig: linux-savedefconfig
  278. cp -f $(LINUX_DIR)/defconfig $(BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE)
  279. else
  280. linux-update-config linux26-update-config: ;
  281. linux-update-defconfig linux26-update-defconfig: ;
  282. endif
  283. endif
  284. # Support for rebuilding the kernel after the cpio archive has
  285. # been generated in $(BINARIES_DIR)/rootfs.cpio.
  286. $(LINUX_DIR)/.stamp_initramfs_rebuilt: $(LINUX_DIR)/.stamp_target_installed $(LINUX_DIR)/.stamp_images_installed $(BINARIES_DIR)/rootfs.cpio
  287. @$(call MESSAGE,"Rebuilding kernel with initramfs")
  288. # Build the kernel.
  289. $(TARGET_MAKE_ENV) $(MAKE) $(LINUX_MAKE_FLAGS) -C $(@D) $(LINUX_IMAGE_NAME)
  290. $(LINUX_APPEND_DTB)
  291. # Copy the kernel image to its final destination
  292. cp $(LINUX_IMAGE_PATH) $(BINARIES_DIR)
  293. # If there is a .ub file copy it to the final destination
  294. test ! -f $(LINUX_IMAGE_PATH).ub || cp $(LINUX_IMAGE_PATH).ub $(BINARIES_DIR)
  295. $(Q)touch $@
  296. # The initramfs building code must make sure this target gets called
  297. # after it generated the initramfs list of files.
  298. linux-rebuild-with-initramfs linux26-rebuild-with-initramfs: $(LINUX_DIR)/.stamp_initramfs_rebuilt
  299. # Checks to give errors that the user can understand
  300. ifeq ($(filter source,$(MAKECMDGOALS)),)
  301. ifeq ($(BR2_LINUX_KERNEL_USE_DEFCONFIG),y)
  302. ifeq ($(call qstrip,$(BR2_LINUX_KERNEL_DEFCONFIG)),)
  303. $(error No kernel defconfig name specified, check your BR2_LINUX_KERNEL_DEFCONFIG setting)
  304. endif
  305. endif
  306. ifeq ($(BR2_LINUX_KERNEL_USE_CUSTOM_CONFIG),y)
  307. ifeq ($(call qstrip,$(BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE)),)
  308. $(error No kernel configuration file specified, check your BR2_LINUX_KERNEL_CUSTOM_CONFIG_FILE setting)
  309. endif
  310. endif
  311. endif