| ############################################################################ |
| # apps/Make.defs |
| # |
| # Licensed to the Apache Software Foundation (ASF) under one or more |
| # contributor license agreements. See the NOTICE file distributed with |
| # this work for additional information regarding copyright ownership. The |
| # ASF licenses this file to you under the Apache License, Version 2.0 (the |
| # "License"); you may not use this file except in compliance with the |
| # License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| # License for the specific language governing permissions and limitations |
| # under the License. |
| # |
| ############################################################################ |
| |
| TOPDIR ?= $(APPDIR)/import |
| include $(TOPDIR)/Make.defs |
| |
| # Application Directories |
| |
| # BUILDIRS is the list of top-level directories containing Make.defs files |
| # CLEANDIRS is the list of all top-level directories containing Makefiles. |
| # It is used only for cleaning. |
| |
| BUILDIRS := $(dir $(wildcard $(APPDIR)/*/Make.defs)) |
| BUILDIRS := $(filter-out $(APPDIR)/import/,$(BUILDIRS)) |
| CONFIGDIRS := $(filter-out $(APPDIR)/builtin/,$(BUILDIRS)) |
| CONFIGDIRS := $(filter-out $(dir $(wildcard $(APPDIR)/*/Kconfig)),$(CONFIGDIRS)) |
| CLEANDIRS := $(dir $(wildcard $(APPDIR)/*/Makefile)) |
| ifeq ($(CONFIG_WINDOWS_NATIVE),y) |
| BUILDIRS := $(subst /,\,$(BUILDIRS)) |
| CONFIGDIRS := $(subst /,\,$(CONFIGDIRS)) |
| CLEANDIRS := $(subst /,\,$(CLEANDIRS)) |
| endif |
| |
| # CONFIGURED_APPS is the application directories that should be built in |
| # the current configuration. |
| |
| CONFIGURED_APPS := |
| |
| define Add_Application |
| include $(1)Make.defs |
| endef |
| |
| $(foreach BDIR, $(BUILDIRS), $(eval $(call Add_Application,$(BDIR)))) |
| |
| # File extensions |
| |
| CXXEXT ?= .cxx |
| RUSTEXT ?= .rs |
| ZIGEXT ?= .zig |
| |
| # Library path |
| |
| LIBPATH ?= $(TOPDIR)$(DELIM)staging |
| |
| # The install path |
| |
| BINDIR ?= $(APPDIR)$(DELIM)bin |
| |
| # The final build target |
| |
| BIN ?= $(APPDIR)$(DELIM)libapps$(LIBEXT) |
| WBIN ?= $(APPDIR)$(DELIM)wasm$(DELIM)libwasm$(LIBEXT) |
| |
| # Tools |
| |
| ifeq ($(CONFIG_WINDOWS_NATIVE),y) |
| MKKCONFIG ?= $(APPDIR)$(DELIM)tools$(DELIM)mkkconfig.bat |
| else |
| MKKCONFIG ?= $(APPDIR)$(DELIM)tools$(DELIM)mkkconfig.sh |
| endif |
| |
| # Builtin Registration |
| |
| BUILTIN_REGISTRY = $(APPDIR)$(DELIM)builtin$(DELIM)registry |
| DEPCONFIG = $(TOPDIR)$(DELIM).config |
| |
| ifeq ($(CONFIG_WINDOWS_NATIVE),y) |
| ifeq ($(CONFIG_SCHED_USER_IDENTITY),y) |
| define REGISTER |
| $(Q) echo Register: $1 |
| $(Q) echo { "$(subst ",,$(1))", $2, $3, $(patsubst ,0,$(subst ",,$(4))), $(patsubst ,0,$(5)), $(patsubst ,0,$(6)), $(patsubst ,0555,$(7))}, > "$(BUILTIN_REGISTRY)$(DELIM)$1.bdat" |
| $(Q) echo int $(subst ",,$(4))(int argc, char *argv[]); > "$(BUILTIN_REGISTRY)$(DELIM)$1.pdat" |
| |
| $(Q) touch $(BUILTIN_REGISTRY)$(DELIM).updated" |
| endef |
| else |
| define REGISTER |
| $(Q) echo Register: $1 |
| $(Q) echo { "$(subst ",,$(1))", $2, $3, $(subst ",,$(4)) }, > "$(BUILTIN_REGISTRY)$(DELIM)$1.bdat" |
| $(Q) echo int $(subst ",,$(4))(int argc, char *argv[]); > "$(BUILTIN_REGISTRY)$(DELIM)$1.pdat" |
| |
| $(Q) touch $(BUILTIN_REGISTRY)$(DELIM).updated" |
| endef |
| endif |
| else |
| ifeq ($(CONFIG_SCHED_USER_IDENTITY),y) |
| define REGISTER |
| $(Q) echo "{ \"$1\", $2, $3, $(patsubst ,0,$(4)), $(patsubst ,0,$(5)), $(patsubst ,0,$(6)), $(patsubst ,0555,$(7)) }," > "$(BUILTIN_REGISTRY)$(DELIM)$1.bdat" |
| $(Q) if [ ! -z $4 ]; then \ |
| echo "int $4(int argc, char *argv[]);" > "$(BUILTIN_REGISTRY)$(DELIM)$1.pdat"; \ |
| fi; |
| $(Q) touch "$(BUILTIN_REGISTRY)$(DELIM).updated" |
| endef |
| else |
| define REGISTER |
| $(Q) echo "Register: $1" |
| $(Q) echo "{ \"$1\", $2, $3, $4 }," > "$(BUILTIN_REGISTRY)$(DELIM)$1.bdat" |
| $(Q) if [ ! -z $4 ]; then \ |
| echo "int $4(int argc, char *argv[]);" > "$(BUILTIN_REGISTRY)$(DELIM)$1.pdat"; \ |
| fi; |
| $(Q) touch "$(BUILTIN_REGISTRY)$(DELIM).updated" |
| endef |
| endif |
| endif |
| |
| # Standard include path |
| |
| CFLAGS += ${INCDIR_PREFIX}"$(APPDIR)$(DELIM)include" |
| CXXFLAGS += ${INCDIR_PREFIX}"$(APPDIR)$(DELIM)include" |
| |
| NUTTXLIB ?= $(call CONVERT_PATH,$(TOPDIR)$(DELIM)staging) |
| |
| # SPLITVARIABLE - Split long variables into specified batches |
| # Usage: $(call SPLITVARIABLE, variable-def, variable-ref, batch-size) |
| # |
| # Example: VAR:= a b c x y z foo bar |
| # $(call SPLITVARIABLE, VAR, $(VAR), 3) |
| # $(foreach, num, $(VAR_TOTAL), $(shell echo $(VAR_$(num)))) |
| # Return new variable definition: |
| # $(variable-def)_TOTAL : total split sequence , start with 1. |
| # $(variable-def)_$(num) : newly defined variable , ended with batch num. |
| # In the case above: |
| # $(VAR_TOTAL) = 1 2 3 |
| # $(VAR_1) = a b c |
| # $(VAR_2) = x y z |
| # $(VAR_3) = foo bar |
| |
| define SPLITVARIABLE |
| $(eval PREFIX = $(1)) |
| $(eval BATCH_SIZE = $(3)) |
| $(eval TOTAL_BATCH = $(shell expr $(words $(2)) / $(BATCH_SIZE) + 1)) |
| $(eval $(PREFIX)_TOTAL = $(shell seq 1 $(TOTAL_BATCH))) |
| $(foreach idx, $($(PREFIX)_TOTAL), \ |
| $(eval FROMINDEX=$(shell expr 1 + $(idx) \* $(BATCH_SIZE) - $(BATCH_SIZE))) \ |
| $(eval $(PREFIX)_$(idx)=$(wordlist $(FROMINDEX), $(shell expr $(FROMINDEX) + $(BATCH_SIZE) - 1), $(2))) \ |
| ) |
| endef |
| |
| define ARLOCK |
| flock $1.lock $(call ARCHIVE, $1, $(2)) |
| endef |
| |
| # dynamic AR target |
| |
| define AROBJSRULES |
| $(1) : $(2) |
| cp $(2) $(1) |
| endef |
| |
| # CLEANAROBJS - del AR target files exclusively |
| |
| ifeq ($(CONFIG_WINDOWS_NATIVE),y) |
| define CLEANAROBJS |
| $(call DELFILE,$(subst /,\,$(AROBJS))) |
| $(call DELFILE,$(subst /,\,$(OBJS))) |
| $(eval OBJS :=) |
| endef |
| else |
| define CLEANAROBJS |
| $(call SPLITVARIABLE,CLEAN_AROBJS,${AROBJS},100) |
| $(foreach BATCH, $(CLEAN_AROBJS_TOTAL), \ |
| $(shell rm -rf $(CLEAN_AROBJS_$(BATCH)))) |
| $(call SPLITVARIABLE,CLEAN_OBJS,${OBJS},100) |
| $(foreach BATCH, $(CLEAN_OBJS_TOTAL), \ |
| $(shell rm -rf $(CLEAN_OBJS_$(BATCH)))) |
| $(eval OBJS :=) |
| endef |
| endif |