144 lines
4.1 KiB
Makefile
144 lines
4.1 KiB
Makefile
#******************************************************************************
|
|
#
|
|
# Makefile - Rules for building the libraries, examples and docs.
|
|
#
|
|
# Copyright (c) 2020, Ambiq Micro
|
|
# 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.
|
|
#
|
|
# Third party software included in this distribution is subject to the
|
|
# additional license terms as defined in the /docs/licenses directory.
|
|
#
|
|
# 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.
|
|
#
|
|
# This is part of revision 2.4.2 of the AmbiqSuite Development Package.
|
|
#
|
|
#******************************************************************************
|
|
TARGET := libam_bsp
|
|
COMPILERNAME := gcc
|
|
PROJECT := libam_bsp_gcc
|
|
CONFIG := bin
|
|
|
|
SHELL:=/bin/bash
|
|
#### Setup ####
|
|
|
|
TOOLCHAIN ?= arm-none-eabi
|
|
PART = apollo2
|
|
CPU = cortex-m4
|
|
FPU = fpv4-sp-d16
|
|
#FABI = softfp
|
|
FABI = hard
|
|
|
|
#### Required Executables ####
|
|
CC = $(TOOLCHAIN)-gcc
|
|
GCC = $(TOOLCHAIN)-gcc
|
|
CPP = $(TOOLCHAIN)-cpp
|
|
LD = $(TOOLCHAIN)-ld
|
|
CP = $(TOOLCHAIN)-objcopy
|
|
OD = $(TOOLCHAIN)-objdump
|
|
RD = $(TOOLCHAIN)-readelf
|
|
AR = $(TOOLCHAIN)-ar
|
|
SIZE = $(TOOLCHAIN)-size
|
|
RM = $(shell which rm 2>/dev/null)
|
|
|
|
EXECUTABLES = CC LD CP OD AR RD SIZE GCC
|
|
K := $(foreach exec,$(EXECUTABLES),\
|
|
$(if $(shell which $($(exec)) 2>/dev/null),,\
|
|
$(info $(exec) not found on PATH ($($(exec))).)$(exec)))
|
|
$(if $(strip $(value K)),$(info Required Program(s) $(strip $(value K)) not found))
|
|
|
|
ifneq ($(strip $(value K)),)
|
|
all clean:
|
|
$(info Tools $(TOOLCHAIN)-$(COMPILERNAME) not installed.)
|
|
$(RM) -rf bin
|
|
else
|
|
|
|
DEFINES = -DAM_PART_APOLLO2
|
|
DEFINES+= -DAM_PACKAGE_BGA
|
|
DEFINES+= -Dgcc
|
|
|
|
INCLUDES = -I../../../../devices
|
|
INCLUDES+= -I../../../../mcu/apollo2
|
|
|
|
VPATH = ..
|
|
|
|
SRC = am_bsp.c
|
|
|
|
CSRC = $(filter %.c,$(SRC))
|
|
ASRC = $(filter %.s,$(SRC))
|
|
|
|
OBJS = $(CSRC:%.c=$(CONFIG)/%.o)
|
|
OBJS+= $(ASRC:%.s=$(CONFIG)/%.o)
|
|
|
|
DEPS = $(CSRC:%.c=$(CONFIG)/%.d)
|
|
DEPS+= $(ASRC:%.s=$(CONFIG)/%.d)
|
|
|
|
CFLAGS = -mthumb -mcpu=$(CPU) -mfpu=$(FPU) -mfloat-abi=$(FABI)
|
|
CFLAGS+= -ffunction-sections -fdata-sections
|
|
CFLAGS+= -MMD -MP -std=c99 -Wall
|
|
# Libraries O3 for production, examples O0 for debug.
|
|
CFLAGS+= -O3
|
|
CFLAGS+= $(DEFINES)
|
|
CFLAGS+= $(INCLUDES)
|
|
CFLAGS+=
|
|
|
|
# Additional user specified CFLAGS
|
|
CFLAGS+=$(EXTRA_CFLAGS)
|
|
|
|
ODFLAGS = -S
|
|
|
|
#### Rules ####
|
|
all: directories $(CONFIG)/$(TARGET).a
|
|
|
|
directories: $(CONFIG)
|
|
|
|
$(CONFIG):
|
|
@mkdir -p $@
|
|
|
|
$(CONFIG)/%.o: %.c $(CONFIG)/%.d $(INCS)
|
|
@echo " Compiling $(COMPILERNAME) $<" ;\
|
|
$(CC) -c $(CFLAGS) $< -o $@
|
|
|
|
$(CONFIG)/%.o: %.s $(CONFIG)/%.d $(INCS)
|
|
@echo " Assembling $(COMPILERNAME) $<" ;\
|
|
$(CC) -c $(CFLAGS) $< -o $@
|
|
|
|
$(CONFIG)/$(TARGET).a: $(OBJS)
|
|
@echo " Library $(COMPILERNAME) $@" ;\
|
|
$(AR) rsvc $@ $(OBJS)
|
|
|
|
clean:
|
|
@echo "Cleaning..." ;\
|
|
$(RM) -f $(OBJS) $(DEPS) \
|
|
$(CONFIG)/$(TARGET).a
|
|
|
|
$(CONFIG)/%.d: ;
|
|
|
|
# Automatically include any generated dependencies
|
|
-include $(DEPS)
|
|
endif
|
|
.PHONY: all clean directories
|