mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge pull request #13862 from maribu/extra_boards
Makefile*: Allow multiple external board dirs
This commit is contained in:
commit
919249f361
1
.murdock
1
.murdock
@ -230,7 +230,6 @@ compile() {
|
||||
# sanity checks
|
||||
[ $# -ne 2 ] && error "$0: compile: invalid parameters (expected \$appdir \$board:\$toolchain)"
|
||||
[ ! -d "$appdir" ] && error "$0: compile: error: application directory \"$appdir\" doesn't exist"
|
||||
[ ! -d "boards/$board" ] && error "$0: compile: error: board directory \"boards/$board\" doesn't exist"
|
||||
|
||||
# compile
|
||||
CCACHE_BASEDIR="$(pwd)" BOARD=$board TOOLCHAIN=$toolchain RIOT_CI_BUILD=1 \
|
||||
|
@ -2,7 +2,7 @@
|
||||
-include $(APPDIR)/Makefile.board.dep
|
||||
|
||||
# include board dependencies
|
||||
-include $(BOARDSDIR)/$(BOARD)/Makefile.dep
|
||||
-include $(BOARDDIR)/Makefile.dep
|
||||
|
||||
# include cpu dependencies
|
||||
-include $(RIOTCPU)/$(CPU)/Makefile.dep
|
||||
|
@ -9,7 +9,7 @@
|
||||
# Moving 'CPU/CPU_MODEL' to Makefile.features is an ongoing work and may not
|
||||
# reflect the state of all boards for the moment.
|
||||
|
||||
include $(BOARDSDIR)/$(BOARD)/Makefile.features
|
||||
include $(BOARDDIR)/Makefile.features
|
||||
|
||||
# Sanity check
|
||||
ifeq (,$(CPU))
|
||||
|
@ -34,9 +34,9 @@ include $(RIOT_MAKEFILES_GLOBAL_PRE)
|
||||
# set undefined variables
|
||||
RIOTBASE ?= $(_riotbase)
|
||||
RIOTCPU ?= $(RIOTBASE)/cpu
|
||||
# Deprecated to set RIOTBOARD, use BOARDSDIR
|
||||
# Deprecated to set RIOTBOARD, use EXTERNAL_BOARD_DIRS
|
||||
RIOTBOARD ?= $(RIOTBASE)/boards
|
||||
BOARDSDIR ?= $(RIOTBOARD)
|
||||
EXTERNAL_BOARD_DIRS ?=
|
||||
RIOTMAKE ?= $(RIOTBASE)/makefiles
|
||||
RIOTPKG ?= $(RIOTBASE)/pkg
|
||||
RIOTTOOLS ?= $(RIOTBASE)/dist/tools
|
||||
@ -76,13 +76,35 @@ __OVERRIDE_DIRECTORY_VARIABLES := $(__DIRECTORY_VARIABLES)
|
||||
# Use absolute paths in recursive "make" even if overridden on command line.
|
||||
MAKEOVERRIDES += $(foreach v,$(__OVERRIDE_DIRECTORY_VARIABLES),$(v)=$($(v)))
|
||||
|
||||
# Setting EXTERNAL_BOARD_DIRS as command line argument is too messy to handle:
|
||||
# Even when every path in EXTERNAL_BOARD_DIRS is turned into an absolute path
|
||||
# using override, sub-makes will still get the original value. Using
|
||||
# MAKEOVERRIDES has issues with spaces in the values, which are used as
|
||||
# separator in EXTERNAL_BOARD_DIRS. So we just enforce setting the value
|
||||
# either in a Makefile, or as environment variable.
|
||||
ifeq ($(origin EXTERNAL_BOARD_DIRS),command line)
|
||||
# In Docker absolute paths are always given, so only fail when not in docker
|
||||
ifeq ($(INSIDE_DOCKER),0)
|
||||
$(error EXTERNAL_BOARD_DIRS must be passed as environment variable, and not as command line argument)
|
||||
endif
|
||||
endif
|
||||
|
||||
# Deprecation of configuring 'RIOTBOARD'
|
||||
ifneq ($(abspath $(RIOTBASE)/boards),$(abspath $(RIOTBOARD)))
|
||||
$(warning overriding RIOTBOARD for external boards is deprecated, please use an absolute BOARDSDIR)
|
||||
$(warning overriding RIOTBOARD for external boards is deprecated, use EXTERNAL_BOARD_DIRS instead)
|
||||
override RIOTBOARD := $(abspath $(RIOTBOARD))
|
||||
__DIRECTORY_VARIABLES += RIOTBOARD
|
||||
endif
|
||||
|
||||
ifneq (,$(BOARDSDIR))
|
||||
# Only warn users, not the CI.
|
||||
ifneq ($(RIOT_CI_BUILD),1)
|
||||
$(warning Using BOARDSDIR is deprecated use EXTERNAL_BOARD_DIRS instead)
|
||||
$(info EXTERNAL_BOARD_DIRS can contain multiple folders separated by space)
|
||||
endif
|
||||
EXTERNAL_BOARD_DIRS += $(BOARDSDIR)
|
||||
endif
|
||||
|
||||
# Make all paths absolute.
|
||||
override RIOTBASE := $(abspath $(RIOTBASE))
|
||||
override RIOTCPU := $(abspath $(RIOTCPU))
|
||||
@ -97,13 +119,9 @@ override BINDIRBASE := $(abspath $(BINDIRBASE))
|
||||
override BINDIR := $(abspath $(BINDIR))
|
||||
override PKGDIRBASE := $(abspath $(PKGDIRBASE))
|
||||
override DLCACHE_DIR := $(abspath $(DLCACHE_DIR))
|
||||
|
||||
# Keep standard make behavior for new variables
|
||||
__DIRECTORY_VARIABLES += \
|
||||
BOARDSDIR \
|
||||
#
|
||||
|
||||
BOARDSDIR := $(abspath $(BOARDSDIR))
|
||||
EXTERNAL_BOARD_DIRS := $(foreach dir,\
|
||||
$(EXTERNAL_BOARD_DIRS),\
|
||||
$(abspath $(dir)))
|
||||
|
||||
# Ensure that all directories are set and don't contain spaces.
|
||||
ifneq (, $(filter-out 1, $(foreach v,$(__DIRECTORY_VARIABLES),$(words $($(v))))))
|
||||
@ -168,19 +186,22 @@ else
|
||||
|
||||
all: link
|
||||
|
||||
# Include Board and CPU configuration, if BOARD is not found in BOARDSDIR
|
||||
# e.g. when set by the environment fallback to searching in RIOTBOARD
|
||||
ifeq (,$(wildcard $(BOARDSDIR)/$(BOARD)/.))
|
||||
ifneq ($(RIOTBOARD),$(BOARDSDIR))
|
||||
# The specified board $(BOARD) was not found in $(BOARDSDIR) fallback to RIOTBOARD
|
||||
BOARDSDIR = $(RIOTBOARD)
|
||||
endif
|
||||
ifeq ($(RIOTBOARD),$(BOARDSDIR))
|
||||
ifeq (,$(wildcard $(BOARDSDIR)/$(BOARD)/.))
|
||||
# Folders to search: First the external boards, than the official
|
||||
BOARDSDIRS := $(EXTERNAL_BOARD_DIRS) $(RIOTBOARD)
|
||||
|
||||
# Take the first folder in $(BOARDSDIRS) that contains a folder named $(BOARD)
|
||||
BOARDDIR := $(word 1,$(foreach dir,$(BOARDSDIRS),$(wildcard $(dir)/$(BOARD)/.)))
|
||||
# Sanitize folder
|
||||
BOARDDIR := $(abspath $(BOARDDIR))
|
||||
|
||||
# Also provide BOARDSDIR for compatibility and for accessing common folders
|
||||
# (e.g. include $(BOARDSDIR)/common/external_common/Makefile.dep)
|
||||
BOARDSDIR := $(dir $(BOARDDIR))
|
||||
|
||||
ifeq (,$(BOARDDIR))
|
||||
$(info Folders searched for the board: $(BOARDSDIRS))
|
||||
$(error The specified board $(BOARD) does not exist.)
|
||||
endif
|
||||
endif
|
||||
endif
|
||||
|
||||
include $(RIOTMAKE)/info.inc.mk
|
||||
|
||||
@ -341,8 +362,8 @@ include $(RIOTMAKE)/pseudomodules.inc.mk
|
||||
include $(RIOTMAKE)/defaultmodules.inc.mk
|
||||
|
||||
# Include Board and CPU configuration
|
||||
INCLUDES += $(addprefix -I,$(wildcard $(BOARDSDIR)/$(BOARD)/include))
|
||||
include $(BOARDSDIR)/$(BOARD)/Makefile.include
|
||||
INCLUDES += $(addprefix -I,$(wildcard $(BOARDDIR)/include))
|
||||
include $(BOARDDIR)/Makefile.include
|
||||
INCLUDES += -I$(RIOTCPU)/$(CPU)/include
|
||||
include $(RIOTCPU)/$(CPU)/Makefile.include
|
||||
|
||||
|
@ -226,9 +226,10 @@ All `BOARD`s in RIOT reside in `RIOTBOARD` (`RIOTBOARD` being a make variable
|
||||
set to `$(RIOTBOARD)/boards`).
|
||||
|
||||
If one wants to use a `BOARD` outside of `RIOTBOARD`, the way to go is setting
|
||||
the `BOARDSDIR` variable to the path to the directory containing your external
|
||||
boards, e.g.: `BOARDSDIR=/home/external-boards/` (this would commonly be done
|
||||
in your application `Makefile` or your environment).
|
||||
the `EXTERNAL_BOARD_DIRS` variable to the path to the directory containing your
|
||||
external boards, e.g.: `EXTERNAL_BOARD_DIRS=/home/external-boards/` (this would
|
||||
commonly be done in your application `Makefile` or your environment). You can
|
||||
specify multiple directories separated by spaces.
|
||||
|
||||
```
|
||||
/home/
|
||||
|
@ -10,7 +10,7 @@ RIOTBASE ?= $(CURDIR)/../..
|
||||
# Uncomment these lines if you want to use platform support from external
|
||||
# repositories:
|
||||
#RIOTCPU ?= $(CURDIR)/../../RIOT/thirdparty_cpu
|
||||
#BOARDSDIR ?= $(CURDIR)/../../RIOT/thirdparty_boards
|
||||
#EXTERNAL_BOARD_DIRS ?= $(CURDIR)/../../RIOT/thirdparty_boards
|
||||
|
||||
# Uncomment this to enable scheduler statistics for ps:
|
||||
#USEMODULE += schedstatistics
|
||||
|
@ -10,7 +10,7 @@ RIOTBASE ?= $(CURDIR)/../..
|
||||
# Uncomment these lines if you want to use platform support from external
|
||||
# repositories:
|
||||
#RIOTCPU ?= $(CURDIR)/../../../thirdparty_cpu
|
||||
#BOARDSDIR ?= $(CURDIR)/../../../thirdparty_boards
|
||||
#EXTERNAL_BOARD_DIRS ?= $(CURDIR)/../../../thirdparty_boards
|
||||
|
||||
# Uncomment this to enable scheduler statistics for ps:
|
||||
#CFLAGS += -DSCHEDSTATISTICS
|
||||
|
@ -1,6 +1,6 @@
|
||||
MODULE = $(APPLICATION_MODULE)
|
||||
|
||||
DIRS += $(RIOTCPU)/$(CPU) $(BOARDSDIR)/$(BOARD)
|
||||
DIRS += $(RIOTCPU)/$(CPU) $(BOARDDIR)
|
||||
DIRS += $(RIOTBASE)/core $(RIOTBASE)/drivers $(RIOTBASE)/sys
|
||||
|
||||
# For regular modules, adding files to BLOBS to their Makefile is sufficient to
|
||||
|
@ -1,19 +1,17 @@
|
||||
# Default when RIOTBASE is not set and is executed from the RIOT directory
|
||||
RIOTBOARD ?= $(or $(RIOTBASE),$(CURDIR))/boards
|
||||
BOARDSDIR ?= $(RIOTBOARD)
|
||||
BOARDSDIRS ?= $(EXTERNAL_BOARD_DIRS) $(RIOTBOARD)
|
||||
|
||||
# List all boards in a directory
|
||||
# By default, all directories in BOARDSDIR except 'common'
|
||||
# By default, all directories in board directory except 'common'
|
||||
# use 'wildcard */.' to only list directories
|
||||
_get_boards_in_directory = $(filter-out common,$(patsubst $1/%/.,%,$(wildcard $1/*/.)))
|
||||
|
||||
# If BOARDSDIR is not in RIOTBOARD also list BOARDS in RIOTBOARD
|
||||
ifneq ($(RIOTBOARD),$(BOARDSDIR))
|
||||
ALLBOARDS_RIOTBOARD ?= $(call _get_boards_in_directory,$(RIOTBOARD))
|
||||
endif
|
||||
|
||||
# Use `:=` so that it is evaluated before BOARDSDIR gets eventually changed
|
||||
ALLBOARDS := $(sort $(call _get_boards_in_directory,$(BOARDSDIR)) $(ALLBOARDS_RIOTBOARD))
|
||||
# Use `:=` so that it is evaluated before BOARDSDIRS gets eventually changed
|
||||
ALLBOARDS := $(sort \
|
||||
$(foreach dir,\
|
||||
$(BOARDSDIRS),\
|
||||
$(call _get_boards_in_directory,$(dir))))
|
||||
|
||||
# Set the default value from `BOARDS`
|
||||
BOARDS ?= $(ALLBOARDS)
|
||||
|
@ -79,7 +79,7 @@ riotboot/flash-bootloader: riotboot/bootloader/flash
|
||||
riotboot/bootloader/%:
|
||||
$(Q)/usr/bin/env -i \
|
||||
QUIET=$(QUIET) PATH=$(PATH)\
|
||||
BOARDSDIR=$(BOARDSDIR) BOARD=$(BOARD)\
|
||||
EXTERNAL_BOARD_DIRS="$(EXTERNAL_BOARD_DIRS)" BOARD=$(BOARD)\
|
||||
DEBUG_ADAPTER_ID=$(DEBUG_ADAPTER_ID)\
|
||||
$(MAKE) --no-print-directory -C $(RIOTBOOT_DIR) $*
|
||||
|
||||
|
@ -251,11 +251,11 @@ DOCKER_VOLUMES_AND_ENV += $(if $(wildcard $(GIT_CACHE_DIR)),-e 'GIT_CACHE_DIR=$(
|
||||
DOCKER_VOLUMES_AND_ENV += $(call docker_volumes_mapping,$(EXTERNAL_MODULE_DIRS),$(DOCKER_BUILD_ROOT)/external,)
|
||||
DOCKER_OVERRIDE_CMDLINE += $(call docker_cmdline_mapping,EXTERNAL_MODULE_DIRS,$(DOCKER_BUILD_ROOT)/external,)
|
||||
|
||||
# Remap 'BOARDSDIR' if it is external
|
||||
DOCKER_VOLUMES_AND_ENV += $(call docker_volumes_mapping,$(BOARDSDIR),,boards)
|
||||
# Remap 'EXTERNAL_BOARD_DIRS' if they are external
|
||||
DOCKER_VOLUMES_AND_ENV += $(call docker_volumes_mapping,$(EXTERNAL_BOARD_DIRS),$(DOCKER_BUILD_ROOT)/external,)
|
||||
# Value is overridden from command line if it is not the default value
|
||||
# This allows handling even if the value is set in the 'Makefile'.
|
||||
DOCKER_OVERRIDE_CMDLINE += $(if $(findstring $(RIOTBOARD),$(BOARDSDIR)),,$(call docker_cmdline_mapping,BOARDSDIR,,boards))
|
||||
DOCKER_OVERRIDE_CMDLINE += $(call docker_cmdline_mapping,EXTERNAL_BOARD_DIRS,$(DOCKER_BUILD_ROOT)/external,)
|
||||
|
||||
# External module directories sanity check:
|
||||
#
|
||||
|
@ -11,7 +11,7 @@ include $(RIOTMAKE)/defaultmodules.inc.mk
|
||||
USEMODULE += $(filter-out $(DISABLE_MODULE),$(DEFAULT_MODULE))
|
||||
include $(RIOTMAKE)/dependency_resolution.inc.mk
|
||||
|
||||
BOARDSDIR_GLOBAL := $(BOARDSDIR)
|
||||
BOARDDIR_GLOBAL := $(BOARDDIR)
|
||||
USEMODULE_GLOBAL := $(USEMODULE)
|
||||
USEPKG_GLOBAL := $(USEPKG)
|
||||
FEATURES_REQUIRED_GLOBAL := $(FEATURES_REQUIRED)
|
||||
@ -24,7 +24,6 @@ FEATURES_BLACKLIST_GLOBAL := $(FEATURES_BLACKLIST)
|
||||
|
||||
define board_unsatisfied_features
|
||||
BOARD := $(1)
|
||||
BOARDSDIR := $(BOARDSDIR_GLOBAL)
|
||||
USEMODULE := $(USEMODULE_GLOBAL)
|
||||
USEPKG := $(USEPKG_GLOBAL)
|
||||
DISABLE_MODULE := $(DISABLE_MODULE_GLOBAL)
|
||||
@ -35,6 +34,9 @@ define board_unsatisfied_features
|
||||
FEATURES_CONFLICT_MSG := $(FEATURES_CONFLICT_MSG_GLOBAL)
|
||||
FEATURES_BLACKLIST:= $(FEATURES_BLACKLIST_GLOBAL)
|
||||
|
||||
# Find matching board folder
|
||||
BOARDDIR := $(word 1,$(foreach dir,$(BOARDSDIRS),$(wildcard $(dir)/$(BOARD)/.)))
|
||||
|
||||
# Remove board specific variables set by Makefile.features/Makefile.dep
|
||||
FEATURES_PROVIDED :=
|
||||
FEATURES_USED :=
|
||||
@ -46,12 +48,6 @@ define board_unsatisfied_features
|
||||
undefine CPU_ARCH
|
||||
undefine CPU_FAM
|
||||
|
||||
# Replicate Makefile.include handling that sets BOARDSDIR to RIOTBOARD
|
||||
# when BOARD is not found in BOARDSDIR
|
||||
ifeq (,$(wildcard $(BOARDSDIR_GLOBAL)/$(BOARD)/.))
|
||||
BOARDSDIR = $(RIOTBOARD)
|
||||
endif
|
||||
|
||||
include $(RIOTBASE)/Makefile.features
|
||||
# FEATURES_USED must be populated first in this case so that dependency
|
||||
# resolution can take optional features into account during the first pass.
|
||||
@ -132,4 +128,4 @@ info-boards-features-missing:
|
||||
|
||||
# Reset BOARDSDIR so unchanged for makefiles included after, for now only
|
||||
# needed for buildtests.inc.mk
|
||||
BOARDSDIR := $(BOARDSDIR_GLOBAL)
|
||||
BOARDDIR := $(BOARDDIR_GLOBAL)
|
||||
|
@ -35,7 +35,8 @@ info-build:
|
||||
@echo 'MCU: $(MCU)'
|
||||
@echo ''
|
||||
@echo 'RIOTBASE: $(RIOTBASE)'
|
||||
@echo 'BOARDSDIR: $(BOARDSDIR)'
|
||||
@echo 'BOARDDIR: $(BOARDDIR)'
|
||||
@echo 'EXTERNAL_BOARD_DIRS:$(EXTERNAL_BOARD_DIRS)'
|
||||
@echo 'RIOTCPU: $(RIOTCPU)'
|
||||
@echo 'RIOTPKG: $(RIOTPKG)'
|
||||
@echo ''
|
||||
|
@ -7,6 +7,7 @@ SCANBUILD_ENV_VARS := \
|
||||
BINDIR \
|
||||
BINDIRBASE \
|
||||
BOARD \
|
||||
BOARDDIR \
|
||||
BOARDSDIR \
|
||||
BUILD_DIR \
|
||||
BUILDRELPATH \
|
||||
|
@ -1,5 +1,5 @@
|
||||
FLASHER = avrdude
|
||||
DIST_PATH = $(BOARDSDIR)/$(BOARD)/dist
|
||||
DIST_PATH = $(BOARDDIR)/dist
|
||||
AVARICE_PATH = $(RIOTTOOLS)/avarice
|
||||
DEBUGSERVER_PORT = 4242
|
||||
DEBUGSERVER = $(AVARICE_PATH)/debug_srv.sh
|
||||
|
@ -17,7 +17,7 @@ endif
|
||||
ifeq (,$(OPENOCD_CONFIG))
|
||||
# if no openocd default configuration is provided by the board,
|
||||
# use the STM32 common one
|
||||
ifeq (0,$(words $(wildcard $(BOARDSDIR)/$(BOARD)/dist/openocd.cfg)))
|
||||
ifeq (0,$(words $(wildcard $(BOARDDIR)/dist/openocd.cfg)))
|
||||
OPENOCD_CONFIG = $(RIOTBASE)/boards/common/stm32/dist/$(CPU).cfg
|
||||
endif
|
||||
endif
|
||||
|
@ -13,7 +13,7 @@ ifneq (,$(DEBUG_ADAPTER))
|
||||
include $(RIOTMAKE)/tools/openocd-adapters/$(DEBUG_ADAPTER).inc.mk
|
||||
endif
|
||||
|
||||
OPENOCD_CONFIG ?= $(BOARDSDIR)/$(BOARD)/dist/openocd.cfg
|
||||
OPENOCD_CONFIG ?= $(BOARDDIR)/dist/openocd.cfg
|
||||
|
||||
# Export OPENOCD_CONFIG to required targets
|
||||
OPENOCD_TARGETS = debug% flash% reset
|
||||
|
@ -1,9 +1,9 @@
|
||||
# http://www.ti.com/tool/uniflash
|
||||
FLASHFILE ?= $(ELFFILE)
|
||||
|
||||
UNIFLASH_CONFIG_CCXML ?= $(BOARDSDIR)/$(BOARD)/dist/$(CPU_MODEL)_$(XDEBUGGER).ccxml
|
||||
UNIFLASH_CONFIG_DAT ?= $(BOARDSDIR)/$(BOARD)/dist/$(CPU_MODEL)_$(XDEBUGGER).dat
|
||||
UNIFLASH_CONFIG_GDB ?= $(BOARDSDIR)/$(BOARD)/dist/$(CPU_MODEL)_gdb.conf
|
||||
UNIFLASH_CONFIG_CCXML ?= $(BOARDDIR)/dist/$(CPU_MODEL)_$(XDEBUGGER).ccxml
|
||||
UNIFLASH_CONFIG_DAT ?= $(BOARDDIR)/dist/$(CPU_MODEL)_$(XDEBUGGER).dat
|
||||
UNIFLASH_CONFIG_GDB ?= $(BOARDDIR)/dist/$(CPU_MODEL)_gdb.conf
|
||||
|
||||
UNIFLASH_PATH ?= "UNIFLASH_PATH unconfigured"
|
||||
# check which uniflash version is available, either 4.x or 3.x
|
||||
|
@ -29,7 +29,9 @@ export APPDEPS # Files / Makefile targets that need to be created
|
||||
export RIOTBASE # The root folder of RIOT. The folder where this very file lives in.
|
||||
export RIOTCPU # For third party CPUs this folder is the base of the CPUs.
|
||||
export RIOTBOARD # This folder is the base of the riot boards.
|
||||
export BOARDSDIR # For third party BOARDs this folder is the base of the BOARDs.
|
||||
export BOARDSDIR # This is the folder containing the board dir
|
||||
export EXTERNAL_BOARD_DIRS # List of folders containing external board dirs
|
||||
export BOARDDIR # This folder contains the board
|
||||
export RIOTPKG # For overriding RIOT's pkg directory
|
||||
export RIOTTOOLS # Location of host machine tools
|
||||
export RIOTPROJECT # Top level git root of the project being built, or PWD if not a git repository
|
||||
|
11
tests/external_board_dirs/Makefile
Normal file
11
tests/external_board_dirs/Makefile
Normal file
@ -0,0 +1,11 @@
|
||||
include ../Makefile.tests_common
|
||||
|
||||
# Require arch_native feature so this is not compiled for other boards in
|
||||
# $(RIOTBOARD)/
|
||||
FEATURES_REQUIRED += arch_native
|
||||
|
||||
# Set without '?=' to also verify the docker integration when set with =
|
||||
EXTERNAL_BOARD_DIRS = $(CURDIR)/external_board_dir_1
|
||||
EXTERNAL_BOARD_DIRS += $(CURDIR)/external_board_dir_2
|
||||
|
||||
include $(RIOTBASE)/Makefile.include
|
16
tests/external_board_dirs/README.md
Normal file
16
tests/external_board_dirs/README.md
Normal file
@ -0,0 +1,16 @@
|
||||
Test for `EXTERNAL_BOARD_DIRS`
|
||||
==============================
|
||||
|
||||
This test contains two directories containing external boards, namely
|
||||
`external_board_dir_1` and `external_board_dir_2`. Each contains a symlink to
|
||||
boards/native (so that this test does not need to maintain boards), the first
|
||||
is named `native1` and the second `native2`. The variable `EXTERNAL_BOARD_DIRS`
|
||||
is set to contain both directories.
|
||||
|
||||
This test succeeds if:
|
||||
|
||||
1. `make info-boards-supported` lists `native native1 native2`
|
||||
2. Building works for all three boards, e.g. by
|
||||
a) `make BOARD=native`
|
||||
b) `make BOARD=native1`
|
||||
c) `make BOARD=native2`
|
1
tests/external_board_dirs/external_board_dir_1/native1
Symbolic link
1
tests/external_board_dirs/external_board_dir_1/native1
Symbolic link
@ -0,0 +1 @@
|
||||
../../../boards/native/
|
1
tests/external_board_dirs/external_board_dir_2/native2
Symbolic link
1
tests/external_board_dirs/external_board_dir_2/native2
Symbolic link
@ -0,0 +1 @@
|
||||
../../../boards/native/
|
32
tests/external_board_dirs/main.c
Normal file
32
tests/external_board_dirs/main.c
Normal file
@ -0,0 +1,32 @@
|
||||
/*
|
||||
* Copyright (C) 2014 Freie Universität Berlin
|
||||
*
|
||||
* This file is subject to the terms and conditions of the GNU Lesser
|
||||
* General Public License v2.1. See the file LICENSE in the top level
|
||||
* directory for more details.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @ingroup examples
|
||||
* @{
|
||||
*
|
||||
* @file
|
||||
* @brief Hello World application
|
||||
*
|
||||
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
||||
* @author Ludwig Knüpfer <ludwig.knuepfer@fu-berlin.de>
|
||||
*
|
||||
* @}
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
int main(void)
|
||||
{
|
||||
puts("Hello World!");
|
||||
|
||||
printf("You are running RIOT on a(n) %s board.\n", RIOT_BOARD);
|
||||
printf("This board features a(n) %s MCU.\n", RIOT_MCU);
|
||||
|
||||
return 0;
|
||||
}
|
@ -12,3 +12,7 @@ done as the 'board' module is implemented directly by the 'RIOT/boards/native'.
|
||||
|
||||
If you are running an 'ubuntu-bionic' you could even compile the example in
|
||||
docker and run the test.
|
||||
|
||||
*Note:* This test uses still the deprecated `BOARDSDIR` variable instead of the
|
||||
new `EXTERNAL_BOARD_DIRS` variable. This is by intent so that the CI can verify
|
||||
backward compatibility is still working as intended.
|
||||
|
@ -22,7 +22,7 @@ USEMODULE += suit_transport_mock
|
||||
|
||||
# Use a version of 'native' that includes flash page support
|
||||
ifeq (native, $(BOARD))
|
||||
BOARDSDIR = $(CURDIR)/native_flashpage
|
||||
EXTERNAL_BOARD_DIRS = $(CURDIR)/native_flashpage
|
||||
endif
|
||||
|
||||
FEATURES_REQUIRED += periph_flashpage
|
||||
|
Loading…
Reference in New Issue
Block a user