blob: 76d9e84175a55343d57c43c04609d217a59d5f0e [file] [log] [blame]
Laxminath Kasam8b1366a2017-10-05 01:44:16 +05301# We can build either as part of a standalone Kernel build or as
2# an external module. Determine which mechanism is being used
Asish Bhattacharya5faacb32017-12-04 17:23:15 +05303ifeq ($(MODNAME),)
4 KERNEL_BUILD := 1
5else
6 KERNEL_BUILD := 0
7endif
Laxminath Kasam8b1366a2017-10-05 01:44:16 +05308
Asish Bhattacharya5faacb32017-12-04 17:23:15 +05309# These are configurable via Kconfig for kernel-based builds
10# Need to explicitly configure for Android-based builds
Meng Wang19fa6de2018-12-20 11:25:47 +080011KDIR := $(TOP)/kernel/msm-4.19
Asish Bhattacharya5faacb32017-12-04 17:23:15 +053012
13ifeq ($(KERNEL_BUILD), 1)
14 AUDIO_ROOT := $(KDIR)/techpack/audio
15endif
Laxminath Kasam8b1366a2017-10-05 01:44:16 +053016
17ifeq ($(KERNEL_BUILD), 0)
Salendarsingh Gaudad978892018-05-14 16:53:09 +053018 ifeq ($(CONFIG_ARCH_SM6150), y)
Rahul Sharmaf53de7f2019-03-03 22:30:47 +053019 ifdef CONFIG_SND_SOC_SA6155
20 include $(AUDIO_ROOT)/config/sa6155auto.conf
21 export
22 INCS += -include $(AUDIO_ROOT)/config/sa6155autoconf.h
23 else
24 include $(AUDIO_ROOT)/config/sm6150auto.conf
25 export
26 INCS += -include $(AUDIO_ROOT)/config/sm6150autoconf.h
27 endif
Salendarsingh Gaudad978892018-05-14 16:53:09 +053028 endif
Hari Veerubhotladcab67c2018-10-14 17:08:35 +053029 ifeq ($(CONFIG_ARCH_TRINKET), y)
30 include $(AUDIO_ROOT)/config/sm6150auto.conf
31 export
32 INCS += -include $(AUDIO_ROOT)/config/sm6150autoconf.h
33 endif
Meng Wangb0e04792018-09-27 18:46:44 +080034 ifeq ($(CONFIG_ARCH_KONA), y)
35 include $(AUDIO_ROOT)/config/konaauto.conf
Meng Wangb0e04792018-09-27 18:46:44 +080036 INCS += -include $(AUDIO_ROOT)/config/konaautoconf.h
37 endif
Vatsal Buchad284ff12019-04-01 15:34:50 +053038 ifeq ($(CONFIG_ARCH_LITO), y)
39 include $(AUDIO_ROOT)/config/litoauto.conf
40 export
41 INCS += -include $(AUDIO_ROOT)/config/litoautoconf.h
42 endif
Laxminath Kasamfdda2d82019-07-31 21:26:30 +053043 ifeq ($(CONFIG_ARCH_BENGAL), y)
44 include $(AUDIO_ROOT)/config/litoauto.conf
45 export
46 INCS += -include $(AUDIO_ROOT)/config/litoautoconf.h
47 endif
Banajit Goswamif58e5fc2018-04-11 14:10:09 -070048 ifeq ($(CONFIG_ARCH_SM8150), y)
Cong Tang1fa4e042018-12-17 19:45:55 +080049 ifdef CONFIG_SND_SOC_SA8155
50 include $(AUDIO_ROOT)/config/sa8155auto.conf
51 export
52 INCS += -include $(AUDIO_ROOT)/config/sa8155autoconf.h
53 else
54 include $(AUDIO_ROOT)/config/sm8150auto.conf
55 export
56 INCS += -include $(AUDIO_ROOT)/config/sm8150autoconf.h
57 endif
Meng Wang5fddb8d2018-01-23 16:56:56 +080058 endif
Mangesh Kunchamwar0bf1f572018-05-24 19:58:42 +053059 ifeq ($(CONFIG_ARCH_QCS405), y)
60 include $(AUDIO_ROOT)/config/qcs405auto.conf
61 export
62 INCS += -include $(AUDIO_ROOT)/config/qcs405autoconf.h
63 endif
Sudheer Papothie3842cf2018-03-31 02:27:42 +053064 ifeq ($(CONFIG_ARCH_SDMSHRIKE), y)
Xiaoyu Ye60c105d2018-04-12 12:43:13 -070065 include $(AUDIO_ROOT)/config/sm8150auto.conf
Sudheer Papothie3842cf2018-03-31 02:27:42 +053066 export
Xiaoyu Ye60c105d2018-04-12 12:43:13 -070067 INCS += -include $(AUDIO_ROOT)/config/sm8150autoconf.h
Sudheer Papothie3842cf2018-03-31 02:27:42 +053068 endif
Timothy Sham4a6979f2019-02-19 12:36:06 -050069 ifeq ($(CONFIG_QTI_GVM), y)
70 include $(AUDIO_ROOT)/config/gvmauto.conf
71 export
72 INCS += -include $(AUDIO_ROOT)/config/gvmautoconf.h
73 endif
Laxminath Kasam8b1366a2017-10-05 01:44:16 +053074endif
75
Laxminath Kasam8b1366a2017-10-05 01:44:16 +053076# As per target team, build is done as follows:
77# Defconfig : build with default flags
78# Slub : defconfig + CONFIG_SLUB_DEBUG := y +
79# CONFIG_SLUB_DEBUG_ON := y + CONFIG_PAGE_POISONING := y
80# Perf : Using appropriate msmXXXX-perf_defconfig
81#
82# Shipment builds (user variants) should not have any debug feature
83# enabled. This is identified using 'TARGET_BUILD_VARIANT'. Slub builds
84# are identified using the CONFIG_SLUB_DEBUG_ON configuration. Since
85# there is no other way to identify defconfig builds, QTI internal
86# representation of perf builds (identified using the string 'perf'),
87# is used to identify if the build is a slub or defconfig one. This
88# way no critical debug feature will be enabled for perf and shipment
89# builds. Other OEMs are also protected using the TARGET_BUILD_VARIANT
90# config.
91
92############ UAPI ############
93UAPI_DIR := uapi
94UAPI_INC := -I$(AUDIO_ROOT)/include/$(UAPI_DIR)
95
96############ COMMON ############
97COMMON_DIR := include
98COMMON_INC := -I$(AUDIO_ROOT)/$(COMMON_DIR)
99
100############ IPC ############
101
Shiv Maliyappanahalli72354822017-11-17 16:07:27 -0800102ifdef CONFIG_MSM_QDSP6_APRV2_RPMSG
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530103APRV_GLINK += apr.o
104APRV_GLINK += apr_v2.o
Shiv Maliyappanahalli72354822017-11-17 16:07:27 -0800105APRV_GLINK += apr_tal_rpmsg.o
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530106endif
107
Shiv Maliyappanahalli72354822017-11-17 16:07:27 -0800108ifdef CONFIG_MSM_QDSP6_APRV3_RPMSG
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530109APRV_GLINK += apr.o
110APRV_GLINK += apr_v3.o
Shiv Maliyappanahalli72354822017-11-17 16:07:27 -0800111APRV_GLINK += apr_tal_rpmsg.o
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530112endif
113
Timothy Sham150c9092019-02-16 02:13:59 -0500114ifdef CONFIG_MSM_QDSP6_APRV2_VM
115APRV_GLINK += apr_vm.o
116APRV_GLINK += apr_v2.o
117endif
118
Asish Bhattacharya5faacb32017-12-04 17:23:15 +0530119ifdef CONFIG_WCD_DSP_GLINK
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530120WDSP_GLINK += wcd-dsp-glink.o
121endif
122
123LINUX_INC += -Iinclude/linux
124
Asish Bhattacharya5faacb32017-12-04 17:23:15 +0530125INCS += $(COMMON_INC) \
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530126 $(UAPI_INC)
127
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530128EXTRA_CFLAGS += $(INCS)
129
130
131CDEFINES += -DANI_LITTLE_BYTE_ENDIAN \
132 -DANI_LITTLE_BIT_ENDIAN \
133 -DDOT11F_LITTLE_ENDIAN_HOST \
134 -DANI_COMPILER_TYPE_GCC \
135 -DANI_OS_TYPE_ANDROID=6 \
136 -DPTT_SOCK_SVC_ENABLE \
137 -Wall\
138 -Werror\
139 -D__linux__
140
141KBUILD_CPPFLAGS += $(CDEFINES)
142
Asish Bhattacharya5faacb32017-12-04 17:23:15 +0530143ifeq ($(KERNEL_BUILD), 0)
Meng Wange61ddb02018-03-07 11:18:35 +0800144KBUILD_EXTRA_SYMBOLS +=$(OUT)/obj/vendor/qcom/opensource/audio-kernel/dsp/Module.symvers
Asish Bhattacharya5faacb32017-12-04 17:23:15 +0530145endif
146
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530147# Currently, for versions of gcc which support it, the kernel Makefile
148# is disabling the maybe-uninitialized warning. Re-enable it for the
149# AUDIO driver. Note that we must use EXTRA_CFLAGS here so that it
150# will override the kernel settings.
151ifeq ($(call cc-option-yn, -Wmaybe-uninitialized),y)
152EXTRA_CFLAGS += -Wmaybe-uninitialized
153endif
154#EXTRA_CFLAGS += -Wmissing-prototypes
155
156ifeq ($(call cc-option-yn, -Wheader-guard),y)
157EXTRA_CFLAGS += -Wheader-guard
158endif
159# If the module name is not "wlan", then the define MULTI_IF_NAME to be the
160# same a the QCA CHIP name. The host driver will then append MULTI_IF_NAME to
161# any string that must be unique for all instances of the driver on the system.
162# This allows multiple instances of the driver with different module names.
163# If the module name is wlan, leave MULTI_IF_NAME undefined and the code will
164# treat the driver as the primary driver.
165ifneq ($(MODNAME), qdsp6v2)
166CHIP_NAME ?= $(MODNAME)
167CDEFINES += -DMULTI_IF_NAME=\"$(CHIP_NAME)\"
168endif
169
Vatsal Bucha1d3f38b2018-08-23 12:45:38 +0530170ifeq ($(CONFIG_SND_SOC_GCOV), y)
171GCOV_PROFILE := y
172endif
173
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530174# Module information used by KBuild framework
Shiv Maliyappanahalli72354822017-11-17 16:07:27 -0800175obj-$(CONFIG_MSM_QDSP6_APRV2_RPMSG) += apr_dlkm.o
176obj-$(CONFIG_MSM_QDSP6_APRV3_RPMSG) += apr_dlkm.o
Timothy Sham150c9092019-02-16 02:13:59 -0500177obj-$(CONFIG_MSM_QDSP6_APRV2_VM) += apr_dlkm.o
Laxminath Kasam8b1366a2017-10-05 01:44:16 +0530178apr_dlkm-y := $(APRV_GLINK)
179
180obj-$(CONFIG_WCD_DSP_GLINK) += wglink_dlkm.o
181wglink_dlkm-y := $(WDSP_GLINK)
182
183# inject some build related information
184CDEFINES += -DBUILD_TIMESTAMP=\"$(shell date -u +'%Y-%m-%dT%H:%M:%SZ')\"