123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250 |
- # 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_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_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_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)
- ############ SoC Modules ############
- # for pinctrl WCD driver
- ifdef CONFIG_PINCTRL_WCD
- PINCTRL_WCD_OBJS += pinctrl-wcd.o
- endif
- # for pinctrl LPI driver
- ifdef CONFIG_PINCTRL_LPI
- PINCTRL_LPI_OBJS += pinctrl-lpi.o
- endif
- # for soundwire driver
- ifdef CONFIG_SOUNDWIRE_WCD_CTRL
- SWR_CTRL_OBJS += swr-wcd-ctrl.o
- endif
- # for new soundwire driver
- ifdef CONFIG_SOUNDWIRE_MSTR_CTRL
- SWR_CTRL_OBJS += swr-mstr-ctrl.o
- endif
- ifdef CONFIG_SOUNDWIRE
- INCS += -include $(KERNEL_SRC)/drivers/base/regmap/internal.h
- SWR_OBJS += regmap-swr.o
- SWR_OBJS += soundwire.o
- endif
- ifdef CONFIG_SND_EVENT
- SND_EVENT_OBJS += snd_event.o
- endif
- ifdef CONFIG_WCD_SPI_AC
- WCD_SPI_ACC_CTL_OBJS += wcd-spi-ac.o
- WCD_SPI_ACC_CTL_OBJS += wcd_spi_ctl_v01.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 ($(CONFIG_SND_SOC_GCOV), y)
- GCOV_PROFILE := y
- endif
- # Module information used by KBuild framework
- obj-$(CONFIG_PINCTRL_WCD) += pinctrl_wcd_dlkm.o
- pinctrl_wcd_dlkm-y := $(PINCTRL_WCD_OBJS)
- obj-$(CONFIG_PINCTRL_LPI) += pinctrl_lpi_dlkm.o
- pinctrl_lpi_dlkm-y := $(PINCTRL_LPI_OBJS)
- obj-$(CONFIG_SOUNDWIRE) += swr_dlkm.o
- swr_dlkm-y := $(SWR_OBJS)
- obj-$(CONFIG_SND_EVENT) += snd_event_dlkm.o
- snd_event_dlkm-y := $(SND_EVENT_OBJS)
- obj-$(CONFIG_SOUNDWIRE_WCD_CTRL) += swr_ctrl_dlkm.o
- obj-$(CONFIG_SOUNDWIRE_MSTR_CTRL) += swr_ctrl_dlkm.o
- swr_ctrl_dlkm-y := $(SWR_CTRL_OBJS)
- obj-$(CONFIG_WCD_SPI_AC) += wcd_spi_acc_ctl_dlkm.o
- wcd_spi_acc_ctl_dlkm-y := $(WCD_SPI_ACC_CTL_OBJS)
- # inject some build related information
- DEFINES += -DBUILD_TIMESTAMP=\"$(shell date -u +'%Y-%m-%dT%H:%M:%SZ')\"
|