# # Copyright (c) 2016, 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 = arm-none-eabi-as CPP = arm-none-eabi-cpp CC = arm-none-eabi-gcc CXX = 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 configure_OPTIONS = \ --enable-cli \ --enable-ftd \ --enable-mtd \ --enable-ncp \ --enable-radio-only \ --enable-linker-map \ --with-examples=cc2538 \ $(NULL) TopSourceDir := $(dir $(shell readlink $(firstword $(MAKEFILE_LIST)))).. AbsTopSourceDir := $(dir $(realpath $(firstword $(MAKEFILE_LIST)))).. CC2538_CONFIG_FILE_CPPFLAGS = -DOPENTHREAD_PROJECT_CORE_CONFIG_FILE='\"openthread-core-cc2538-config.h\"' CC2538_CONFIG_FILE_CPPFLAGS += -DOPENTHREAD_CORE_CONFIG_PLATFORM_CHECK_FILE='\"openthread-core-cc2538-config-check.h\"' CC2538_CONFIG_FILE_CPPFLAGS += -I$(AbsTopSourceDir)/examples/platforms/cc2538/ COMMONCFLAGS := \ -fdata-sections \ -ffunction-sections \ -Os \ -g \ $(CC2538_CONFIG_FILE_CPPFLAGS) \ $(NULL) include $(dir $(abspath $(lastword $(MAKEFILE_LIST))))/common-switches.mk # Optional CC2592 options, first and foremost, whether to enable support for it # at all. ifeq ($(CC2592),1) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2538_WITH_CC2592=1 # If the PA_EN is on another port C pin, specify it with CC2592_PA_PIN. ifneq ($(CC2592_PA_EN),) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2592_PA_EN_PIN=$(CC2592_PA_EN) endif # If the LNA_EN is on another port C pin, specify it with CC2592_LNA_PIN. ifneq ($(CC2592_LNA_EN),) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2592_LNA_EN_PIN=$(CC2592_LNA_EN) endif # If we're not using HGM, set CC2538_USE_HGM to 0. ifeq ($(CC2592_USE_HGM),0) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2592_USE_HGM=0 else # CC2592_USE_HGM=1 # HGM in use, if not on port D, specify the port here (A, B or C) with CC2592_HGM_PORT. ifneq ($(CC2592_HGM_PORT),) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2592_HGM_PORT=GPIO_$(CC2592_HGM_PORT)_BASE endif # If HGM is not at pin 2, specify which pin here with CC2592_HGM_PIN. ifneq ($(CC2592_HGM_PIN),) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2592_HGM_PIN=$(CC2592_HGM_PIN) endif # If we want it off by default, specify CC2592_HGM_DEFAULT_STATE=0 ifeq ($(CC2592_HGM_DEFAULT_STATE),0) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2592_HGM_DEFAULT_STATE=false endif endif # CC2592_USE_HGM endif # CC2592 ifneq ($(CC2538_RECEIVE_SENSITIVITY),) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2538_RECEIVE_SENSITIVITY=$(CC2538_RECEIVE_SENSITIVITY) endif ifneq ($(CC2538_RSSI_OFFSET),) COMMONCFLAGS += -DOPENTHREAD_CONFIG_CC2538_RSSI_OFFSET=$(CC2538_RSSI_OFFSET) endif CPPFLAGS += \ $(COMMONCFLAGS) \ $(target_CPPFLAGS) \ $(NULL) CFLAGS += \ $(COMMONCFLAGS) \ $(target_CFLAGS) \ $(NULL) CXXFLAGS += \ $(COMMONCFLAGS) \ $(target_CXXFLAGS) \ -fno-exceptions \ -fno-rtti \ $(NULL) LDFLAGS += \ $(COMMONCFLAGS) \ $(target_LDFLAGS) \ -nostartfiles \ -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 = cc2538 ARCHS = cortex-m3 TopTargetLibDir = $(TopResultDir)/$(TargetTuple)/lib ifndef BuildJobs BuildJobs := $(shell getconf _NPROCESSORS_ONLN) endif JOBSFLAG := -j$(BuildJobs) # # configure-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)" OBJC="$(OBJC)" OBJCXX="$(OBJCXX)" AR="$(AR)" RANLIB="$(RANLIB)" NM="$(NM)" STRIP="$(STRIP)" CPPFLAGS="$(CPPFLAGS)" CFLAGS="$(CFLAGS)" CXXFLAGS="$(CXXFLAGS)" LDFLAGS="$(LDFLAGS)" \ --host=arm-none-eabi \ --prefix=/ \ --exec-prefix=/$(TargetTuple) \ $(configure_OPTIONS)) endef # configure-arch # # build-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 # # 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 # # ARCH_template # # 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) 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): $(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)) stage-$(1): do-build-$(1) stage-$(1): | $(TopResultDir) $$(call stage-arch,$(1)) $(1): stage-$(1) endef # ARCH_template .DEFAULT_GOAL := all all: stage # # cortex-m3 # cortex-m3_target_ABI = cortex-m3 cortex-m3_target_CPPFLAGS = -mcpu=cortex-m3 -mfloat-abi=soft -mthumb cortex-m3_target_CFLAGS = -mcpu=cortex-m3 -mfloat-abi=soft -mthumb cortex-m3_target_CXXFLAGS = -mcpu=cortex-m3 -mfloat-abi=soft -mthumb cortex-m3_target_LDFLAGS = -mcpu=cortex-m3 -mfloat-abi=soft -mthumb # 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) DIRECTORIES = $(TopResultDir) $(TopResultDir)/$(TargetTuple)/lib $(BUILD_DIRS) CLEAN_DIRS = $(TopResultDir) $(BUILD_DIRS) all: stage $(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)) " $(ECHO) ""