linux.mk 11 KB

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