Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 1 | # We can build either as part of a standalone Kernel build or as |
| 2 | # an external module. Determine which mechanism is being used |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 3 | ifeq ($(MODNAME),) |
| 4 | KERNEL_BUILD := 1 |
| 5 | else |
| 6 | KERNEL_BUILD := 0 |
| 7 | endif |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 8 | |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 9 | ifeq ($(KERNEL_BUILD), 1) |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 10 | # These are configurable via Kconfig for kernel-based builds |
| 11 | # Need to explicitly configure for Android-based builds |
Piyush Balwani | 677fa73 | 2018-11-30 19:13:42 +0530 | [diff] [blame] | 12 | AUDIO_BLD_DIR := $(shell pwd)/kernel/msm-4.9 |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 13 | AUDIO_ROOT := $(AUDIO_BLD_DIR)/techpack/audio |
| 14 | endif |
| 15 | |
| 16 | ifeq ($(KERNEL_BUILD), 0) |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 17 | ifeq ($(CONFIG_ARCH_SDM845), y) |
| 18 | include $(AUDIO_ROOT)/config/sdm845auto.conf |
| 19 | export |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 20 | INCS += -include $(AUDIO_ROOT)/config/sdm845autoconf.h |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 21 | endif |
| 22 | ifeq ($(CONFIG_ARCH_SDM670), y) |
Aditya Bavanari | 68d3ed8 | 2018-04-08 14:34:47 +0530 | [diff] [blame] | 23 | include $(AUDIO_ROOT)/config/sdm710auto.conf |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 24 | export |
Aditya Bavanari | 68d3ed8 | 2018-04-08 14:34:47 +0530 | [diff] [blame] | 25 | INCS += -include $(AUDIO_ROOT)/config/sdm710autoconf.h |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 26 | endif |
Laxminath Kasam | 942d1c6 | 2017-12-29 11:02:22 +0530 | [diff] [blame] | 27 | ifeq ($(CONFIG_ARCH_SDM450), y) |
Soumya Managoli | eaff662 | 2018-02-23 12:00:54 +0530 | [diff] [blame] | 28 | include $(AUDIO_ROOT)/config/sdm450auto.conf |
Laxminath Kasam | 942d1c6 | 2017-12-29 11:02:22 +0530 | [diff] [blame] | 29 | export |
Soumya Managoli | eaff662 | 2018-02-23 12:00:54 +0530 | [diff] [blame] | 30 | INCS += -include $(AUDIO_ROOT)/config/sdm450autoconf.h |
Laxminath Kasam | 942d1c6 | 2017-12-29 11:02:22 +0530 | [diff] [blame] | 31 | endif |
Vaishnavi Kommaraju | 59562a1 | 2018-04-25 19:33:46 +0530 | [diff] [blame] | 32 | ifeq ($(CONFIG_ARCH_SDM439), y) |
| 33 | include $(AUDIO_ROOT)/config/sdm450auto.conf |
| 34 | export |
| 35 | INCS += -include $(AUDIO_ROOT)/config/sdm450autoconf.h |
| 36 | endif |
Sundara Vinayagam | 3983833 | 2018-05-23 12:04:25 +0530 | [diff] [blame] | 37 | ifeq ($(CONFIG_ARCH_MSM8909), y) |
| 38 | include $(AUDIO_ROOT)/config/msm8909auto.conf |
| 39 | export |
| 40 | INCS += -include $(AUDIO_ROOT)/config/msm8909autoconf.h |
| 41 | endif |
Soumya Managoli | d63fb8e | 2018-05-08 17:28:01 +0530 | [diff] [blame] | 42 | ifeq ($(CONFIG_ARCH_MSM8917), y) |
| 43 | include $(AUDIO_ROOT)/config/sdm450auto.conf |
| 44 | export |
| 45 | INCS += -include $(AUDIO_ROOT)/config/sdm450autoconf.h |
| 46 | endif |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 47 | endif |
| 48 | |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 49 | # As per target team, build is done as follows: |
| 50 | # Defconfig : build with default flags |
| 51 | # Slub : defconfig + CONFIG_SLUB_DEBUG := y + |
| 52 | # CONFIG_SLUB_DEBUG_ON := y + CONFIG_PAGE_POISONING := y |
| 53 | # Perf : Using appropriate msmXXXX-perf_defconfig |
| 54 | # |
| 55 | # Shipment builds (user variants) should not have any debug feature |
| 56 | # enabled. This is identified using 'TARGET_BUILD_VARIANT'. Slub builds |
| 57 | # are identified using the CONFIG_SLUB_DEBUG_ON configuration. Since |
| 58 | # there is no other way to identify defconfig builds, QTI internal |
| 59 | # representation of perf builds (identified using the string 'perf'), |
| 60 | # is used to identify if the build is a slub or defconfig one. This |
| 61 | # way no critical debug feature will be enabled for perf and shipment |
| 62 | # builds. Other OEMs are also protected using the TARGET_BUILD_VARIANT |
| 63 | # config. |
| 64 | |
| 65 | ############ UAPI ############ |
| 66 | UAPI_DIR := uapi |
| 67 | UAPI_INC := -I$(AUDIO_ROOT)/include/$(UAPI_DIR) |
| 68 | |
| 69 | ############ COMMON ############ |
| 70 | COMMON_DIR := include |
| 71 | COMMON_INC := -I$(AUDIO_ROOT)/$(COMMON_DIR) |
| 72 | |
| 73 | ############ SoC Modules ############ |
| 74 | |
| 75 | # for pinctrl WCD driver |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 76 | ifdef CONFIG_PINCTRL_WCD |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 77 | PINCTRL_WCD_OBJS += pinctrl-wcd.o |
| 78 | endif |
| 79 | |
| 80 | # for pinctrl LPI driver |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 81 | ifdef CONFIG_PINCTRL_LPI |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 82 | PINCTRL_LPI_OBJS += pinctrl-lpi.o |
| 83 | endif |
| 84 | |
| 85 | # for soundwire driver |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 86 | ifdef CONFIG_SOUNDWIRE_WCD_CTRL |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 87 | SWR_CTRL_OBJS += swr-wcd-ctrl.o |
| 88 | endif |
| 89 | |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 90 | ifdef CONFIG_SOUNDWIRE |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 91 | SWR_OBJS += regmap-swr.o |
| 92 | SWR_OBJS += soundwire.o |
| 93 | endif |
| 94 | |
| 95 | LINUX_INC += -Iinclude/linux |
| 96 | |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 97 | INCS += $(COMMON_INC) \ |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 98 | $(UAPI_INC) |
| 99 | |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 100 | EXTRA_CFLAGS += $(INCS) |
| 101 | |
| 102 | |
| 103 | CDEFINES += -DANI_LITTLE_BYTE_ENDIAN \ |
| 104 | -DANI_LITTLE_BIT_ENDIAN \ |
| 105 | -DDOT11F_LITTLE_ENDIAN_HOST \ |
| 106 | -DANI_COMPILER_TYPE_GCC \ |
| 107 | -DANI_OS_TYPE_ANDROID=6 \ |
| 108 | -DPTT_SOCK_SVC_ENABLE \ |
| 109 | -Wall\ |
| 110 | -Werror\ |
| 111 | -D__linux__ |
| 112 | |
| 113 | KBUILD_CPPFLAGS += $(CDEFINES) |
| 114 | |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 115 | ifeq ($(KERNEL_BUILD), 0) |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 116 | KBUILD_EXTRA_SYMBOLS +=$(OUT)/obj/vendor/qcom/opensource/audio-kernel/dsp/Module.symvers |
Asish Bhattacharya | 5faacb3 | 2017-12-04 17:23:15 +0530 | [diff] [blame] | 117 | endif |
| 118 | |
Laxminath Kasam | 8b1366a | 2017-10-05 01:44:16 +0530 | [diff] [blame] | 119 | # Currently, for versions of gcc which support it, the kernel Makefile |
| 120 | # is disabling the maybe-uninitialized warning. Re-enable it for the |
| 121 | # AUDIO driver. Note that we must use EXTRA_CFLAGS here so that it |
| 122 | # will override the kernel settings. |
| 123 | ifeq ($(call cc-option-yn, -Wmaybe-uninitialized),y) |
| 124 | EXTRA_CFLAGS += -Wmaybe-uninitialized |
| 125 | endif |
| 126 | #EXTRA_CFLAGS += -Wmissing-prototypes |
| 127 | |
| 128 | ifeq ($(call cc-option-yn, -Wheader-guard),y) |
| 129 | EXTRA_CFLAGS += -Wheader-guard |
| 130 | endif |
| 131 | |
| 132 | # Module information used by KBuild framework |
| 133 | obj-$(CONFIG_PINCTRL_WCD) += pinctrl_wcd_dlkm.o |
| 134 | pinctrl_wcd_dlkm-y := $(PINCTRL_WCD_OBJS) |
| 135 | |
| 136 | obj-$(CONFIG_PINCTRL_LPI) += pinctrl_lpi_dlkm.o |
| 137 | pinctrl_lpi_dlkm-y := $(PINCTRL_LPI_OBJS) |
| 138 | |
| 139 | obj-$(CONFIG_SOUNDWIRE) += swr_dlkm.o |
| 140 | swr_dlkm-y := $(SWR_OBJS) |
| 141 | |
| 142 | obj-$(CONFIG_SOUNDWIRE_WCD_CTRL) += swr_ctrl_dlkm.o |
| 143 | swr_ctrl_dlkm-y := $(SWR_CTRL_OBJS) |
| 144 | |
| 145 | # inject some build related information |
| 146 | DEFINES += -DBUILD_TIMESTAMP=\"$(shell date -u +'%Y-%m-%dT%H:%M:%SZ')\" |