| # |
| # Copyright (c) 2019, The OpenThread Authors. |
| # All rights reserved. |
| # |
| # Redistribution and use in source and binary forms, with or without |
| # modification, are permitted provided that the following conditions are met: |
| # 1. Redistributions of source code must retain the above copyright |
| # notice, this list of conditions and the following disclaimer. |
| # 2. Redistributions in binary form must reproduce the above copyright |
| # notice, this list of conditions and the following disclaimer in the |
| # documentation and/or other materials provided with the distribution. |
| # 3. Neither the name of the copyright holder nor the |
| # names of its contributors may be used to endorse or promote products |
| # derived from this software without specific prior written permission. |
| # |
| # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE |
| # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| # POSSIBILITY OF SUCH DAMAGE. |
| # |
| |
| .NOTPARALLEL: |
| |
| AR = arm-none-eabi-ar |
| CCAS = $(CCPREFIX) arm-none-eabi-gcc |
| CPP = arm-none-eabi-cpp |
| CC = $(CCPREFIX) arm-none-eabi-gcc |
| CXX = $(CCPREFIX) arm-none-eabi-g++ |
| LD = arm-none-eabi-ld |
| STRIP = arm-none-eabi-strip |
| NM = arm-none-eabi-nm |
| RANLIB = arm-none-eabi-ranlib |
| OBJCOPY = arm-none-eabi-objcopy |
| |
| BuildJobs ?= 10 |
| GCCVersion = $(shell expr `$(CC) -dumpversion | cut -f1 -d.`) |
| |
| configure_OPTIONS = \ |
| --enable-cli \ |
| --enable-ftd \ |
| --enable-mtd \ |
| --enable-ncp \ |
| --enable-radio-only \ |
| --enable-linker-map \ |
| --with-examples=qpg6095 \ |
| MBEDTLS_CPPFLAGS="$(QPG6095_MBEDTLS_CPPFLAGS)" \ |
| $(NULL) |
| |
| TopSourceDir := $(dir $(shell readlink $(firstword $(MAKEFILE_LIST)))).. |
| AbsTopSourceDir := $(dir $(realpath $(firstword $(MAKEFILE_LIST)))).. |
| |
| QPG6095_CONFIG_FILE_CPPFLAGS = -DOPENTHREAD_PROJECT_CORE_CONFIG_FILE='\"openthread-core-qpg6095-config.h\"' |
| QPG6095_CONFIG_FILE_CPPFLAGS += -DOPENTHREAD_CORE_CONFIG_PLATFORM_CHECK_FILE='\"openthread-core-qpg6095-config-check.h\"' |
| QPG6095_CONFIG_FILE_CPPFLAGS += -I$(PWD)/examples/platforms/qpg6095/ |
| QPG6095_MBEDTLS_CPPFLAGS = -DMBEDTLS_CONFIG_FILE='\"mbedtls-config.h\"' |
| QPG6095_MBEDTLS_CPPFLAGS += -DMBEDTLS_USER_CONFIG_FILE='\"qpg6095-mbedtls-config.h\"' |
| QPG6095_MBEDTLS_CPPFLAGS += -I$(PWD)/examples/platforms/qpg6095/crypto |
| QPG6095_MBEDTLS_CPPFLAGS += -I$(PWD)/third_party/mbedtls |
| QPG6095_MBEDTLS_CPPFLAGS += -I$(PWD)/third_party/mbedtls/repo/include |
| QPG6095_MBEDTLS_CPPFLAGS += -I$(PWD)/third_party/mbedtls/repo/include/mbedtls |
| |
| COMMONCFLAGS := \ |
| -fdata-sections \ |
| -ffunction-sections \ |
| -Os \ |
| -g \ |
| $(QPG6095_CONFIG_FILE_CPPFLAGS) \ |
| $(NULL) |
| |
| include $(dir $(abspath $(lastword $(MAKEFILE_LIST))))/common-switches.mk |
| |
| CPPFLAGS += \ |
| $(COMMONCFLAGS) \ |
| $(target_CPPFLAGS) \ |
| $(NULL) |
| |
| CFLAGS += \ |
| $(COMMONCFLAGS) \ |
| $(target_CFLAGS) \ |
| $(NULL) |
| |
| CXXFLAGS += \ |
| $(COMMONCFLAGS) \ |
| $(target_CXXFLAGS) \ |
| -fno-exceptions \ |
| -fno-rtti \ |
| $(NULL) |
| |
| LDFLAGS += \ |
| $(COMMONCFLAGS) \ |
| $(target_LDFLAGS) \ |
| -specs=nano.specs \ |
| -specs=nosys.specs \ |
| -Wl,--gc-sections \ |
| $(NULL) |
| |
| ECHO := @echo |
| MAKE := make |
| MKDIR_P := mkdir -p |
| LN_S := ln -s |
| RM_F := rm -f |
| |
| INSTALL := /usr/bin/install |
| INSTALLFLAGS := -p |
| |
| BuildPath = build |
| TopBuildDir = $(BuildPath) |
| AbsTopBuildDir = $(PWD)/$(TopBuildDir) |
| |
| ResultPath = output |
| TopResultDir = $(ResultPath) |
| AbsTopResultDir = $(PWD)/$(TopResultDir) |
| |
| TargetTuple = qpg6095 |
| |
| ARCHS = cortex-m4 |
| |
| TopTargetLibDir = $(TopResultDir)/$(TargetTuple)/lib |
| |
| ifndef BuildJobs |
| BuildJobs := $(shell getconf _NPROCESSORS_ONLN) |
| endif |
| JOBSFLAG := -j$(BuildJobs) |
| |
| # |
| # configure-arch <arch> |
| # |
| # Configure OpenThread for the specified architecture. |
| # |
| # arch - The architecture to configure. |
| # |
| define configure-arch |
| $(ECHO) " CONFIG $(TargetTuple)..." |
| (cd $(BuildPath)/$(TargetTuple) && $(AbsTopSourceDir)/configure \ |
| INSTALL="$(INSTALL) $(INSTALLFLAGS)" \ |
| CPP="$(CPP)" CC="$(CC)" CXX="$(CXX)" CCAS="$(CCAS)" OBJC="$(OBJC)" OBJCXX="$(OBJCXX)" AR="$(AR)" RANLIB="$(RANLIB)" NM="$(NM)" STRIP="$(STRIP)" CPPFLAGS="$(CPPFLAGS)" CFLAGS="$(CFLAGS)" CXXFLAGS="$(CXXFLAGS)" CCASFLAGS="$(CCASFLAGS)" LDFLAGS="$(LDFLAGS)" \ |
| --host=arm-none-eabi \ |
| --prefix=/ \ |
| --exec-prefix=/$(TargetTuple) \ |
| $(configure_OPTIONS)) |
| endef # configure-arch |
| |
| # |
| # build-arch <arch> |
| # |
| # Build the OpenThread intermediate build products for the specified |
| # architecture. |
| # |
| # arch - The architecture to build. |
| # |
| define build-arch |
| $(ECHO) " BUILD $(TargetTuple)" |
| $(MAKE) $(JOBSFLAG) -C $(BuildPath)/$(TargetTuple) --no-print-directory \ |
| all |
| endef # build-arch |
| |
| # |
| # stage-arch <arch> |
| # |
| # Stage (install) the OpenThread final build products for the specified |
| # architecture. |
| # |
| # arch - The architecture to stage. |
| # |
| define stage-arch |
| $(ECHO) " STAGE $(TargetTuple)" |
| $(MAKE) $(JOBSFLAG) -C $(BuildPath)/$(TargetTuple) --no-print-directory \ |
| DESTDIR=$(AbsTopResultDir) \ |
| install |
| endef # stage-arch |
| |
| # @FIXME: get the filenames of the targets of OBJCOPY (now they are hardcoded) |
| define hex-arch |
| $(ECHO) " HEX $(TargetTuple)" |
| $(OBJCOPY) -O ihex $(AbsTopResultDir)/$(TargetTuple)/bin/ot-cli-mtd $(AbsTopResultDir)/$(TargetTuple)/bin/ot-cli-mtd.hex |
| $(OBJCOPY) -O ihex $(AbsTopResultDir)/$(TargetTuple)/bin/ot-cli-ftd $(AbsTopResultDir)/$(TargetTuple)/bin/ot-cli-ftd.hex |
| endef # hex-arch |
| |
| # |
| # ARCH_template <arch> |
| # |
| # Define macros, targets and rules to configure, build, and stage the |
| # OpenThread for a single architecture. |
| # |
| # arch - The architecture to instantiate the template for. |
| # |
| define ARCH_template |
| CONFIGURE_TARGETS += configure-$(1) |
| BUILD_TARGETS += do-build-$(1) |
| HEX_TARGETS += hex-$(1) |
| STAGE_TARGETS += stage-$(1) |
| BUILD_DIRS += $(BuildPath)/$(TargetTuple) |
| DIRECTORIES += $(BuildPath)/$(TargetTuple) |
| |
| configure-$(1): target_CPPFLAGS=$($(1)_target_CPPFLAGS) |
| configure-$(1): target_CFLAGS=$($(1)_target_CFLAGS) |
| configure-$(1): target_CXXFLAGS=$($(1)_target_CXXFLAGS) |
| configure-$(1): target_LDFLAGS=$($(1)_target_LDFLAGS) |
| configure-$(1): target_CCASFLAGS=$($(1)_target_CCASFLAGS) |
| |
| configure-$(1): $(BuildPath)/$(TargetTuple)/config.status |
| |
| $(BuildPath)/$(TargetTuple)/config.status: | $(BuildPath)/$(TargetTuple) |
| $$(call configure-arch,$(1)) |
| |
| do-build-$(1): configure-$(1) |
| |
| do-build-$(1): |
| +$$(call build-arch,$(1)) |
| |
| hex-$(1): stage-$(1) |
| |
| hex-$(1): |
| $$(call hex-arch,$(1)) |
| |
| $(1): hex-$(1) |
| |
| stage-$(1): do-build-$(1) |
| |
| stage-$(1): | $(TopResultDir) |
| $$(call stage-arch,$(1)) |
| endef # ARCH_template |
| |
| .DEFAULT_GOAL := all |
| |
| all: hex |
| |
| # |
| # cortex-m4 |
| # |
| |
| cortex-m4_target_ABI = cortex-m4 |
| cortex-m4_target_CPPFLAGS = -mcpu=cortex-m4 -mthumb -ffunction-sections |
| cortex-m4_target_CFLAGS = -mcpu=cortex-m4 -mthumb -ffunction-sections |
| cortex-m4_target_CXXFLAGS = -mcpu=cortex-m4 -mthumb -ffunction-sections |
| cortex-m4_target_LDFLAGS = -mcpu=cortex-m4 -mthumb -ffunction-sections |
| |
| # Instantiate an architecture-specific build template for each target |
| # architecture. |
| |
| $(foreach arch,$(ARCHS),$(eval $(call ARCH_template,$(arch)))) |
| |
| # |
| # Common / Finalization |
| # |
| |
| configure: $(CONFIGURE_TARGETS) |
| |
| build: $(BUILD_TARGETS) |
| |
| stage: $(STAGE_TARGETS) |
| |
| hex: $(HEX_TARGETS) |
| |
| DIRECTORIES = $(TopResultDir) $(TopResultDir)/$(TargetTuple)/lib $(BUILD_DIRS) |
| |
| CLEAN_DIRS = $(TopResultDir) $(BUILD_DIRS) |
| |
| all: hex |
| |
| $(DIRECTORIES): |
| $(ECHO) " MKDIR $@" |
| @$(MKDIR_P) "$@" |
| |
| clean: |
| $(ECHO) " CLEAN" |
| @$(RM_F) -r $(CLEAN_DIRS) |
| |
| help: |
| $(ECHO) "Simply type 'make -f $(firstword $(MAKEFILE_LIST))' to build OpenThread for the following " |
| $(ECHO) "architectures: " |
| $(ECHO) "" |
| $(ECHO) " $(ARCHS)" |
| $(ECHO) "" |
| $(ECHO) "To build only a particular architecture, specify: " |
| $(ECHO) "" |
| $(ECHO) " make -f $(firstword $(MAKEFILE_LIST)) <architecture>" |
| $(ECHO) "" |