X-Git-Url: http://git.osdn.net/view?p=android-x86%2Fdevice-generic-common.git;a=blobdiff_plain;f=build%2Ftasks%2Fkernel.mk;h=ee6dbfc73a6c9d337a17b7f45301232cdf47d934;hp=abdd3122b2d554e54cc99c4dbe1f91eb6552461c;hb=9b4484c2661d2ec037f0d9c4f3b40a61ff62cdcf;hpb=e77f82d89a7f30aef31196f66eecf735739120ae diff --git a/build/tasks/kernel.mk b/build/tasks/kernel.mk index abdd312..ee6dbfc 100644 --- a/build/tasks/kernel.mk +++ b/build/tasks/kernel.mk @@ -1,5 +1,5 @@ # -# Copyright (C) 2014-2017 The Android-x86 Open Source Project +# Copyright (C) 2014-2019 The Android-x86 Open Source Project # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -8,6 +8,9 @@ # http://www.apache.org/licenses/LICENSE-2.0 # +export LC_CTYPE := C +export LC_MESSAGES := C + ifneq ($(TARGET_NO_KERNEL),true) ifeq ($(TARGET_PREBUILT_KERNEL),) @@ -25,13 +28,26 @@ TARGET_KERNEL_CONFIG ?= goldfish_defconfig KERNEL_CONFIG_DIR := arch/arm/configs endif +ifeq ($(BUILD_KERNEL_WITH_CLANG),true) +CROSS_COMPILE := x86_64-linux-androidkernel- +KERNEL_CLANG_CLAGS := CC=clang HOSTCC=clang CLANG_TRIPLE=x86_64-linux-gnu- PATH=$(abspath $(LLVM_PREBUILTS_BASE)/$(BUILD_OS)-x86/$(LLVM_PREBUILTS_VERSION)/bin):$$PATH +else ifeq ($(TARGET_KERNEL_ARCH),x86_64) +ifeq ($(HOST_OS),darwin) +CROSS_COMPILE ?= $(abspath prebuilts/gcc/darwin-x86/host/i686-apple-darwin-4.2.1/bin)/i686-apple-darwin11- +else CROSS_COMPILE ?= $(abspath prebuilts/gcc/linux-x86/host/x86_64-linux-glibc2.11-4.6/bin)/x86_64-linux- +endif else CROSS_COMPILE ?= $(abspath $(TARGET_TOOLS_PREFIX)) endif +endif + KBUILD_OUTPUT := $(abspath $(TARGET_OUT_INTERMEDIATES)/kernel) -mk_kernel := + $(hide) $(MAKE) -C $(KERNEL_DIR) O=$(KBUILD_OUTPUT) ARCH=$(TARGET_ARCH) CROSS_COMPILE="$(abspath $(CC_WRAPPER)) $(CROSS_COMPILE)" $(if $(SHOW_COMMANDS),V=1) +mk_kernel := + $(hide) $(MAKE) $(if $(filter darwin,$(HOST_OS)),-j$$(sysctl -n hw.ncpu) -l$$(($$(sysctl -n hw.ncpu)+2)),-j$$(nproc) -l$$(($$(nproc)+2))) \ + -C $(KERNEL_DIR) O=$(KBUILD_OUTPUT) ARCH=$(TARGET_ARCH) CROSS_COMPILE="$(abspath $(CC_WRAPPER)) $(CROSS_COMPILE)" $(if $(SHOW_COMMANDS),V=1) \ + YACC=$(abspath $(BISON)) LEX=$(abspath $(LEX)) \ + $(KERNEL_CLANG_CLAGS) KERNEL_CONFIG_FILE := $(if $(wildcard $(TARGET_KERNEL_CONFIG)),$(TARGET_KERNEL_CONFIG),$(KERNEL_DIR)/$(KERNEL_CONFIG_DIR)/$(TARGET_KERNEL_CONFIG)) @@ -45,15 +61,12 @@ KERNEL_DOTCONFIG_FILE := $(KBUILD_OUTPUT)/.config KERNEL_ARCH_CHANGED := $(if $(filter 0,$(shell grep -s ^$(if $(filter x86,$(TARGET_KERNEL_ARCH)),\#.)CONFIG_64BIT $(KERNEL_DOTCONFIG_FILE) | wc -l)),FORCE) $(KERNEL_DOTCONFIG_FILE): $(KERNEL_CONFIG_FILE) $(wildcard $(TARGET_KERNEL_DIFFCONFIG)) $(KERNEL_ARCH_CHANGED) $(hide) mkdir -p $(@D) && cat $(wildcard $^) > $@ - $(mk_kernel) oldnoconfig - -# bison is needed to build kernel and external modules from source -BISON := $(HOST_OUT_EXECUTABLES)/bison$(HOST_EXECUTABLE_SUFFIX) + $(hide) ln -sf ../../../../../../external $(@D) + $(mk_kernel) olddefconfig BUILT_KERNEL_TARGET := $(KBUILD_OUTPUT)/arch/$(TARGET_ARCH)/boot/$(KERNEL_TARGET) -$(INSTALLED_KERNEL_TARGET): $(KERNEL_DOTCONFIG_FILE) | $(ACP) $(BISON) +$(BUILT_KERNEL_TARGET): $(KERNEL_DOTCONFIG_FILE) $(mk_kernel) $(KERNEL_TARGET) $(if $(MOD_ENABLED),modules) - $(hide) $(ACP) -fp $(BUILT_KERNEL_TARGET) $@ $(if $(FIRMWARE_ENABLED),$(mk_kernel) INSTALL_MOD_PATH=$(abspath $(TARGET_OUT)) firmware_install) ifneq ($(MOD_ENABLED),) @@ -61,12 +74,12 @@ KERNEL_MODULES_DEP := $(firstword $(wildcard $(TARGET_OUT)/lib/modules/*/modules KERNEL_MODULES_DEP := $(if $(KERNEL_MODULES_DEP),$(KERNEL_MODULES_DEP),$(TARGET_OUT)/lib/modules) ALL_EXTRA_MODULES := $(patsubst %,$(TARGET_OUT_INTERMEDIATES)/kmodule/%,$(TARGET_EXTRA_KERNEL_MODULES)) -$(ALL_EXTRA_MODULES): $(TARGET_OUT_INTERMEDIATES)/kmodule/%: $(INSTALLED_KERNEL_TARGET) +$(ALL_EXTRA_MODULES): $(TARGET_OUT_INTERMEDIATES)/kmodule/%: $(BUILT_KERNEL_TARGET) | $(ACP) @echo Building additional kernel module $* $(hide) mkdir -p $(@D) && $(ACP) -fr $(EXTRA_KERNEL_MODULE_PATH_$*) $(@D) - $(mk_kernel) M=$(abspath $@) modules + $(mk_kernel) M=$(abspath $@) modules || ( rm -rf $@ && exit 1 ) -$(KERNEL_MODULES_DEP): $(INSTALLED_KERNEL_TARGET) $(ALL_EXTRA_MODULES) +$(KERNEL_MODULES_DEP): $(BUILT_KERNEL_TARGET) $(ALL_EXTRA_MODULES) $(hide) rm -rf $(TARGET_OUT)/lib/modules $(mk_kernel) INSTALL_MOD_PATH=$(abspath $(TARGET_OUT)) modules_install + $(hide) for kmod in $(TARGET_EXTRA_KERNEL_MODULES) ; do \ @@ -78,29 +91,21 @@ endif $(BUILT_SYSTEMIMAGE): $(KERNEL_MODULES_DEP) -# rules to get source of Broadcom 802.11a/b/g/n hybrid device driver -# based on broadcomsetup.sh of Kyle Evans -WL_PATH := $(KERNEL_DIR)/drivers/net/wireless/broadcom/wl -ifeq ($(wildcard $(WL_PATH)/build.mk),) -WL_PATH := $(KERNEL_DIR)/drivers/net/wireless/wl -endif --include $(WL_PATH)/build.mk - installclean: FILES += $(KBUILD_OUTPUT) $(INSTALLED_KERNEL_TARGET) -TARGET_PREBUILT_KERNEL := $(INSTALLED_KERNEL_TARGET) +TARGET_PREBUILT_KERNEL := $(BUILT_KERNEL_TARGET) .PHONY: kernel $(if $(KERNEL_ARCH_CHANGED),$(KERNEL_HEADERS_COMMON)/linux/binder.h) -kernel: $(TARGET_PREBUILT_KERNEL) +kernel: $(INSTALLED_KERNEL_TARGET) $(KERNEL_MODULES_DEP) -else +endif # TARGET_PREBUILT_KERNEL +ifndef LINEAGE_BUILD $(INSTALLED_KERNEL_TARGET): $(TARGET_PREBUILT_KERNEL) | $(ACP) $(copy-file-to-new-target) ifdef TARGET_PREBUILT_MODULES mkdir -p $(TARGET_OUT)/lib $(hide) cp -r $(TARGET_PREBUILT_MODULES) $(TARGET_OUT)/lib endif - -endif # TARGET_PREBUILT_KERNEL +endif # LINEAGE_BUILD endif # KBUILD_OUTPUT