310 lines
8.1 KiB
Makefile
Raw Normal View History

2012-08-14 18:07:04 -04:00
##############################################################################
2015-04-28 13:45:35 -04:00
# Product: Makefile for DPP on EK-TM4C123GXL, QV kernel, GNU-ARM
2015-10-10 10:50:06 -04:00
# Last Updated for Version: 5.5.1
# Date of the Last Update: 2015-10-05
2012-08-14 18:07:04 -04:00
#
# Q u a n t u m L e a P s
# ---------------------------
# innovating embedded systems
#
2015-05-22 20:36:44 -04:00
# Copyright (C) Quantum Leaps, LLC. All rights reserved.
2012-08-14 18:07:04 -04:00
#
# This program is open source software: you can redistribute it and/or
# modify it under the terms of the GNU General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
2012-08-14 18:07:04 -04:00
# (at your option) any later version.
#
# Alternatively, this program may be distributed and modified under the
# terms of Quantum Leaps commercial licenses, which expressly supersede
# the GNU General Public License and are specifically designed for
# licensees interested in retaining the proprietary status of their code.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# Contact information:
2015-09-04 12:08:22 -04:00
# http://www.state-machine.com
# mailto:info@state-machine.com
2012-08-14 18:07:04 -04:00
##############################################################################
# examples of invoking this Makefile:
# building configurations: Debug (default), Release, and Spy
# make
# make CONF=rel
# make CONF=spy
#
# cleaning configurations: Debug (default), Release, and Spy
# make clean
# make CONF=rel clean
# make CONF=spy clean
2015-04-28 13:45:35 -04:00
#
# NOTE:
# To use this Makefile on Windows, you will need the GNU make utility, which
# is included in the Qtools collection for Windows, see:
# http://sourceforge.net/projects/qpc/files/Qtools/
#
2012-08-14 18:07:04 -04:00
#-----------------------------------------------------------------------------
2015-04-28 13:45:35 -04:00
# project name
2012-08-14 18:07:04 -04:00
#
2015-04-28 13:45:35 -04:00
PROJECT := dpp-qv
2012-08-14 18:07:04 -04:00
2013-09-23 14:34:35 -04:00
#-----------------------------------------------------------------------------
2015-04-28 13:45:35 -04:00
# project directories
2013-09-23 14:34:35 -04:00
#
2015-04-28 13:45:35 -04:00
# location of the QP/C framework (if not provided in an environemnt var.)
ifeq ($(QPC),)
QPC := ../../../../..
2013-09-23 14:34:35 -04:00
endif
2015-04-28 13:45:35 -04:00
# QP port used in this project
QP_PORT_DIR := $(QPC)/ports/arm-cm/qv/gnu
# list of all source directories used by this project
VPATH = \
.. \
../.. \
$(QPC)/source \
$(QP_PORT_DIR) \
$(QPC)/3rd_party/ek-tm4c123gxl \
2015-05-14 15:45:53 -04:00
$(QPC)/3rd_party/ek-tm4c123gxl/gnu
2015-04-28 13:45:35 -04:00
# list of all include directories needed by this project
INCLUDES = \
2015-05-14 15:45:53 -04:00
-I../.. \
2015-04-28 13:45:35 -04:00
-I$(QPC)/include \
-I$(QPC)/source \
-I$(QP_PORT_DIR) \
-I$(QPC)/3rd_party/CMSIS/Include \
-I$(QPC)/3rd_party/ek-tm4c123gxl
2012-08-14 18:07:04 -04:00
#-----------------------------------------------------------------------------
2015-04-28 13:45:35 -04:00
# files
2012-08-14 18:07:04 -04:00
#
2015-04-28 13:45:35 -04:00
# assembler source files
ASM_SRCS :=
# C source files
C_SRCS := \
bsp.c \
main.c \
philo.c \
table.c \
system_TM4C123GH6PM.c \
startup_TM4C123GH6PM.c
# C++ source files
CPP_SRCS :=
2012-08-14 18:07:04 -04:00
2013-09-23 14:34:35 -04:00
OUTPUT := $(PROJECT)
2015-04-28 13:45:35 -04:00
LD_SCRIPT := $(PROJECT).ld
2012-08-14 18:07:04 -04:00
2015-04-28 13:45:35 -04:00
QP_SRCS := \
qep_hsm.c \
qep_msm.c \
qf_act.c \
qf_actq.c \
qf_defer.c \
qf_dyn.c \
qf_mem.c \
qf_ps.c \
qf_qact.c \
qf_qeq.c \
qf_qmact.c \
qf_time.c \
qv.c
QP_ASMS :=
QS_SRCS := \
qs.c \
2015-09-04 12:08:22 -04:00
qs_rx.c \
2015-04-28 13:45:35 -04:00
qs_fp.c
LIB_DIRS :=
LIBS :=
2012-08-14 18:07:04 -04:00
# defines
2015-05-22 20:36:44 -04:00
DEFINES :=
2012-08-14 18:07:04 -04:00
2015-04-28 13:45:35 -04:00
# ARM CPU, FPU, and Float-ABI types
ARM_CPU := -mcpu=cortex-m4
ARM_FPU := -mfpu=vfp
2015-09-04 12:08:22 -04:00
FLOAT_ABI := -mfloat-abi=softfp
2013-12-30 17:37:40 -05:00
#-----------------------------------------------------------------------------
2015-04-28 13:45:35 -04:00
# GNU-ARM toolset (NOTE: You need to adjust to your machine)
# see http://gnutoolchains.com/arm-eabi/
2013-12-30 17:37:40 -05:00
#
ifeq ($(GNU_ARM),)
2015-04-28 13:45:35 -04:00
GNU_ARM = C:/tools/gnu_arm-eabi
2013-12-30 17:37:40 -05:00
endif
2015-04-28 13:45:35 -04:00
# make sure that the GNU-ARM toolset exists...
ifeq ("$(wildcard $(GNU_ARM))","")
$(error GNU_ARM toolset not found. Please adjust the Makefile)
endif
CC := $(GNU_ARM)/bin/arm-eabi-gcc
CPP := $(GNU_ARM)/bin/arm-eabi-g++
AS := $(GNU_ARM)/bin/arm-eabi-as
LINK := $(GNU_ARM)/bin/arm-eabi-gcc
BIN := $(GNU_ARM)/bin/arm-eabi-objcopy
2013-12-30 17:37:40 -05:00
##############################################################################
# Typically, you should not need to change anything below this line
2015-04-28 13:45:35 -04:00
# basic utilities (included in Qtools for Windows), see:
# http://sourceforge.net/projects/qpc/files/Qtools
2013-12-30 17:37:40 -05:00
MKDIR := mkdir
RM := rm
2012-08-14 18:07:04 -04:00
#-----------------------------------------------------------------------------
2015-04-28 13:45:35 -04:00
# build options for various configurations for ARM Cortex-M4F
2012-08-14 18:07:04 -04:00
#
2015-05-22 20:36:44 -04:00
# combine all the soruces...
2015-04-28 13:45:35 -04:00
C_SRCS += $(QP_SRCS)
ASM_SRCS += $(QP_ASMS)
2012-08-14 18:07:04 -04:00
2015-05-22 20:36:44 -04:00
# add the pre-defined symbol __FPU_PRESENT if needed...
ifneq (,$(ARM_FPU))
DEFINES += -D__FPU_PRESENT
ASM_FPU += -defsym=__FPU_PRESENT=1
endif
2012-08-14 18:07:04 -04:00
2015-05-22 20:36:44 -04:00
ifeq (rel, $(CONF)) # Release configuration ..................................
2012-08-14 18:07:04 -04:00
BIN_DIR := rel
2015-05-22 20:36:44 -04:00
ASFLAGS = $(ARM_CPU) $(ASM_FPU)
2012-08-14 18:07:04 -04:00
2015-04-28 13:45:35 -04:00
CFLAGS = $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
2015-05-22 20:36:44 -04:00
-ffunction-sections -fdata-sections \
2015-10-10 10:50:06 -04:00
-O1 $(INCLUDES) $(DEFINES) -DNDEBUG
2012-08-14 18:07:04 -04:00
2015-05-22 20:36:44 -04:00
CPPFLAGS = $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
-ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
2015-10-10 10:50:06 -04:00
-O1 $(INCLUDES) $(DEFINES) -DNDEBUG
2012-08-14 18:07:04 -04:00
else ifeq (spy, $(CONF)) # Spy configuration ................................
BIN_DIR := spy
2015-04-28 13:45:35 -04:00
C_SRCS += $(QS_SRCS)
2012-08-14 18:07:04 -04:00
2015-05-22 20:36:44 -04:00
ASFLAGS = -g $(ARM_CPU) $(ASM_FPU)
2012-08-14 18:07:04 -04:00
2015-04-28 13:45:35 -04:00
CFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
2015-05-22 20:36:44 -04:00
-ffunction-sections -fdata-sections \
2015-04-28 13:45:35 -04:00
-O $(INCLUDES) $(DEFINES) -DQ_SPY
2015-05-22 20:36:44 -04:00
CPPFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
-ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
-O $(INCLUDES) $(DEFINES) -DQ_SPY
2012-08-14 18:07:04 -04:00
2015-05-22 20:36:44 -04:00
else # default Debug configuration ..........................................
2012-08-14 18:07:04 -04:00
BIN_DIR := dbg
2015-05-22 20:36:44 -04:00
ASFLAGS = -g $(ARM_CPU) $(ASM_FPU)
2012-08-14 18:07:04 -04:00
2015-04-28 13:45:35 -04:00
CFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
2015-05-22 20:36:44 -04:00
-ffunction-sections -fdata-sections \
-O $(INCLUDES) $(DEFINES)
2012-08-14 18:07:04 -04:00
2015-05-22 20:36:44 -04:00
CPPFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
-ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
2015-04-28 13:45:35 -04:00
-O $(INCLUDES) $(DEFINES)
2012-08-14 18:07:04 -04:00
2015-05-22 20:36:44 -04:00
endif # ......................................................................
2015-04-28 13:45:35 -04:00
LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) \
-mthumb -nostdlib \
-Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
2012-08-14 18:07:04 -04:00
2015-04-28 13:45:35 -04:00
ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
2012-08-14 18:07:04 -04:00
2013-09-23 14:34:35 -04:00
TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
2012-08-14 18:07:04 -04:00
TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
2015-04-28 13:45:35 -04:00
# create $(BIN_DIR) if it does not exist
ifeq ("$(wildcard $(BIN_DIR))","")
$(shell $(MKDIR) $(BIN_DIR))
endif
2012-08-14 18:07:04 -04:00
#-----------------------------------------------------------------------------
# rules
#
2015-04-28 13:45:35 -04:00
all: $(TARGET_BIN)
#all: $(TARGET_ELF)
2012-08-14 18:07:04 -04:00
$(TARGET_BIN): $(TARGET_ELF)
2013-09-23 14:34:35 -04:00
$(BIN) -O binary $< $@
2012-08-14 18:07:04 -04:00
$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
2015-09-04 12:08:22 -04:00
$(CC) $(CFLAGS) -c $(QPC)/include/qstamp.c -o $(BIN_DIR)/qstamp.o
$(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
2012-08-14 18:07:04 -04:00
$(BIN_DIR)/%.d : %.c
$(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
$(BIN_DIR)/%.d : %.cpp
$(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
$(BIN_DIR)/%.o : %.s
$(AS) $(ASFLAGS) $< -o $@
$(BIN_DIR)/%.o : %.c
$(CC) $(CFLAGS) -c $< -o $@
$(BIN_DIR)/%.o : %.cpp
$(CPP) $(CPPFLAGS) -c $< -o $@
2013-12-30 17:37:40 -05:00
# include dependency files only if our goal depends on their existence
ifneq ($(MAKECMDGOALS),clean)
ifneq ($(MAKECMDGOALS),show)
2012-08-14 18:07:04 -04:00
-include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
2013-12-30 17:37:40 -05:00
endif
endif
2012-08-14 18:07:04 -04:00
2015-04-28 13:45:35 -04:00
2012-08-14 18:07:04 -04:00
.PHONY : clean
clean:
-$(RM) $(BIN_DIR)/*.o \
$(BIN_DIR)/*.d \
2013-09-23 14:34:35 -04:00
$(BIN_DIR)/*.bin \
2012-08-14 18:07:04 -04:00
$(BIN_DIR)/*.elf \
$(BIN_DIR)/*.map
show:
2015-05-22 20:36:44 -04:00
@echo PROJECT = $(PROJECT)
2012-08-14 18:07:04 -04:00
@echo CONF = $(CONF)
2015-05-22 20:36:44 -04:00
@echo DEFINES = $(DEFINES)
@echo ASM_FPU = $(ASM_FPU)
2012-08-14 18:07:04 -04:00
@echo ASM_SRCS = $(ASM_SRCS)
@echo C_SRCS = $(C_SRCS)
@echo CPP_SRCS = $(CPP_SRCS)
@echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
@echo C_OBJS_EXT = $(C_OBJS_EXT)
@echo C_DEPS_EXT = $(C_DEPS_EXT)
@echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
@echo TARGET_ELF = $(TARGET_ELF)