123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213 |
- # We can build either as part of a standalone Kernel build or as
- # an external module. Determine which mechanism is being used
- ifeq ($(MODNAME),)
- KERNEL_BUILD := 1
- else
- KERNEL_BUILD := 0
- endif
- # These are configurable via Kconfig for kernel-based builds
- # Need to explicitly configure for Android-based builds
- KDIR := $(TOP)/kernel/msm-5.4
- ifeq ($(KERNEL_BUILD), 1)
- AUDIO_ROOT := $(KDIR)/techpack/audio
- endif
- ifeq ($(CONFIG_SND_SOC_AUTO), y)
- ifdef CONFIG_SND_SOC_SA8155
- include $(AUDIO_ROOT)/config/sa8155auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sa8155autoconf.h
- endif
- ifdef CONFIG_SND_SOC_SA6155
- include $(AUDIO_ROOT)/config/sa6155auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sa6155autoconf.h
- endif
- ifdef CONFIG_SND_SOC_GVM
- include $(AUDIO_ROOT)/config/gvmauto.conf
- INCS += -include $(AUDIO_ROOT)/config/gvmautoconf.h
- endif
- ifdef CONFIG_SND_SOC_SA7255
- include $(AUDIO_ROOT)/config/sa7255auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sa7255autoconf.h
- endif
- else
- ifeq ($(KERNEL_BUILD), 0)
- ifeq ($(CONFIG_ARCH_SM6150), y)
- ifdef CONFIG_SND_SOC_SA6155
- include $(AUDIO_ROOT)/config/sa6155auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sa6155autoconf.h
- else
- include $(AUDIO_ROOT)/config/sm6150auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sm6150autoconf.h
- endif
- endif
- ifeq ($(CONFIG_ARCH_TRINKET), y)
- include $(AUDIO_ROOT)/config/sm6150auto.conf
- export
- INCS += -include $(AUDIO_ROOT)/config/sm6150autoconf.h
- endif
- ifeq ($(CONFIG_ARCH_KONA), y)
- include $(AUDIO_ROOT)/config/konaauto.conf
- INCS += -include $(AUDIO_ROOT)/config/konaautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_WAIPIO), y)
- include $(AUDIO_ROOT)/config/waipioauto.conf
- INCS += -include $(AUDIO_ROOT)/config/waipioautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_KALAMA), y)
- include $(AUDIO_ROOT)/config/kalamaauto.conf
- INCS += -include $(AUDIO_ROOT)/config/kalamaautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_PINEAPPLE), y)
- include $(AUDIO_ROOT)/config/pineappleauto.conf
- INCS += -include $(AUDIO_ROOT)/config/pineappleautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_PITTI), y)
- include $(AUDIO_ROOT)/config/pittiauto.conf
- INCS += -include $(AUDIO_ROOT)/config/pittiautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_LITO), y)
- include $(AUDIO_ROOT)/config/litoauto.conf
- export
- INCS += -include $(AUDIO_ROOT)/config/litoautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_KHAJE), y)
- include $(AUDIO_ROOT)/config/bengalauto.conf
- export
- INCS += -include $(AUDIO_ROOT)/config/bengalautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_HOLI), y)
- include $(AUDIO_ROOT)/config/holiauto.conf
- INCS += -include $(AUDIO_ROOT)/config/holiautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_BLAIR), y)
- include $(AUDIO_ROOT)/config/holiauto.conf
- INCS += -include $(AUDIO_ROOT)/config/holiautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_SM8150), y)
- ifdef CONFIG_SND_SOC_SA8155
- include $(AUDIO_ROOT)/config/sa8155auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sa8155autoconf.h
- else
- include $(AUDIO_ROOT)/config/sm8150auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sm8150autoconf.h
- endif
- endif
- ifeq ($(CONFIG_ARCH_QCS405), y)
- include $(AUDIO_ROOT)/config/qcs405auto.conf
- export
- INCS += -include $(AUDIO_ROOT)/config/qcs405autoconf.h
- endif
- ifeq ($(CONFIG_ARCH_SDMSHRIKE), y)
- ifdef CONFIG_SND_SOC_SA8155
- include $(AUDIO_ROOT)/config/sa8155auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sa8155autoconf.h
- else
- include $(AUDIO_ROOT)/config/sm8150auto.conf
- INCS += -include $(AUDIO_ROOT)/config/sm8150autoconf.h
- endif
- endif
- ifeq ($(CONFIG_QTI_QUIN_GVM), y)
- include $(AUDIO_ROOT)/config/gvmauto.conf
- INCS += -include $(AUDIO_ROOT)/config/gvmautoconf.h
- endif
- ifeq ($(CONFIG_ARCH_SDXLEMUR), y)
- include $(AUDIO_ROOT)/config/sdxlemurauto.conf
- export
- INCS += -include $(AUDIO_ROOT)/config/sdxlemurautoconf.h
- endif
- endif
- endif
- # As per target team, build is done as follows:
- # Defconfig : build with default flags
- # Slub : defconfig + CONFIG_SLUB_DEBUG := y +
- # CONFIG_SLUB_DEBUG_ON := y + CONFIG_PAGE_POISONING := y
- # Perf : Using appropriate msmXXXX-perf_defconfig
- #
- # Shipment builds (user variants) should not have any debug feature
- # enabled. This is identified using 'TARGET_BUILD_VARIANT'. Slub builds
- # are identified using the CONFIG_SLUB_DEBUG_ON configuration. Since
- # there is no other way to identify defconfig builds, QTI internal
- # representation of perf builds (identified using the string 'perf'),
- # is used to identify if the build is a slub or defconfig one. This
- # way no critical debug feature will be enabled for perf and shipment
- # builds. Other OEMs are also protected using the TARGET_BUILD_VARIANT
- # config.
- ############ UAPI ############
- UAPI_DIR := uapi/audio
- UAPI_INC := -I$(AUDIO_ROOT)/include/$(UAPI_DIR)
- ############ COMMON ############
- COMMON_DIR := include
- COMMON_INC := -I$(AUDIO_ROOT)/$(COMMON_DIR)
- ############ IPC ############
- ifdef CONFIG_MSM_QDSP6_GPR_RPMSG
- GPRV_GLINK += gpr-lite.o
- endif
- ifdef CONFIG_AUDIO_PKT
- AUDIO_PKT += audio-pkt.o
- endif
- LINUX_INC += -Iinclude/linux
- INCS += $(COMMON_INC) \
- $(UAPI_INC)
- EXTRA_CFLAGS += $(INCS)
- CDEFINES += -DANI_LITTLE_BYTE_ENDIAN \
- -DANI_LITTLE_BIT_ENDIAN \
- -DDOT11F_LITTLE_ENDIAN_HOST \
- -DANI_COMPILER_TYPE_GCC \
- -DANI_OS_TYPE_ANDROID=6 \
- -DPTT_SOCK_SVC_ENABLE \
- -Wall\
- -Werror\
- -D__linux__
- KBUILD_CPPFLAGS += $(CDEFINES)
- # Currently, for versions of gcc which support it, the kernel Makefile
- # is disabling the maybe-uninitialized warning. Re-enable it for the
- # AUDIO driver. Note that we must use EXTRA_CFLAGS here so that it
- # will override the kernel settings.
- ifeq ($(call cc-option-yn, -Wmaybe-uninitialized),y)
- EXTRA_CFLAGS += -Wmaybe-uninitialized
- endif
- #EXTRA_CFLAGS += -Wmissing-prototypes
- ifeq ($(call cc-option-yn, -Wheader-guard),y)
- EXTRA_CFLAGS += -Wheader-guard
- endif
- # If the module name is not "wlan", then the define MULTI_IF_NAME to be the
- # same a the QCA CHIP name. The host driver will then append MULTI_IF_NAME to
- # any string that must be unique for all instances of the driver on the system.
- # This allows multiple instances of the driver with different module names.
- # If the module name is wlan, leave MULTI_IF_NAME undefined and the code will
- # treat the driver as the primary driver.
- ifneq ($(MODNAME), qdsp6v2)
- CHIP_NAME ?= $(MODNAME)
- CDEFINES += -DMULTI_IF_NAME=\"$(CHIP_NAME)\"
- endif
- ifeq ($(CONFIG_SND_SOC_GCOV), y)
- GCOV_PROFILE := y
- endif
- # Module information used by KBuild framework
- obj-$(CONFIG_MSM_QDSP6_GPR_RPMSG) += gpr_dlkm.o
- gpr_dlkm-y := $(GPRV_GLINK)
- obj-$(CONFIG_AUDIO_PKT) += audio_pkt_dlkm.o
- audio_pkt_dlkm-y := $(AUDIO_PKT)
- # inject some build related information
- CDEFINES += -DBUILD_TIMESTAMP=\"$(shell date -u +'%Y-%m-%dT%H:%M:%SZ')\"
|