123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347 |
- # 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
- ifeq ($(KERNEL_BUILD), 1)
- # These are configurable via Kconfig for kernel-based builds
- # Need to explicitly configure for Android-based builds
- AUDIO_BLD_DIR := $(shell pwd)/kernel/msm-5.4
- AUDIO_ROOT := $(AUDIO_BLD_DIR)/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_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_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 ($(BOARD_PLATFORM), pineapple)
- include $(AUDIO_ROOT)/config/pineappleauto.conf
- INCS += -include $(AUDIO_ROOT)/config/pineappleautoconf.h
- endif
- ifeq ($(BOARD_PLATFORM), cliffs)
- include $(AUDIO_ROOT)/config/pineappleauto.conf
- INCS += -include $(AUDIO_ROOT)/config/pineappleautoconf.h
- endif
- ifeq ($(BOARD_PLATFORM), volcano)
- include $(AUDIO_ROOT)/config/volcanoauto.conf
- INCS += -include $(AUDIO_ROOT)/config/volcanoautoconf.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_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_ARCH_QCS405), y)
- include $(AUDIO_ROOT)/config/qcs405auto.conf
- export
- INCS += -include $(AUDIO_ROOT)/config/qcs405autoconf.h
- 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)
- ############ ASoC Drivers ############
- MACHINE_OBJS += msm_common.o
- # for SM8150 sound card driver
- ifdef CONFIG_SND_SOC_SM8150
- MACHINE_OBJS += sm8150.o
- MACHINE_OBJS += machine_815x_init.o
- endif
- # for SM6150 sound card driver
- ifdef CONFIG_SND_SOC_SM6150
- MACHINE_OBJS += sm6150.o
- MACHINE_OBJS += machine_615x_init.o
- endif
- # For sa6155 sound card driver
- ifdef CONFIG_SND_SOC_SA6155
- MACHINE_OBJS += sa6155.o
- endif
- # for qcs405 sound card driver
- ifdef CONFIG_SND_SOC_QCS405
- MACHINE_OBJS += qcs405.o
- endif
- # for KONA sound card driver
- ifdef CONFIG_SND_SOC_KONA
- MACHINE_OBJS += kona.o
- endif
- # for LAHAINA sound card driver
- ifdef CONFIG_SND_SOC_LAHAINA
- MACHINE_OBJS += lahaina.o
- endif
- # for WAIPIO sound card driver
- ifdef CONFIG_SND_SOC_WAIPIO
- MACHINE_OBJS += waipio.o
- endif
- # for KALAMA sound card driver
- ifdef CONFIG_SND_SOC_KALAMA
- MACHINE_OBJS += kalama.o
- endif
- # for PINEAPPLE sound card driver
- ifdef CONFIG_SND_SOC_PINEAPPLE
- MACHINE_OBJS += pineapple.o
- endif
- # for VOLCANO sound card driver
- ifdef CONFIG_SND_SOC_VOLCANO
- MACHINE_OBJS += pineapple.o
- endif
- # for PITTI sound card driver
- ifdef CONFIG_SND_SOC_PITTI
- MACHINE_OBJS += pineapple.o
- endif
- # for HOLI sound card driver
- ifdef CONFIG_SND_SOC_HOLI
- MACHINE_OBJS += holi.o
- endif
- ifdef CONFIG_SND_SOC_LITO
- MACHINE_OBJS += kona.o
- endif
- # for BENGAL sound card driver
- ifdef CONFIG_SND_SOC_BENGAL
- MACHINE_OBJS += bengal.o
- endif
- # for sa8155 sound card driver
- ifdef CONFIG_SND_SOC_SA8155
- MACHINE_OBJS += sa8155.o
- endif
- # for sa7255 sound card driver
- ifdef CONFIG_SND_SOC_SA7255_AUTO_SPF
- SPF_MACHINE_OBJS += msm_common.o
- SPF_MACHINE_OBJS += auto_spf_dummy.o
- endif
- ifdef CONFIG_SND_SOC_QDSP6V2
- PLATFORM_OBJS += platform_init.o
- endif
- ifdef CONFIG_SND_SOC_SDX
- MACHINE_OBJS += sdx-target.o
- endif
- ifdef CONFIG_SND_SOC_GVM_AUTO_SPF
- SPF_MACHINE_OBJS += gvm_auto_spf_dummy.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
- ifeq ($(KERNEL_BUILD), 1)
- obj-y += codecs/
- endif
- # Module information used by KBuild framework
- obj-$(CONFIG_SND_SOC_QDSP6V2) += platform_dlkm.o
- platform_dlkm-y := $(PLATFORM_OBJS)
- obj-$(CONFIG_SND_SOC_SM8150) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_SM6150) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_SA6155) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_QCS405) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_KONA) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_LAHAINA) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_WAIPIO) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_KALAMA) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_PINEAPPLE) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_VOLCANO) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_PITTI) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_HOLI) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_LITO) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_BENGAL) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_SA8155) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_SDX) += machine_dlkm.o
- machine_dlkm-y := $(MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_GVM_AUTO_SPF) += spf_machine_dlkm.o
- spf_machine_dlkm-y := $(SPF_MACHINE_OBJS)
- obj-$(CONFIG_SND_SOC_SA7255_AUTO_SPF) += spf_machine_dlkm.o
- spf_machine_dlkm-y := $(SPF_MACHINE_OBJS)
- # inject some build related information
- DEFINES += -DBUILD_TIMESTAMP=\"$(shell date -u +'%Y-%m-%dT%H:%M:%SZ')\"
|