|
| 1 | +# Android makefile for the WLAN Module |
| 2 | + |
| 3 | +# Assume no targets will be supported |
| 4 | +WLAN_CHIPSET := |
| 5 | + |
| 6 | +# Build/Package options for 8960 target |
| 7 | +ifeq ($(TARGET_BOARD_PLATFORM),msm8960) |
| 8 | +WLAN_CHIPSET := prima |
| 9 | +WLAN_SELECT := CONFIG_PRIMA_WLAN=m |
| 10 | +endif |
| 11 | + |
| 12 | +# Build/Package options for 8916, 8974, 8226, 8610, 8909, 8952, 8937, 8953 targets |
| 13 | +ifneq (,$(filter msm8916 msm8974 msm8226 msm8610 msm8909 msm8952 msm8937 msm8953 titanium,$(TARGET_BOARD_PLATFORM))) |
| 14 | +ifneq ($(TARGET_SUPPORTS_ANDROID_WEAR_KERNEL_4_14),true) |
| 15 | +WLAN_CHIPSET := pronto |
| 16 | +WLAN_SELECT := CONFIG_PRONTO_WLAN=m |
| 17 | +endif |
| 18 | +endif |
| 19 | + |
| 20 | +# Build/Package only in case of supported target |
| 21 | +ifneq ($(WLAN_CHIPSET),) |
| 22 | + |
| 23 | +LOCAL_PATH := $(call my-dir) |
| 24 | + |
| 25 | +ifeq ($(TARGET_SUPPORTS_WEARABLES),true) |
| 26 | +ifneq ($(findstring device,$(LOCAL_PATH)),) |
| 27 | + WLAN_DLKM := 1 |
| 28 | +else |
| 29 | +ifneq ($(findstring vendor,$(LOCAL_PATH)),) |
| 30 | + WLAN_DLKM := 1 |
| 31 | +else |
| 32 | + WLAN_DLKM := 0 |
| 33 | +endif # findstring device |
| 34 | +endif |
| 35 | +else |
| 36 | +ifneq ($(findstring vendor,$(LOCAL_PATH)),) |
| 37 | + WLAN_DLKM := 1 |
| 38 | +else |
| 39 | + WLAN_DLKM := 0 |
| 40 | +endif # findstring vendor |
| 41 | +endif # TARGET_SUPPORTS_WEARABLES |
| 42 | + |
| 43 | +# This makefile is only for DLKM |
| 44 | +ifeq ($(WLAN_DLKM),1) |
| 45 | + |
| 46 | +# Determine if we are Proprietary or Open Source |
| 47 | +ifneq ($(findstring opensource,$(LOCAL_PATH)),) |
| 48 | + WLAN_PROPRIETARY := 0 |
| 49 | +else |
| 50 | + WLAN_PROPRIETARY := 1 |
| 51 | +endif |
| 52 | + |
| 53 | +# DLKM_DIR was moved for JELLY_BEAN (PLATFORM_SDK 16) |
| 54 | +ifeq (1,$(filter 1,$(shell echo "$$(( $(PLATFORM_SDK_VERSION) >= 16 ))" ))) |
| 55 | +ifneq ($(TARGET_SUPPORTS_WEARABLES),true) |
| 56 | + DLKM_DIR := $(TOP)/device/qcom/common/dlkm |
| 57 | +else |
| 58 | + DLKM_DIR := $(BOARD_DLKM_DIR) |
| 59 | +endif |
| 60 | +else |
| 61 | + DLKM_DIR := build/dlkm |
| 62 | +endif |
| 63 | + |
| 64 | +# Copy WCNSS_cfg.dat file from firmware_bin/ folder to target out directory. |
| 65 | +ifeq ($(WLAN_PROPRIETARY),0) |
| 66 | + |
| 67 | +$(shell mkdir -p $(TARGET_OUT_ETC)/firmware/wlan/prima) |
| 68 | +$(shell rm -f $(TARGET_OUT_ETC)/firmware/wlan/prima/WCNSS_cfg.dat) |
| 69 | +$(shell cp $(LOCAL_PATH)/firmware_bin/WCNSS_cfg.dat $(TARGET_OUT_ETC)/firmware/wlan/prima) |
| 70 | + |
| 71 | +else |
| 72 | + |
| 73 | +include $(CLEAR_VARS) |
| 74 | +LOCAL_MODULE := WCNSS_qcom_wlan_nv.bin |
| 75 | +LOCAL_MODULE_TAGS := optional |
| 76 | +LOCAL_MODULE_CLASS := ETC |
| 77 | +LOCAL_MODULE_PATH := $(PRODUCT_OUT)/persist |
| 78 | +LOCAL_SRC_FILES := firmware_bin/$(LOCAL_MODULE) |
| 79 | +include $(BUILD_PREBUILT) |
| 80 | + |
| 81 | +include $(CLEAR_VARS) |
| 82 | +LOCAL_MODULE := WCNSS_cfg.dat |
| 83 | +LOCAL_MODULE_TAGS := optional |
| 84 | +LOCAL_MODULE_CLASS := ETC |
| 85 | +LOCAL_MODULE_PATH := $(TARGET_OUT_ETC)/firmware/wlan/prima |
| 86 | +LOCAL_SRC_FILES := firmware_bin/$(LOCAL_MODULE) |
| 87 | +include $(BUILD_PREBUILT) |
| 88 | + |
| 89 | +include $(CLEAR_VARS) |
| 90 | +LOCAL_MODULE := WCNSS_qcom_cfg.ini |
| 91 | +LOCAL_MODULE_TAGS := optional |
| 92 | +LOCAL_MODULE_CLASS := ETC |
| 93 | +LOCAL_MODULE_PATH := $(PRODUCT_OUT)/persist |
| 94 | +LOCAL_SRC_FILES := firmware_bin/$(LOCAL_MODULE) |
| 95 | +include $(BUILD_PREBUILT) |
| 96 | + |
| 97 | +endif |
| 98 | + |
| 99 | +ifeq ($(TARGET_KERNEL_VERSION),) |
| 100 | +$(info "WLAN: TARGET_KERNEL_VERSION is not defined, assuming default") |
| 101 | +TARGET_KERNEL_SOURCE := kernel |
| 102 | +KERNEL_TO_BUILD_ROOT_OFFSET := ../ |
| 103 | +endif |
| 104 | + |
| 105 | +ifeq ($(KERNEL_TO_BUILD_ROOT_OFFSET),) |
| 106 | +$(info "WLAN: KERNEL_TO_BUILD_ROOT_OFFSET is not defined, assuming default") |
| 107 | +KERNEL_TO_BUILD_ROOT_OFFSET := ../ |
| 108 | +endif |
| 109 | + |
| 110 | +# Build wlan.ko as either prima_wlan.ko or pronto_wlan.ko |
| 111 | +########################################################### |
| 112 | + |
| 113 | +# This is set once per LOCAL_PATH, not per (kernel) module |
| 114 | + |
| 115 | +ifeq ($(KBUILD_OPTIONS),) |
| 116 | +KBUILD_OPTIONS += WLAN_PROPRIETARY=$(WLAN_PROPRIETARY) |
| 117 | +KBUILD_OPTIONS += TARGET_SUPPORTS_WEARABLES=$(TARGET_SUPPORTS_WEARABLES) |
| 118 | +KBUILD_OPTIONS += KERNEL_TO_BUILD_ROOT_OFFSET=$(KERNEL_TO_BUILD_ROOT_OFFSET) |
| 119 | +endif |
| 120 | + |
| 121 | +# We are actually building wlan.ko here, as per the |
| 122 | +# requirement we are specifying <chipset>_wlan.ko as LOCAL_MODULE. |
| 123 | +# This means we need to rename the module to <chipset>_wlan.ko |
| 124 | +# after wlan.ko is built. |
| 125 | +KBUILD_OPTIONS += MODNAME=wlan |
| 126 | +KBUILD_OPTIONS += BOARD_PLATFORM=$(TARGET_BOARD_PLATFORM) |
| 127 | +KBUILD_OPTIONS += $(WLAN_SELECT) |
| 128 | + |
| 129 | + |
| 130 | +ifeq ($(KERNEL_TO_BUILD_ROOT_OFFSET),../../) |
| 131 | +VERSION=$(shell grep -w "VERSION =" $(TOP)/kernel/msm-$(TARGET_KERNEL_VERSION)/Makefile | sed 's/^VERSION = //' ) |
| 132 | +PATCHLEVEL=$(shell grep -w "PATCHLEVEL =" $(TOP)/kernel/msm-$(TARGET_KERNEL_VERSION)/Makefile | sed 's/^PATCHLEVEL = //' ) |
| 133 | +else |
| 134 | +VERSION=$(shell grep -w "VERSION =" $(TOP)/kernel/Makefile | sed 's/^VERSION = //' ) |
| 135 | +PATCHLEVEL=$(shell grep -w "PATCHLEVEL =" $(TOP)/kernel/Makefile | sed 's/^PATCHLEVEL = //' ) |
| 136 | +endif |
| 137 | + |
| 138 | +include $(CLEAR_VARS) |
| 139 | +LOCAL_MODULE := $(WLAN_CHIPSET)_wlan.ko |
| 140 | +LOCAL_MODULE_KBUILD_NAME := wlan.ko |
| 141 | +LOCAL_MODULE_TAGS := optional |
| 142 | +LOCAL_MODULE_DEBUG_ENABLE := true |
| 143 | +ifeq ($(PRODUCT_VENDOR_MOVE_ENABLED), true) |
| 144 | + ifeq ($(WIFI_DRIVER_INSTALL_TO_KERNEL_OUT),true) |
| 145 | + LOCAL_MODULE_PATH := $(KERNEL_MODULES_OUT) |
| 146 | + else |
| 147 | + LOCAL_MODULE_PATH := $(TARGET_OUT_VENDOR)/lib/modules/$(WLAN_CHIPSET) |
| 148 | + endif |
| 149 | +else |
| 150 | + LOCAL_MODULE_PATH := $(TARGET_OUT)/lib/modules/$(WLAN_CHIPSET) |
| 151 | +endif # PRODUCT_VENDOR_MOVE_ENABLED |
| 152 | +include $(DLKM_DIR)/AndroidKernelModule.mk |
| 153 | +########################################################### |
| 154 | + |
| 155 | +#Create symbolic link |
| 156 | +ifeq ($(PRODUCT_VENDOR_MOVE_ENABLED), true) |
| 157 | +$(shell mkdir -p $(TARGET_OUT_VENDOR)/lib/modules; \ |
| 158 | + ln -sf /$(TARGET_COPY_OUT_VENDOR)/lib/modules/$(WLAN_CHIPSET)/$(WLAN_CHIPSET)_wlan.ko \ |
| 159 | + $(TARGET_OUT_VENDOR)/lib/modules/wlan.ko) |
| 160 | +else |
| 161 | +$(shell mkdir -p $(TARGET_OUT)/lib/modules; \ |
| 162 | + ln -sf /system/lib/modules/$(WLAN_CHIPSET)/$(WLAN_CHIPSET)_wlan.ko \ |
| 163 | + $(TARGET_OUT)/lib/modules/wlan.ko) |
| 164 | +endif # PRODUCT_VENDOR_MOVE_ENABLED |
| 165 | +endif # DLKM check |
| 166 | + |
| 167 | +endif # supported target check |
0 commit comments