You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
1.8 KiB
Makefile
70 lines
1.8 KiB
Makefile
##
|
|
# @file Makefile
|
|
# Script to build source files
|
|
#
|
|
# Copyright (C) 2018 Clyne Sullivan
|
|
#
|
|
# This program is free 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
|
|
# (at your option) any later version.
|
|
#
|
|
# 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 <https://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
CROSS = arm-none-eabi-
|
|
CC = gcc
|
|
AS = as
|
|
AR = tools/rba
|
|
OBJCOPY = objcopy
|
|
STRIP = strip
|
|
|
|
MCUFLAGS = -mthumb -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16
|
|
AFLAGS = $(MCUFLAGS)
|
|
CFLAGS = $(MCUFLAGS) -ggdb \
|
|
-Iinclude -Iinclude/cmsis \
|
|
-fno-builtin -fsigned-char -ffreestanding \
|
|
-Wall -Werror -Wextra -pedantic \
|
|
-Wno-overlength-strings -Wno-discarded-qualifiers
|
|
LFLAGS = -T link.ld
|
|
|
|
CFILES = $(wildcard src/*.c)
|
|
AFILES = $(wildcard src/*.s)
|
|
|
|
OUTDIR = out
|
|
OFILES = $(patsubst src/%.c, $(OUTDIR)/%.o, $(CFILES)) \
|
|
$(patsubst src/%.s, $(OUTDIR)/%.asm.o, $(AFILES))
|
|
|
|
OUT = out/main.elf
|
|
INITRD = initrd.img
|
|
|
|
all: $(OUT)
|
|
|
|
$(OUT): $(OFILES) initrd/init libinterp.a
|
|
@echo " INITRD " $(INITRD)
|
|
@rm -f $(INITRD)
|
|
@$(AR) $(INITRD) initrd/*
|
|
@$(CROSS)$(OBJCOPY) -B arm -I binary -O elf32-littlearm $(INITRD) out/initrd.img.o
|
|
@echo " LINK " $(OUT)
|
|
@$(CROSS)$(CC) $(CFLAGS) $(LFLAGS) out/*.o -o $(OUT) -L. -linterp -lm
|
|
|
|
$(OUTDIR)/%.o: src/%.c
|
|
@echo " CC " $<
|
|
@$(CROSS)$(CC) $(CFLAGS) -c $< -o $@
|
|
|
|
$(OUTDIR)/%.asm.o: src/%.s
|
|
@echo " AS " $<
|
|
@$(CROSS)$(AS) $(AFLAGS) -c $< -o $@
|
|
|
|
clean:
|
|
@echo " CLEAN"
|
|
@rm -rf out/*
|
|
|
|
|