2016-07-14 21:10:51 +02:00
|
|
|
#! /usr/bin/make -f
|
|
|
|
#
|
2017-02-25 19:02:07 +01:00
|
|
|
# gint project Makefile
|
2016-07-14 21:10:51 +02:00
|
|
|
#
|
|
|
|
#---
|
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
#
|
|
|
|
# Build configuration
|
|
|
|
#
|
2017-04-13 21:59:13 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Some rules don't care if config files are missing (eg. clean, etc)
|
|
|
|
cfg := config/Makefile.cfg
|
|
|
|
-include $(cfg)
|
2017-04-13 21:59:13 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Those that do may use this special dependency
|
|
|
|
cfgdep := $(if $(shell [ -f $(cfg) ] || echo n),CFGDEP,$(cfg))
|
2016-11-05 22:00:23 +01:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
cf-fx := -m3 -mb -ffreestanding -nostdlib -Wall -Wextra -std=c11 -Os \
|
|
|
|
-I include $(cfg_macros)
|
|
|
|
cf-cg := -m4 -mb -ffreestanding -nostdlib -Wall -Wextra -std=c11 -Os \
|
|
|
|
-I include $(cfg_macros)
|
|
|
|
|
|
|
|
# On fx9860g, use the sh3eb-elf toolchain; on fxcg50, prefer sh4eb-elf
|
|
|
|
toolchain := $(if $(filter $(cfg_target),fx),sh3eb-elf,sh4eb-elf)
|
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Compiler flags, assembler flags, dependency generation, archiving
|
2018-04-19 13:24:26 +02:00
|
|
|
cflags := $(cf-$(cfg_target))
|
|
|
|
sflags := $(cfg_macros)
|
2018-04-09 08:31:12 +02:00
|
|
|
dflags = -MMD -MT $@ -MF $(@:.o=.d) -MP
|
|
|
|
arflags :=
|
2016-11-05 22:00:23 +01:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
#
|
|
|
|
# File listings
|
|
|
|
#
|
2016-11-05 22:00:23 +01:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
# Target file (cfg_target is either "fx" or "cg")
|
|
|
|
target := bin/libgint-$(cfg_target).a
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Automatic names for object and dependency files
|
|
|
|
src2obj = build/$(1:src/%=%).o
|
|
|
|
src2dep = build/$(1:src/%=%).d
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Source files
|
2018-04-19 13:24:26 +02:00
|
|
|
src := $(shell find src -name '*.[csS]')
|
2018-04-09 08:31:12 +02:00
|
|
|
src_obj := $(foreach s,$(src),$(call src2obj,$s))
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Files with special handling
|
2018-04-19 13:24:26 +02:00
|
|
|
# spe := build/version.o src/display/font.bmp
|
|
|
|
spe :=
|
|
|
|
spe_obj := build/version.o $(foreach s,$(spe),$(call src2obj,$s))
|
2016-07-25 09:04:22 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# All object files
|
|
|
|
obj := $(src_obj) $(spe_obj)
|
2016-07-25 09:04:22 +02:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
# Version file
|
|
|
|
version := config/version
|
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
#
|
|
|
|
# Toolchain
|
|
|
|
#
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
gcc = $(toolchain)-gcc
|
|
|
|
as = $(toolchain)-as
|
|
|
|
ld = $(toolchain)-ld
|
|
|
|
ar = $(toolchain)-ar
|
|
|
|
objcopy = $(toolchain)-objcopy
|
2018-04-09 08:31:12 +02:00
|
|
|
conv = fxconv
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
|
|
|
|
#
|
|
|
|
# Version management
|
|
|
|
#
|
|
|
|
|
|
|
|
# Retrieve version information
|
|
|
|
v_file = $(shell cat $(version) | sed 's/[-.]/ /g')
|
|
|
|
v_type = $(word 1,$(v_file))
|
|
|
|
v_major = $(word 2,$(v_file))
|
|
|
|
v_minor = $(word 3,$(v_file))
|
|
|
|
v_build = $(word 4,$(v_file))
|
|
|
|
|
|
|
|
# Create the current version symbol and the new version integer
|
|
|
|
v_newbuild = $(shell echo $$(($(v_build) + 1)))
|
|
|
|
v_letter = $(shell echo -n $(v_type) | sed -r 's/^(.).*/\1/')
|
|
|
|
v_symbol = $(shell printf '0x%02x%01x%01x%04x' "'$(v_letter)'" \
|
|
|
|
$(v_major) $(v_minor) $(v_build))
|
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
#
|
|
|
|
# Build rules
|
|
|
|
#
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
all: $(target)
|
2017-04-17 12:56:27 +02:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
$(target): $(obj) $(version) | $(dir $(target))
|
2018-04-09 08:31:12 +02:00
|
|
|
$(call cmd_l,ar,$@) $(ar) -crs $(arflags) $@ $(obj)
|
2016-07-25 09:04:22 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Assembler sources
|
|
|
|
build/%.s.o: src/%.s build/%.s.d
|
|
|
|
@ mkdir -p $(dir $@)
|
2018-04-19 13:24:26 +02:00
|
|
|
$(call cmd_b,as,$<) $(gcc) -c $< -o $@ $(sflags)
|
|
|
|
build/%.S.o: src/%.S build/%.S.d
|
|
|
|
@ mkdir -p $(dir $@)
|
|
|
|
$(call cmd_b,as,$<) $(gcc) -c $< -o $@ $(sflags)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# C sources
|
|
|
|
build/%.c.o: src/%.c build/%.c.d $(cfgdep)
|
|
|
|
@ mkdir -p $(dir $@)
|
|
|
|
$(call cmd_b,gcc,$<) $(gcc) -c $< -o $@ $(dflags) $(cflags)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Special files
|
|
|
|
$(call src2obj,src/display/font.bmp): src/display/font.bmp
|
|
|
|
@ mkdir -p $(dir $@)
|
|
|
|
$(call cmd_m,fxconv,$<) $(conv) -font $< -n gint_font -o $@
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
# Version symbol. ld generates a .stack section for unknown reasons; I fall
|
|
|
|
# back to removing it afterwards.
|
|
|
|
build/version.o:
|
|
|
|
@ mkdir -p $(dir $@)
|
|
|
|
@ echo "_GINT_VERSION = $(v_symbol);" > $@.txt
|
|
|
|
$(call cmd_b,ld,$@) $(ld) -r -R $@.txt -o $@
|
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
#
|
|
|
|
# Cleaning
|
|
|
|
#
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
clean:
|
2018-04-09 08:31:12 +02:00
|
|
|
@ rm -rf build/
|
|
|
|
distclean: clean
|
|
|
|
@ rm -rf bin/
|
2018-04-19 13:24:26 +02:00
|
|
|
@ rm -f $(config)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
#
|
|
|
|
# Utilities
|
|
|
|
#
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2018-04-19 13:24:26 +02:00
|
|
|
$(version): $(src) $(wildcard include/**/*)
|
|
|
|
@ echo '$(v_type)-$(v_major).$(v_minor)-$(v_newbuild)' > $@
|
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Evaluated when a rule requires the configuration file but it doesn't exist
|
|
|
|
CFGDEP:
|
|
|
|
@ echo "Configuration file $(cfg) is missing. Have you configured?"
|
|
|
|
@ echo "See \`./configure --help\` for details."
|
|
|
|
@ false
|
|
|
|
|
|
|
|
# Make directories: make conveniently leaves a '/' at the end of $(dir ...)
|
|
|
|
%/:
|
|
|
|
@ mkdir -p $@
|
|
|
|
# Don't try to unlink directories once they're built (that wouldn't work =p)
|
|
|
|
.PRECIOUS: %/
|
|
|
|
|
|
|
|
# Dependency information
|
|
|
|
-include $(shell [ -d build ] && find build -name *.d)
|
|
|
|
build/%.d: ;
|
|
|
|
.PRECIOUS: build/%.d
|
|
|
|
|
|
|
|
# Do not output full commands by default
|
|
|
|
VERBOSE ?=
|
|
|
|
|
|
|
|
# Simple command output method
|
|
|
|
# $1 Program name
|
|
|
|
# $2 Argument string to display
|
|
|
|
# $3 Command color
|
|
|
|
define cmd
|
|
|
|
@ echo -e "\e[""$3"";1m>\e[0;1m $1\e[0m $2"
|
|
|
|
$(if $(VERBOSE),,@)
|
|
|
|
endef
|
2016-12-25 11:45:05 +01:00
|
|
|
|
2018-04-09 08:31:12 +02:00
|
|
|
# Some pre-colored command kinds: misc, build, link, clean, install
|
|
|
|
cmd_m = $(call cmd,$1,$2,30)
|
|
|
|
cmd_b = $(call cmd,$1,$2,32)
|
|
|
|
cmd_l = $(call cmd,$1,$2,36)
|
|
|
|
cmd_c = $(call cmd,$1,$2,31)
|
|
|
|
cmd_i = $(call cmd,$1,$2,33)
|