# # 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/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) # 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/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 += -I$(SLPI_PREFIX)/ssc/inc/pb SLPI_SEE_CFLAGS += -DCHRE_SLPI_SEE SLPI_SEE_CFLAGS += -DSSC_TARGET_HEXAGON SLPI_SEE_CFLAGS += -DSNS_ISLAND_INCLUDE_QCM # 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/platform_gnss.cc SLPI_SRCS += platform/shared/platform_wifi.cc SLPI_SRCS += platform/shared/platform_wwan.cc SLPI_SRCS += platform/shared/system_time.cc SLPI_SRCS += platform/slpi/chre_api_re.cc SLPI_SRCS += platform/slpi/fatal_error.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/preloaded_nanoapps.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_CFLAGS += -I$(SLPI_PREFIX)/ssc/goog/wcd_spi/api SLPI_SRCS += platform/slpi/platform_audio.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 ############################################### # TODO(P2-c001d8): (b/68860346) replace pb-related source files with exported # symbols. SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/utils/nanopb/src/pb_common.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/utils/nanopb/src/pb_decode.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/utils/nanopb/src/pb_encode.c SLPI_SEE_SRCS += platform/slpi/see/island_vote_client.cc SLPI_SEE_SRCS += platform/slpi/see/platform_sensor.cc SLPI_SEE_SRCS += platform/slpi/see/power_control_manager.cc SLPI_SEE_SRCS += platform/slpi/see/see_helper.cc SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/framework/cm/pb/sns_client.pb.c SLPI_SEE_QSK_SRCS += $(SLPI_PREFIX)/ssc/framework/qcm/pb/sns_client_qsocket.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/framework/suid_sensor/pb/sns_suid.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/sensors/pb/sns_cal.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/sensors/pb/sns_physical_sensor_test.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/sensors/pb/sns_proximity.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/sensors/pb/sns_remote_proc_state.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/sensors/pb/sns_std.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/sensors/pb/sns_std_sensor.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/ssc/sensors/pb/sns_std_type.pb.c SLPI_SEE_SRCS += $(SLPI_PREFIX)/chre/chre/src/system/chre/platform/slpi/sns_osa.c SLPI_SEE_QSK_SRCS += $(SLPI_PREFIX)/chre/chre/src/system/chre/platform/slpi/sns_qsocket_client.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/linux/preloaded_nanoapps.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_gnss_stub.cc SIM_SRCS += platform/shared/pal_wifi_stub.cc SIM_SRCS += platform/shared/pal_wwan_stub.cc SIM_SRCS += platform/shared/pal_system_api.cc SIM_SRCS += platform/shared/platform_gnss.cc SIM_SRCS += platform/shared/platform_wifi.cc SIM_SRCS += platform/shared/platform_wwan.cc SIM_SRCS += platform/shared/system_time.cc # Linux-specific Compiler Flags ################################################ GOOGLE_X86_LINUX_CFLAGS += -Iplatform/linux/include # Linux-specific Source Files ################################################## GOOGLE_X86_LINUX_SRCS += platform/linux/audio_source.cc GOOGLE_X86_LINUX_SRCS += platform/linux/platform_audio.cc GOOGLE_X86_LINUX_SRCS += platform/linux/init.cc # 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. ifneq ($(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_SRCS += platform/linux/assert.cc GOOGLETEST_SRCS += platform/linux/audio_source.cc GOOGLETEST_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