forked from openkylin/platform_build
Merge commit '597cfdb' into merge
Change-Id: I4df718345626439ece9fdad242cccea7d6930819
This commit is contained in:
commit
5c92a46ea3
|
@ -506,6 +506,18 @@ my_generated_sources := $(patsubst $(generated_sources_dir)/%,$(intermediates)/%
|
||||||
|
|
||||||
ALL_GENERATED_SOURCES += $(my_generated_sources)
|
ALL_GENERATED_SOURCES += $(my_generated_sources)
|
||||||
|
|
||||||
|
###########################################################
|
||||||
|
# PROTOC transforms
|
||||||
|
###########################################################
|
||||||
|
|
||||||
|
proto_sources := $(filter %.proto,$(LOCAL_SRC_FILES))
|
||||||
|
|
||||||
|
proto_generated_objects :=
|
||||||
|
proto_generated_headers :=
|
||||||
|
nanopb_c_generated_objects :=
|
||||||
|
nanopb_c_generated_headers :=
|
||||||
|
ifeq (,$(filter nanopb-c nanopb-c-enable_malloc, $(LOCAL_PROTOC_OPTIMIZE_TYPE)))
|
||||||
|
|
||||||
###########################################################
|
###########################################################
|
||||||
## Compile the .proto files to .cc and then to .o
|
## Compile the .proto files to .cc and then to .o
|
||||||
###########################################################
|
###########################################################
|
||||||
|
@ -565,6 +577,47 @@ endif
|
||||||
endif # $(proto_sources) non-empty
|
endif # $(proto_sources) non-empty
|
||||||
|
|
||||||
|
|
||||||
|
else
|
||||||
|
|
||||||
|
###########################################################
|
||||||
|
## Compile the .proto files to .c from nanopb-c and then to .o
|
||||||
|
###########################################################
|
||||||
|
ifneq ($(proto_sources),)
|
||||||
|
nanopb_c_sources_fullpath := $(addprefix $(LOCAL_PATH)/, $(proto_sources))
|
||||||
|
nanopb_c_generated_sources_dir := $(intermediates)/proto
|
||||||
|
nanopb_c_generated_sources := $(addprefix $(nanopb_c_generated_sources_dir)/, \
|
||||||
|
$(patsubst %.proto,%.pb.c,$(nanopb_c_sources_fullpath)))
|
||||||
|
nanopb_c_generated_objects := $(patsubst %.c,%.o, $(nanopb_c_generated_sources))
|
||||||
|
|
||||||
|
# Auto-export the generated proto source dir.
|
||||||
|
LOCAL_EXPORT_C_INCLUDE_DIRS += $(nanopb_c_generated_sources_dir)
|
||||||
|
|
||||||
|
$(nanopb_c_generated_sources): PRIVATE_NANOPB_C_INCLUDES := $(TOP)
|
||||||
|
$(nanopb_c_generated_sources): PRIVATE_NANOPB_C_OUTPUT_DIR := $(nanopb_c_generated_sources_dir)
|
||||||
|
$(nanopb_c_generated_sources): PRIVATE_NANOPB_C_FLAGS := $(LOCAL_PROTOC_FLAGS)
|
||||||
|
|
||||||
|
$(nanopb_c_generated_sources): $(nanopb_c_generated_sources_dir)/%.pb.c: %.proto $(PROTOC)
|
||||||
|
$(transform-nanopb_c-to-c)
|
||||||
|
|
||||||
|
nanopb_c_generated_headers := $(patsubst %.pb.c,%.pb.h, $(nanopb_c_generated_sources))
|
||||||
|
$(nanopb_c_generated_headers): $(nanopb_c_generated_sources_dir)/%.pb.h: $(nanopb_c_generated_sources_dir)/%.pb.c
|
||||||
|
|
||||||
|
$(nanopb_c_generated_objects): PRIVATE_ARM_MODE := $(normal_objects_mode)
|
||||||
|
$(nanopb_c_generated_objects): PRIVATE_ARM_CFLAGS := $(normal_objects_cflags)
|
||||||
|
$(nanopb_c_generated_objects): $(nanopb_c_generated_sources_dir)/%.o: $(nanopb_c_generated_sources_dir)/%.c $(nanopb_c_generated_headers)
|
||||||
|
$(transform-$(PRIVATE_HOST)c-to-o)
|
||||||
|
-include $(nanopb_c_generated_objects:%.o=%.P)
|
||||||
|
|
||||||
|
LOCAL_C_INCLUDES += external/nanopb-c $(dir $(nanopb_c_generated_headers))
|
||||||
|
ifeq ($(LOCAL_PROTOC_OPTIMIZE_TYPE),nanopb-c-enable_malloc)
|
||||||
|
LOCAL_STATIC_LIBRARIES += libnanopb-c-2.8.0-enable_malloc
|
||||||
|
else
|
||||||
|
LOCAL_STATIC_LIBRARIES += libnanopb-c-2.8.0
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
###########################################################
|
###########################################################
|
||||||
## YACC: Compile .y and .yy files to .cpp and the to .o.
|
## YACC: Compile .y and .yy files to .cpp and the to .o.
|
||||||
###########################################################
|
###########################################################
|
||||||
|
@ -775,7 +828,7 @@ $(dotdot_objects) $(c_normal_objects): PRIVATE_ARM_CFLAGS := $(normal_objects_cf
|
||||||
c_objects := $(c_arm_objects) $(c_normal_objects)
|
c_objects := $(c_arm_objects) $(c_normal_objects)
|
||||||
|
|
||||||
ifneq ($(strip $(c_objects)),)
|
ifneq ($(strip $(c_objects)),)
|
||||||
$(c_objects): $(intermediates)/%.o: $(TOPDIR)$(LOCAL_PATH)/%.c $(yacc_cpps) $(proto_generated_headers) \
|
$(c_objects): $(intermediates)/%.o: $(TOPDIR)$(LOCAL_PATH)/%.c $(yacc_cpps) $(proto_generated_headers) $(nanopb_c_generated_headers) \
|
||||||
$(my_additional_dependencies)
|
$(my_additional_dependencies)
|
||||||
$(transform-$(PRIVATE_HOST)c-to-o)
|
$(transform-$(PRIVATE_HOST)c-to-o)
|
||||||
-include $(c_objects:%.o=%.P)
|
-include $(c_objects:%.o=%.P)
|
||||||
|
@ -795,7 +848,7 @@ ifneq ($(strip $(gen_c_objects)),)
|
||||||
# TODO: support compiling certain generated files as arm.
|
# TODO: support compiling certain generated files as arm.
|
||||||
$(gen_c_objects): PRIVATE_ARM_MODE := $(normal_objects_mode)
|
$(gen_c_objects): PRIVATE_ARM_MODE := $(normal_objects_mode)
|
||||||
$(gen_c_objects): PRIVATE_ARM_CFLAGS := $(normal_objects_cflags)
|
$(gen_c_objects): PRIVATE_ARM_CFLAGS := $(normal_objects_cflags)
|
||||||
$(gen_c_objects): $(intermediates)/%.o: $(intermediates)/%.c $(yacc_cpps) $(proto_generated_headers) \
|
$(gen_c_objects): $(intermediates)/%.o: $(intermediates)/%.c $(yacc_cpps) $(proto_generated_headers) $(nanopb_c_generated_headers) \
|
||||||
$(my_additional_dependencies)
|
$(my_additional_dependencies)
|
||||||
$(transform-$(PRIVATE_HOST)c-to-o)
|
$(transform-$(PRIVATE_HOST)c-to-o)
|
||||||
-include $(gen_c_objects:%.o=%.P)
|
-include $(gen_c_objects:%.o=%.P)
|
||||||
|
@ -930,6 +983,7 @@ normal_objects := \
|
||||||
$(objc_objects) \
|
$(objc_objects) \
|
||||||
$(yacc_objects) \
|
$(yacc_objects) \
|
||||||
$(lex_objects) \
|
$(lex_objects) \
|
||||||
|
$(nanopb_c_generated_objects) \
|
||||||
$(proto_generated_objects) \
|
$(proto_generated_objects) \
|
||||||
$(addprefix $(TOPDIR)$(LOCAL_PATH)/,$(LOCAL_PREBUILT_OBJ_FILES))
|
$(addprefix $(TOPDIR)$(LOCAL_PATH)/,$(LOCAL_PREBUILT_OBJ_FILES))
|
||||||
|
|
||||||
|
@ -1098,7 +1152,7 @@ $(LOCAL_INSTALLED_MODULE): | $(installed_static_library_notice_file_targets)
|
||||||
export_includes := $(intermediates)/export_includes
|
export_includes := $(intermediates)/export_includes
|
||||||
$(export_includes): PRIVATE_EXPORT_C_INCLUDE_DIRS := $(LOCAL_EXPORT_C_INCLUDE_DIRS)
|
$(export_includes): PRIVATE_EXPORT_C_INCLUDE_DIRS := $(LOCAL_EXPORT_C_INCLUDE_DIRS)
|
||||||
# Make sure .pb.h are already generated before any dependent source files get compiled.
|
# Make sure .pb.h are already generated before any dependent source files get compiled.
|
||||||
$(export_includes) : $(LOCAL_MODULE_MAKEFILE) $(proto_generated_headers)
|
$(export_includes) : $(LOCAL_MODULE_MAKEFILE) $(proto_generated_headers) $(nanopb_c_generated_headers)
|
||||||
@echo Export includes file: $< -- $@
|
@echo Export includes file: $< -- $@
|
||||||
$(hide) mkdir -p $(dir $@) && rm -f $@
|
$(hide) mkdir -p $(dir $@) && rm -f $@
|
||||||
ifdef LOCAL_EXPORT_C_INCLUDE_DIRS
|
ifdef LOCAL_EXPORT_C_INCLUDE_DIRS
|
||||||
|
|
|
@ -139,7 +139,7 @@ LOCAL_RENDERSCRIPT_TARGET_API:=
|
||||||
LOCAL_DEX_PREOPT:= # '',true,false,nostripping
|
LOCAL_DEX_PREOPT:= # '',true,false,nostripping
|
||||||
LOCAL_DEX_PREOPT_IMAGE_LOCATION:=
|
LOCAL_DEX_PREOPT_IMAGE_LOCATION:=
|
||||||
LOCAL_DEX_PREOPT_FLAGS:=
|
LOCAL_DEX_PREOPT_FLAGS:=
|
||||||
LOCAL_PROTOC_OPTIMIZE_TYPE:= # lite(default),micro,nano,full
|
LOCAL_PROTOC_OPTIMIZE_TYPE:= # lite(default),micro,nano,full,nanopb-c,nanopb-c-enable_malloc
|
||||||
LOCAL_PROTOC_FLAGS:=
|
LOCAL_PROTOC_FLAGS:=
|
||||||
LOCAL_PROTO_JAVA_OUTPUT_PARAMS:=
|
LOCAL_PROTO_JAVA_OUTPUT_PARAMS:=
|
||||||
LOCAL_NO_CRT:=
|
LOCAL_NO_CRT:=
|
||||||
|
|
|
@ -994,6 +994,7 @@ endef
|
||||||
## Commands for running protoc to compile .proto into .pb.cc and .pb.h
|
## Commands for running protoc to compile .proto into .pb.cc and .pb.h
|
||||||
######################################################################
|
######################################################################
|
||||||
define transform-proto-to-cc
|
define transform-proto-to-cc
|
||||||
|
$(warning transform-proto-to-cc)
|
||||||
@mkdir -p $(dir $@)
|
@mkdir -p $(dir $@)
|
||||||
@echo "Protoc: $@ <= $<"
|
@echo "Protoc: $@ <= $<"
|
||||||
$(hide) $(PROTOC) \
|
$(hide) $(PROTOC) \
|
||||||
|
@ -1002,6 +1003,18 @@ $(hide) $(PROTOC) \
|
||||||
--cpp_out=$(PRIVATE_PROTO_CC_OUTPUT_DIR) $<
|
--cpp_out=$(PRIVATE_PROTO_CC_OUTPUT_DIR) $<
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
######################################################################
|
||||||
|
## Commands for running protoc to compile .proto into nano protobuf .pb.c and .pb.h
|
||||||
|
######################################################################
|
||||||
|
define transform-nanopb_c-to-c
|
||||||
|
$(warning transform-nanopb_c-to-c)
|
||||||
|
@mkdir -p $(dir $@)
|
||||||
|
@echo "Protoc: $@ <= $<"
|
||||||
|
$(hide) $(PROTOC) \
|
||||||
|
$(addprefix --proto_path=, $(PRIVATE_NANOPB_C_INCLUDES)) \
|
||||||
|
$(PRIVATE_NANOPB_C_FLAGS) \
|
||||||
|
--nanopb_out=$(PRIVATE_NANOPB_C_OUTPUT_DIR) --plugin=external/nanopb-c/generator/protoc-gen-nanopb $<
|
||||||
|
endef
|
||||||
|
|
||||||
###########################################################
|
###########################################################
|
||||||
## Commands for running gcc to compile a C++ file
|
## Commands for running gcc to compile a C++ file
|
||||||
|
|
Loading…
Reference in New Issue