# # Platform Makefile # include $(CHRE_PREFIX)/external/flatbuffers/flatbuffers.mk # Common Compiler Flags ######################################################## # Include paths. COMMON_CFLAGS += -Iplatform/include # Common Compiler Flags ######################################################## # Common Source Files ########################################################## COMMON_SRCS += platform/shared/platform_sensor_util.cc # SLPI-specific Compiler Flags ################################################# # Include paths. SLPI_CFLAGS += -I$(SLPI_PREFIX)/build/ms SLPI_CFLAGS += -I$(SLPI_PREFIX)/build/cust SLPI_CFLAGS += -I$(SLPI_PREFIX)/core/api/debugtools SLPI_CFLAGS += -I$(SLPI_PREFIX)/core/api/services SLPI_CFLAGS += -I$(SLPI_PREFIX)/core/api/kernel/devcfg SLPI_CFLAGS += -I$(SLPI_PREFIX)/core/api/kernel/qurt SLPI_CFLAGS += -I$(SLPI_PREFIX)/core/api/dal SLPI_CFLAGS += -I$(SLPI_PREFIX)/core/api/mproc SLPI_CFLAGS += -I$(SLPI_PREFIX)/core/api/systemdrivers SLPI_CFLAGS += -I$(SLPI_PREFIX)/platform/inc SLPI_CFLAGS += -I$(SLPI_PREFIX)/platform/inc/HAP SLPI_CFLAGS += -I$(SLPI_PREFIX)/platform/inc/a1std SLPI_CFLAGS += -I$(SLPI_PREFIX)/platform/inc/stddef SLPI_CFLAGS += -I$(SLPI_PREFIX)/platform/rtld/inc SLPI_CFLAGS += -Iplatform/shared/include SLPI_CFLAGS += -Iplatform/slpi/include # We use FlatBuffers in the SLPI platform layer SLPI_CFLAGS += $(FLATBUFFERS_CFLAGS) ifneq ($(CHRE_ENABLE_ACCEL_CAL), false) SLPI_CFLAGS += -DCHRE_ENABLE_ACCEL_CAL endif ifneq ($(CHRE_ENABLE_ASH_DEBUG_DUMP), false) SLPI_CFLAGS += -DCHRE_ENABLE_ASH_DEBUG_DUMP endif # SLPI/SMGR-specific Compiler Flags ############################################ # Include paths. SLPI_SMGR_CFLAGS += -I$(SLPI_PREFIX)/Sensors/api SLPI_SMGR_CFLAGS += -I$(SLPI_PREFIX)/Sensors/common/idl/inc SLPI_SMGR_CFLAGS += -I$(SLPI_PREFIX)/Sensors/common/inc SLPI_SMGR_CFLAGS += -I$(SLPI_PREFIX)/Sensors/common/smr/inc SLPI_SMGR_CFLAGS += -I$(SLPI_PREFIX)/Sensors/common/util/mathtools/inc SLPI_SMGR_CFLAGS += -I$(SLPI_PREFIX)/Sensors/goog/api SLPI_SMGR_CFLAGS += -I$(SLPI_PREFIX)/Sensors/pm/inc SLPI_SMGR_CFLAGS += -Iplatform/slpi/smgr/include SLPI_SMGR_CFLAGS += -DCHRE_SLPI_SMGR # SLPI/SEE-specific Compiler Flags ############################################# # Include paths. SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/chre/chre/src/system/chre/platform/slpi SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/core/api/kernel/libstd/stringl SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/qmimsgs/common/api SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/ssc_api/pb SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/ssc/framework/cm/inc SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/ssc/goog/api SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/ssc/inc SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/ssc/inc/internal SLPI_SEE_CFLAGS += -I$(SLPI_PREFIX)/ssc/inc/utils/nanopb SLPI_SEE_CFLAGS += -Iplatform/slpi/see/include SLPI_SEE_CFLAGS += -DCHRE_SLPI_SEE # Needed to define __SIZEOF_ATTR_THREAD in sns_osa_thread.h, included in # sns_memmgr.h. SLPI_SEE_CFLAGS += -DSSC_TARGET_HEXAGON # Defined in slpi_proc/ssc/build/ssc.scons SLPI_SEE_CFLAGS += -DPB_FIELD_16BIT ifeq ($(IMPORT_CHRE_UTILS), true) SLPI_SEE_CFLAGS += -DIMPORT_CHRE_UTILS endif # SLPI-specific Source Files ################################################### SLPI_SRCS += platform/shared/chre_api_audio.cc SLPI_SRCS += platform/shared/chre_api_core.cc SLPI_SRCS += platform/shared/chre_api_gnss.cc SLPI_SRCS += platform/shared/chre_api_re.cc SLPI_SRCS += platform/shared/chre_api_sensor.cc SLPI_SRCS += platform/shared/chre_api_version.cc SLPI_SRCS += platform/shared/chre_api_wifi.cc SLPI_SRCS += platform/shared/chre_api_wwan.cc SLPI_SRCS += platform/shared/host_protocol_chre.cc SLPI_SRCS += platform/shared/host_protocol_common.cc SLPI_SRCS += platform/shared/memory_manager.cc SLPI_SRCS += platform/shared/nanoapp/nanoapp_dso_util.cc SLPI_SRCS += platform/shared/pal_system_api.cc SLPI_SRCS += platform/shared/system_time.cc SLPI_SRCS += platform/slpi/chre_api_re.cc SLPI_SRCS += platform/slpi/debug_dump.cc SLPI_SRCS += platform/slpi/host_link.cc SLPI_SRCS += platform/slpi/init.cc SLPI_SRCS += platform/slpi/memory.cc SLPI_SRCS += platform/slpi/memory_manager.cc SLPI_SRCS += platform/slpi/nanoapp_load_manager.cc SLPI_SRCS += platform/slpi/platform_nanoapp.cc SLPI_SRCS += platform/slpi/platform_pal.cc SLPI_SRCS += platform/slpi/system_time.cc SLPI_SRCS += platform/slpi/system_time_util.cc SLPI_SRCS += platform/slpi/system_timer.cc # Optional audio support. ifeq ($(CHRE_AUDIO_SUPPORT_ENABLED), true) SLPI_SRCS += platform/slpi/platform_audio.cc endif # Optional GNSS support. ifeq ($(CHRE_GNSS_SUPPORT_ENABLED), true) SLPI_SRCS += platform/shared/platform_gnss.cc endif # Optional Wi-Fi support. ifeq ($(CHRE_WIFI_SUPPORT_ENABLED), true) SLPI_SRCS += platform/shared/platform_wifi.cc endif # Optional WWAN support. ifeq ($(CHRE_WWAN_SUPPORT_ENABLED), true) SLPI_SRCS += platform/shared/platform_wwan.cc endif # SLPI/SMGR-specific Source Files ############################################## SLPI_SMGR_SRCS += platform/slpi/smgr/platform_sensor.cc SLPI_SMGR_SRCS += platform/slpi/smgr/platform_sensor_util.cc SLPI_SMGR_SRCS += platform/slpi/smgr/power_control_manager.cc SLPI_SMGR_SRCS += platform/slpi/smgr/smr_helper.cc # SLPI/SEE-specific Source Files ############################################### SLPI_SEE_SRCS += platform/slpi/see/platform_sensor.cc SLPI_SEE_SRCS += platform/slpi/see/power_control_manager.cc ifneq ($(IMPORT_CHRE_UTILS), true) SLPI_SEE_SRCS += platform/slpi/see/island_vote_client.cc SLPI_SEE_SRCS += platform/slpi/see/see_cal_helper.cc SLPI_SEE_SRCS += platform/slpi/see/see_helper.cc endif SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_client.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_suid.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_cal.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_physical_sensor_test.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_proximity.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_remote_proc_state.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_resampler.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_std.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_std_sensor.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc_api/pb/sns_std_type.pb.c SLPI_SEE_QSK_SRCS += $(SLPI_PREFIX)/chre/chre/src/system/chre/platform/slpi/sns_qmi_client_alt.c SLPI_SEE_QMI_SRCS += $(SLPI_PREFIX)/chre/chre/src/system/chre/platform/slpi/sns_qmi_client.c # Simulator-specific Compiler Flags ############################################ SIM_CFLAGS += -Iplatform/shared/include # Simulator-specific Source Files ############################################## SIM_SRCS += platform/linux/chre_api_re.cc SIM_SRCS += platform/linux/context.cc SIM_SRCS += platform/linux/fatal_error.cc SIM_SRCS += platform/linux/host_link.cc SIM_SRCS += platform/linux/memory.cc SIM_SRCS += platform/linux/memory_manager.cc SIM_SRCS += platform/linux/platform_log.cc SIM_SRCS += platform/linux/platform_pal.cc SIM_SRCS += platform/linux/power_control_manager.cc SIM_SRCS += platform/linux/system_time.cc SIM_SRCS += platform/linux/system_timer.cc SIM_SRCS += platform/linux/platform_nanoapp.cc SIM_SRCS += platform/linux/platform_sensor.cc SIM_SRCS += platform/shared/chre_api_audio.cc SIM_SRCS += platform/shared/chre_api_core.cc SIM_SRCS += platform/shared/chre_api_gnss.cc SIM_SRCS += platform/shared/chre_api_re.cc SIM_SRCS += platform/shared/chre_api_sensor.cc SIM_SRCS += platform/shared/chre_api_version.cc SIM_SRCS += platform/shared/chre_api_wifi.cc SIM_SRCS += platform/shared/chre_api_wwan.cc SIM_SRCS += platform/shared/memory_manager.cc SIM_SRCS += platform/shared/nanoapp/nanoapp_dso_util.cc SIM_SRCS += platform/shared/pal_system_api.cc SIM_SRCS += platform/shared/system_time.cc # Optional GNSS support. ifeq ($(CHRE_GNSS_SUPPORT_ENABLED), true) SIM_SRCS += platform/shared/pal_gnss_stub.cc SIM_SRCS += platform/shared/platform_gnss.cc endif # Optional Wi-Fi support. ifeq ($(CHRE_WIFI_SUPPORT_ENABLED), true) SIM_SRCS += platform/shared/pal_wifi_stub.cc SIM_SRCS += platform/shared/platform_wifi.cc endif # Optional WWAN support. ifeq ($(CHRE_WWAN_SUPPORT_ENABLED), true) SIM_SRCS += platform/shared/pal_wwan_stub.cc SIM_SRCS += platform/shared/platform_wwan.cc endif # Linux-specific Compiler Flags ################################################ GOOGLE_X86_LINUX_CFLAGS += -Iplatform/linux/include # Linux-specific Source Files ################################################## GOOGLE_X86_LINUX_SRCS += platform/linux/init.cc # Optional audio support. ifeq ($(CHRE_AUDIO_SUPPORT_ENABLED), true) GOOGLE_X86_LINUX_SRCS += platform/linux/audio_source.cc GOOGLE_X86_LINUX_SRCS += platform/linux/platform_audio.cc endif # Android-specific Compiler Flags ############################################## # Add the Android include search path for Android-specific header files. GOOGLE_ARM64_ANDROID_CFLAGS += -Iplatform/android/include # Add in host sources to allow the executable to both be a socket server and # CHRE implementation. GOOGLE_ARM64_ANDROID_CFLAGS += -I$(ANDROID_BUILD_TOP)/system/core/base/include GOOGLE_ARM64_ANDROID_CFLAGS += -I$(ANDROID_BUILD_TOP)/system/core/libcutils/include GOOGLE_ARM64_ANDROID_CFLAGS += -I$(ANDROID_BUILD_TOP)/system/core/libutils/include GOOGLE_ARM64_ANDROID_CFLAGS += -I$(ANDROID_BUILD_TOP)/system/core/liblog/include GOOGLE_ARM64_ANDROID_CFLAGS += -Ihost/common/include # Also add the linux sources to fall back to the default Linux implementation. GOOGLE_ARM64_ANDROID_CFLAGS += -Iplatform/linux/include # We use FlatBuffers in the Android simulator GOOGLE_ARM64_ANDROID_CFLAGS += -I$(FLATBUFFERS_PATH)/include # Android-specific Source Files ################################################ ANDROID_CUTILS_TOP = $(ANDROID_BUILD_TOP)/system/core/libcutils ANDROID_LOG_TOP = $(ANDROID_BUILD_TOP)/system/core/liblog GOOGLE_ARM64_ANDROID_SRCS += $(ANDROID_CUTILS_TOP)/sockets_unix.cpp GOOGLE_ARM64_ANDROID_SRCS += $(ANDROID_CUTILS_TOP)/android_get_control_file.cpp GOOGLE_ARM64_ANDROID_SRCS += $(ANDROID_CUTILS_TOP)/socket_local_server_unix.cpp GOOGLE_ARM64_ANDROID_SRCS += $(ANDROID_CUTILS_TOP)/socket_local_client_unix.cpp GOOGLE_ARM64_ANDROID_SRCS += $(ANDROID_LOG_TOP)/logd_reader.c GOOGLE_ARM64_ANDROID_SRCS += platform/android/init.cc GOOGLE_ARM64_ANDROID_SRCS += platform/android/host_link.cc GOOGLE_ARM64_ANDROID_SRCS += platform/shared/host_protocol_common.cc GOOGLE_ARM64_ANDROID_SRCS += host/common/host_protocol_host.cc GOOGLE_ARM64_ANDROID_SRCS += host/common/socket_server.cc # Optional audio support. ifeq ($(CHRE_AUDIO_SUPPORT_ENABLED), true) GOOGLE_ARM64_ANDROID_SRCS += platform/android/platform_audio.cc endif # GoogleTest Compiler Flags #################################################### # The order here is important so that the googletest target prefers shared, # linux and then SLPI. GOOGLETEST_CFLAGS += -Iplatform/shared/include GOOGLETEST_CFLAGS += -Iplatform/linux/include GOOGLETEST_CFLAGS += -Iplatform/slpi/include # GoogleTest Source Files ###################################################### GOOGLETEST_COMMON_SRCS += platform/linux/assert.cc GOOGLETEST_COMMON_SRCS += platform/linux/audio_source.cc GOOGLETEST_COMMON_SRCS += platform/linux/platform_audio.cc GOOGLETEST_SRCS += platform/slpi/smgr/platform_sensor_util.cc GOOGLETEST_SRCS += platform/slpi/smgr/tests/platform_sensor_util_test.cc