apps/builtin: better fix for building with parallel make
Build-server sometimes fails 'make -j24' with: In file included from builtin_list.c:62:0: builtin_list.h:1:46: error: 'ts_engine_main' undeclared here (not in a function) { "ts_engine", SCHED_PRIORITY_DEFAULT, 2048, ts_engine_main }, or sometimes silently succeeds but generates builds that contain a random subset of configured NuttX applications. There are two root causes for this: 1) Recipes for building builtin_list.h and builtin_proto.h are not linearizable. 2) Nothing ensures that 'make context' is run first for apps/builtin This patch addresses both issues. Signed-off-by: Juha Niskanen <juha.niskanen@haltian.com>
This commit is contained in:
parent
5499189417
commit
7b925ccb4c
12
Makefile
12
Makefile
@ -45,7 +45,7 @@ TOPDIR ?= $(APPDIR)/import
|
|||||||
# CONFIGURED_APPS is the list of all configured built-in directories/built
|
# CONFIGURED_APPS is the list of all configured built-in directories/built
|
||||||
# action.
|
# action.
|
||||||
# SUBDIRS is the list of all directories containing Makefiles. It is used
|
# SUBDIRS is the list of all directories containing Makefiles. It is used
|
||||||
# only for cleaning. builtin must always be the first in the list.
|
# only for cleaning.
|
||||||
|
|
||||||
CONFIGURED_APPS =
|
CONFIGURED_APPS =
|
||||||
SUBDIRS = examples graphics interpreters modbus builtin import nshlib
|
SUBDIRS = examples graphics interpreters modbus builtin import nshlib
|
||||||
@ -114,7 +114,7 @@ BIN = libapps$(LIBEXT)
|
|||||||
# Build targets
|
# Build targets
|
||||||
|
|
||||||
all: $(BIN)
|
all: $(BIN)
|
||||||
.PHONY: import install context .depdirs depend clean distclean
|
.PHONY: import install context context_serialize context_rest .depdirs depend clean distclean
|
||||||
|
|
||||||
define SDIR_template
|
define SDIR_template
|
||||||
$(1)_$(2):
|
$(1)_$(2):
|
||||||
@ -142,7 +142,13 @@ install: $(BIN_DIR) .install
|
|||||||
import:
|
import:
|
||||||
$(Q) $(MAKE) .import TOPDIR="$(APPDIR)$(DELIM)import"
|
$(Q) $(MAKE) .import TOPDIR="$(APPDIR)$(DELIM)import"
|
||||||
|
|
||||||
context: $(foreach SDIR, $(INSTALLED_APPS), $(SDIR)_context)
|
context_rest: $(foreach SDIR, $(INSTALLED_APPS), $(SDIR)_context)
|
||||||
|
|
||||||
|
context_serialize:
|
||||||
|
$(Q) $(MAKE) -C builtin context TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"
|
||||||
|
$(Q) $(MAKE) context_rest
|
||||||
|
|
||||||
|
context: context_serialize
|
||||||
|
|
||||||
.depdirs: $(foreach SDIR, $(INSTALLED_APPS), $(SDIR)_depend)
|
.depdirs: $(foreach SDIR, $(INSTALLED_APPS), $(SDIR)_depend)
|
||||||
|
|
||||||
|
@ -74,35 +74,39 @@ $(COBJS): %$(OBJEXT): %.c
|
|||||||
registry$(DELIM).updated:
|
registry$(DELIM).updated:
|
||||||
$(Q) $(MAKE) -C registry .updated TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"
|
$(Q) $(MAKE) -C registry .updated TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"
|
||||||
|
|
||||||
|
builtin_list$(OBJEXT): builtin_list.h builtin_proto.h
|
||||||
|
|
||||||
builtin_list.h: registry$(DELIM).updated
|
builtin_list.h: registry$(DELIM).updated
|
||||||
$(call DELFILE, builtin_list.h)
|
$(call DELFILE, .xx_builtin_list.h)
|
||||||
$(Q) touch builtin_list.h
|
$(Q) touch .xx_builtin_list.h
|
||||||
ifeq ($(CONFIG_WINDOWS_NATIVE),y)
|
ifeq ($(CONFIG_WINDOWS_NATIVE),y)
|
||||||
$(Q) (for /f %%G in ('dir /b registry\*.bdat') do ( type registry\%%G >> builtin_list.h )) || echo ""
|
$(Q) (for /f %%G in ('dir /b registry\*.bdat') do ( type registry\%%G >> .xx_builtin_list.h )) || echo ""
|
||||||
else
|
else
|
||||||
$(Q) ( \
|
$(Q) ( \
|
||||||
filelist=`ls registry/*.bdat 2>/dev/null || echo ""`; \
|
filelist=`ls registry/*.bdat 2>/dev/null || echo ""`; \
|
||||||
for file in $$filelist; \
|
for file in $$filelist; \
|
||||||
do cat $$file >> builtin_list.h; \
|
do cat $$file >> .xx_builtin_list.h; \
|
||||||
done; \
|
done; \
|
||||||
)
|
)
|
||||||
endif
|
endif
|
||||||
|
$(Q) mv .xx_builtin_list.h builtin_list.h
|
||||||
|
|
||||||
builtin_proto.h: registry$(DELIM).updated
|
builtin_proto.h: registry$(DELIM).updated
|
||||||
$(call DELFILE, builtin_proto.h)
|
$(call DELFILE, .xx_builtin_proto.h)
|
||||||
$(Q) touch builtin_proto.h
|
$(Q) touch .xx_builtin_proto.h
|
||||||
ifeq ($(CONFIG_WINDOWS_NATIVE),y)
|
ifeq ($(CONFIG_WINDOWS_NATIVE),y)
|
||||||
$(Q) (for /f %%G in ('dir /b registry\*.pdat') do ( type registry\%%G >> builtin_proto.h )) || echo ""
|
$(Q) (for /f %%G in ('dir /b registry\*.pdat') do ( type registry\%%G >> .xx_builtin_proto.h )) || echo ""
|
||||||
else
|
else
|
||||||
$(Q) ( \
|
$(Q) ( \
|
||||||
filelist=`ls registry/*.pdat 2>/dev/null || echo ""`; \
|
filelist=`ls registry/*.pdat 2>/dev/null || echo ""`; \
|
||||||
for file in $$filelist; \
|
for file in $$filelist; \
|
||||||
do cat $$file >> builtin_proto.h; \
|
do cat $$file >> .xx_builtin_proto.h; \
|
||||||
done; \
|
done; \
|
||||||
)
|
)
|
||||||
endif
|
endif
|
||||||
|
$(Q) mv .xx_builtin_proto.h builtin_proto.h
|
||||||
|
|
||||||
.built: builtin_list.h builtin_proto.h $(OBJS)
|
.built: $(OBJS)
|
||||||
$(call ARCHIVE, $(BIN), $(OBJS))
|
$(call ARCHIVE, $(BIN), $(OBJS))
|
||||||
$(Q) touch .built
|
$(Q) touch .built
|
||||||
|
|
||||||
@ -120,6 +124,8 @@ depend: .depend
|
|||||||
clean:
|
clean:
|
||||||
$(Q) $(MAKE) -C registry clean TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"
|
$(Q) $(MAKE) -C registry clean TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"
|
||||||
$(call DELFILE, .built)
|
$(call DELFILE, .built)
|
||||||
|
$(call DELFILE, .xx_builtin_list.h)
|
||||||
|
$(call DELFILE, .xx_builtin_proto.h)
|
||||||
$(call CLEAN)
|
$(call CLEAN)
|
||||||
|
|
||||||
distclean: clean
|
distclean: clean
|
||||||
|
Loading…
Reference in New Issue
Block a user