2015-08-03 21:42:21 +02:00
|
|
|
# vim: filetype=make
|
2015-10-09 12:23:01 +02:00
|
|
|
#
|
|
|
|
|
2016-04-27 17:15:14 +02:00
|
|
|
UNAME := $(shell uname)
|
|
|
|
ifeq (MINGW, $(findstring MINGW, $(UNAME)))
|
2016-08-23 00:22:07 +02:00
|
|
|
DQUOTE = '
|
|
|
|
# '
|
2016-04-27 17:15:14 +02:00
|
|
|
PROJECT_BASE ?= $(shell sh -c "pwd -W")
|
|
|
|
else
|
2016-08-23 00:22:07 +02:00
|
|
|
DQUOTE = "
|
|
|
|
# "
|
2015-12-30 23:17:36 +01:00
|
|
|
PROJECT_BASE ?= $(CURDIR)
|
2016-04-27 17:15:14 +02:00
|
|
|
endif
|
|
|
|
|
2016-08-23 21:32:20 +02:00
|
|
|
ifdef BOARD
|
2016-10-19 22:13:41 +02:00
|
|
|
KBUILD_DEFCONFIG_PATH=$(wildcard $(ZEPHYR_BASE)/boards/*/*/$(BOARD)_defconfig)
|
2016-08-23 21:32:20 +02:00
|
|
|
ifeq ($(KBUILD_DEFCONFIG_PATH),)
|
|
|
|
$(error Board $(BOARD) not found!)
|
|
|
|
endif
|
|
|
|
else
|
|
|
|
$(error BOARD is not defined!)
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Choose a default output directory if one wasn't supplied. Note that
|
|
|
|
# PRISTINE_O depends on whether this is default or not. If building
|
|
|
|
# in-tree, we want to remove the whole outdir and not just the BOARD
|
|
|
|
# specified (thus "pristine"). Out of tree, we can obviously remove
|
|
|
|
# only what we were told to build.
|
|
|
|
ifndef O
|
|
|
|
PRISTINE_O = outdir
|
|
|
|
O = $(PROJECT_BASE)/outdir/$(BOARD)
|
|
|
|
else
|
|
|
|
PRISTINE_O = $(O)
|
|
|
|
endif
|
2015-08-22 20:40:43 +02:00
|
|
|
|
2015-07-23 01:15:43 +02:00
|
|
|
# Turn O into an absolute path; we call the main Kbuild with $(MAKE) -C
|
|
|
|
# which changes the working directory, relative paths don't work right.
|
2015-11-27 16:04:08 +01:00
|
|
|
# Need to create the directory first to make realpath happy
|
2016-01-30 11:36:52 +01:00
|
|
|
|
|
|
|
ifneq ($(MAKECMDGOALS),help)
|
2015-07-23 01:15:43 +02:00
|
|
|
$(shell mkdir -p $(O))
|
2015-11-27 16:04:08 +01:00
|
|
|
override O := $(realpath $(O))
|
2016-01-30 11:36:52 +01:00
|
|
|
endif
|
2015-06-01 18:48:10 +02:00
|
|
|
|
2017-04-18 22:42:09 +02:00
|
|
|
export ARCH QEMU_EXTRA_FLAGS PROJECT_BASE
|
2015-05-06 00:21:55 +02:00
|
|
|
|
2016-01-30 11:36:52 +01:00
|
|
|
override CONF_FILE := $(strip $(subst $(DQUOTE),,$(CONF_FILE)))
|
2015-10-03 16:24:57 +02:00
|
|
|
|
2015-07-17 21:03:52 +02:00
|
|
|
SOURCE_DIR ?= $(PROJECT_BASE)/src/
|
2016-08-27 00:24:13 +02:00
|
|
|
override SOURCE_DIR := $(realpath $(SOURCE_DIR))
|
2015-12-31 00:38:26 +01:00
|
|
|
override SOURCE_DIR := $(subst \,/,$(SOURCE_DIR))
|
2016-06-03 16:51:56 +02:00
|
|
|
override SOURCE_DIR_PARENT := $(patsubst %, %/.., $(SOURCE_DIR))
|
|
|
|
override SOURCE_DIR_PARENT := $(abspath $(SOURCE_DIR_PARENT))
|
|
|
|
override SOURCE_DIR_PARENT := $(subst \,/,$(SOURCE_DIR_PARENT))
|
|
|
|
export SOURCE_DIR SOURCE_DIR_PARENT
|
2015-05-21 18:08:16 +02:00
|
|
|
|
2015-05-26 23:50:44 +02:00
|
|
|
ifeq ("$(origin V)", "command line")
|
|
|
|
KBUILD_VERBOSE = $(V)
|
|
|
|
endif
|
|
|
|
ifndef KBUILD_VERBOSE
|
|
|
|
KBUILD_VERBOSE = 0
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(KBUILD_VERBOSE),1)
|
|
|
|
Q =
|
|
|
|
S =
|
|
|
|
else
|
|
|
|
Q = @
|
|
|
|
S = -s
|
|
|
|
endif
|
|
|
|
|
2016-05-20 16:54:53 +02:00
|
|
|
export CFLAGS
|
|
|
|
|
2016-06-03 20:34:18 +02:00
|
|
|
zephyrmake = +$(MAKE) -C $(ZEPHYR_BASE) O=$(1) \
|
2016-08-23 00:22:07 +02:00
|
|
|
PROJECT=$(PROJECT_BASE) SOURCE_DIR=$(DQUOTE)$(SOURCE_DIR)$(DQUOTE) $(2)
|
2015-02-21 23:05:51 +01:00
|
|
|
|
2016-05-15 03:56:35 +02:00
|
|
|
BOARDCONFIG = $(O)/.board_$(BOARD)
|
|
|
|
|
2015-08-28 21:42:03 +02:00
|
|
|
DOTCONFIG = $(O)/.config
|
|
|
|
|
|
|
|
all: $(DOTCONFIG)
|
2015-08-22 20:40:43 +02:00
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
2015-02-21 23:05:51 +01:00
|
|
|
|
2017-01-07 22:31:34 +01:00
|
|
|
debug: $(DOTCONFIG)
|
2015-08-22 20:40:43 +02:00
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
2015-05-06 00:21:55 +02:00
|
|
|
|
2017-01-07 22:31:34 +01:00
|
|
|
flash: $(DOTCONFIG)
|
2016-02-02 04:24:21 +01:00
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
2016-01-15 18:18:53 +01:00
|
|
|
|
2017-01-07 22:31:34 +01:00
|
|
|
run: $(DOTCONFIG)
|
2016-01-15 18:18:53 +01:00
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
|
|
|
|
2017-03-09 08:20:20 +01:00
|
|
|
ifeq ($(MAKECMDGOALS),debugserver)
|
2016-11-10 06:34:19 +01:00
|
|
|
ARCH = $(notdir $(subst /$(BOARD),,$(wildcard $(ZEPHYR_BASE)/boards/*/$(BOARD))))
|
2017-07-31 18:27:45 +02:00
|
|
|
BOARD_DIR = $(dir $(wildcard $(ZEPHYR_BASE)/boards/*/*/$(BOARD)_defconfig))
|
|
|
|
-include $(BOARD_DIR)/Makefile.board
|
2016-02-02 01:42:54 +01:00
|
|
|
-include $(ZEPHYR_BASE)/scripts/Makefile.toolchain.$(ZEPHYR_GCC_VARIANT)
|
|
|
|
BOARD_NAME = $(BOARD)
|
|
|
|
export BOARD_NAME
|
|
|
|
endif
|
2017-01-07 19:22:21 +01:00
|
|
|
|
2017-10-18 04:47:25 +02:00
|
|
|
ifneq ($(DEBUG_SCRIPT),)
|
2017-10-18 04:52:30 +02:00
|
|
|
debugserver: FORCE
|
|
|
|
$(Q)$(ZEPHYR_BASE)/scripts/support/zephyr_flash_debug.py debugserver $(ZEPHYR_BASE)/scripts/support/$(DEBUG_SCRIPT)
|
|
|
|
else
|
2017-10-18 04:47:25 +02:00
|
|
|
debugserver: FORCE
|
|
|
|
@echo Debugging not supported with this board.
|
|
|
|
@echo Please check the documentation for alternate instructions.
|
|
|
|
endif
|
2016-02-02 01:42:54 +01:00
|
|
|
|
2017-04-19 06:36:01 +02:00
|
|
|
initconfig: $(DOTCONFIG)
|
2015-10-03 23:49:46 +02:00
|
|
|
|
2016-05-15 03:56:35 +02:00
|
|
|
$(BOARDCONFIG):
|
|
|
|
@rm -f $(O)/.board_*
|
|
|
|
@touch $@
|
|
|
|
|
2016-05-22 18:34:06 +02:00
|
|
|
ram_report: initconfig
|
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
|
|
|
|
|
|
|
rom_report: initconfig
|
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
|
|
|
|
2017-04-19 06:36:01 +02:00
|
|
|
outputexports: initconfig
|
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
|
|
|
|
2017-04-19 06:43:58 +02:00
|
|
|
dts: initconfig
|
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
|
|
|
|
2017-06-07 04:23:33 +02:00
|
|
|
config-sanitycheck: dts
|
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
|
|
|
|
2015-10-14 23:42:59 +02:00
|
|
|
menuconfig: initconfig
|
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
|
|
|
|
2016-01-30 11:36:52 +01:00
|
|
|
help:
|
|
|
|
$(Q)$(MAKE) -s -C $(ZEPHYR_BASE) $@
|
|
|
|
|
2015-08-28 21:42:03 +02:00
|
|
|
# Catch all
|
|
|
|
%:
|
|
|
|
$(Q)$(call zephyrmake,$(O),$@)
|
2015-06-05 18:08:43 +02:00
|
|
|
|
2016-05-15 03:56:35 +02:00
|
|
|
$(DOTCONFIG): $(BOARDCONFIG) $(KBUILD_DEFCONFIG_PATH) $(CONF_FILE)
|
2015-08-28 20:22:29 +02:00
|
|
|
$(Q)$(CONFIG_SHELL) $(ZEPHYR_BASE)/scripts/kconfig/merge_config.sh \
|
2016-12-21 20:38:37 +01:00
|
|
|
-q -m -O $(O) $(KBUILD_DEFCONFIG_PATH) $(OVERLAY_CONFIG) $(CONF_FILE) \
|
2017-11-02 21:40:21 +01:00
|
|
|
$(sort $(wildcard $(O)/*.conf))
|
2015-11-27 02:39:26 +01:00
|
|
|
$(Q)$(MAKE) $(S) -C $(ZEPHYR_BASE) O=$(O) PROJECT=$(PROJECT_BASE) oldnoconfig
|
2015-08-22 20:40:43 +02:00
|
|
|
|
|
|
|
pristine:
|
2016-08-23 21:32:20 +02:00
|
|
|
$(Q)rm -rf $(PRISTINE_O)
|
2015-05-06 00:21:55 +02:00
|
|
|
|
2015-10-03 23:49:46 +02:00
|
|
|
PHONY += FORCE initconfig
|
2015-08-28 20:22:29 +02:00
|
|
|
FORCE:
|
2015-08-14 18:21:36 +02:00
|
|
|
|
2015-02-21 23:05:51 +01:00
|
|
|
.PHONY: $(PHONY)
|