2019-02-21 20:58:38 +01:00
|
|
|
#! /usr/bin/make -f
|
|
|
|
#
|
|
|
|
# gint project Makefile
|
|
|
|
#
|
|
|
|
#---
|
|
|
|
|
|
|
|
#
|
|
|
|
# Build configuration
|
|
|
|
#
|
|
|
|
|
|
|
|
# Require configuration file (if you want to clean up and lost the file, you
|
|
|
|
# can either reconfigure or just delete the build directory)
|
|
|
|
CONFIG := Makefile.cfg
|
|
|
|
ifeq "$(wildcard $(CONFIG))" ""
|
|
|
|
$(error "config file $(CONFIG) does not exist (reconfigure or wipe directory)")
|
|
|
|
endif
|
|
|
|
include $(CONFIG)
|
|
|
|
|
|
|
|
# Machine flags, defaults are provided for common toolchains
|
2019-09-12 17:59:24 +02:00
|
|
|
|
2019-02-21 20:58:38 +01:00
|
|
|
ifeq "$(CONFIG.TOOLCHAIN)" "sh3eb-elf"
|
2019-09-12 17:59:24 +02:00
|
|
|
machine ?= -m3 -mb
|
2019-02-21 20:58:38 +01:00
|
|
|
endif
|
2019-03-10 15:45:34 +01:00
|
|
|
ifeq "$(CONFIG.TOOLCHAIN)" "sh4eb-elf"
|
2019-09-12 17:59:24 +02:00
|
|
|
machine ?= -m4-nofpu -mb
|
2019-02-21 20:58:38 +01:00
|
|
|
endif
|
|
|
|
|
|
|
|
# Compiler flags, assembler flags, dependency generation, archiving
|
|
|
|
cflags := $(machine) -ffreestanding -nostdlib -Wall -Wextra -std=c11 -Os \
|
|
|
|
-fstrict-volatile-bitfields -I ../include $(CONFIG.MACROS) \
|
|
|
|
$(CONFIG.CFLAGS)
|
|
|
|
sflags := $(CONFIG.MACROS)
|
|
|
|
dflags = -MMD -MT $@ -MF $(@:.o=.d) -MP
|
|
|
|
arflags :=
|
|
|
|
|
2020-06-14 08:30:09 +02:00
|
|
|
# Git file with current hash
|
|
|
|
ifeq "$(shell git branch --show-current)" ""
|
|
|
|
gitfile := ../.git/HEAD
|
|
|
|
else
|
|
|
|
gitfile := ../.git/refs/heads/$(shell git branch --show-current)
|
|
|
|
endif
|
|
|
|
|
2019-02-21 20:58:38 +01:00
|
|
|
|
|
|
|
#
|
|
|
|
# File listings
|
|
|
|
#
|
|
|
|
|
|
|
|
# Target file (CONFIG.TARGET is either "fx" or "cg")
|
|
|
|
target := libgint-$(CONFIG.TARGET).a
|
|
|
|
|
|
|
|
# Automatic names for object and dependency files
|
|
|
|
src2obj = $(1:../src/%=src/%).o
|
|
|
|
src2dep = $(1:../src/%=src/%).d
|
|
|
|
|
|
|
|
# Source files
|
2020-02-23 15:49:55 +01:00
|
|
|
# TODO: Enable the DMA on fx-9860G
|
2019-09-15 10:18:03 +02:00
|
|
|
prune-fx := -name render-cg -prune -o -name dma -prune -o -name r61524 -prune
|
|
|
|
prune-cg := -name render-fx -prune -o -name gray -prune -o -name t6k11 -prune
|
2020-02-23 15:49:55 +01:00
|
|
|
src := $(shell find ../src $(prune-$(CONFIG.TARGET)) \
|
2019-02-21 20:58:38 +01:00
|
|
|
-o -name '*.[csS]' -print)
|
|
|
|
src_obj := $(foreach s,$(src),$(call src2obj,$s))
|
|
|
|
|
|
|
|
# Files with special handling
|
2019-06-15 07:04:38 +02:00
|
|
|
spe-fx := ../src/font5x7.png
|
2019-07-01 17:22:12 +02:00
|
|
|
spe-cg := ../src/font8x9.png
|
2019-06-15 07:04:38 +02:00
|
|
|
spe_obj := version.o $(foreach s,$(spe-$(CONFIG.TARGET)),$(call src2obj,$s))
|
2019-02-21 20:58:38 +01:00
|
|
|
|
|
|
|
# All object files
|
|
|
|
obj := $(src_obj) $(spe_obj)
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Toolchain
|
|
|
|
#
|
|
|
|
|
|
|
|
gcc = $(CONFIG.TOOLCHAIN)-gcc
|
|
|
|
as = $(CONFIG.TOOLCHAIN)-as
|
|
|
|
ld = $(CONFIG.TOOLCHAIN)-ld
|
|
|
|
ar = $(CONFIG.TOOLCHAIN)-ar
|
|
|
|
objcopy = $(CONFIG.TOOLCHAIN)-objcopy
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Version management
|
|
|
|
#
|
|
|
|
|
|
|
|
# Version symbol is obtained by using the last commit hash on 7 nibbles
|
2019-02-22 15:08:51 +01:00
|
|
|
version_hash = 0x0$(shell git rev-parse --short HEAD)
|
2019-02-21 20:58:38 +01:00
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Build rules
|
|
|
|
#
|
|
|
|
|
|
|
|
all: $(target)
|
|
|
|
|
|
|
|
$(target): $(obj)
|
2020-06-20 11:41:13 +02:00
|
|
|
@ rm -f $@
|
2019-02-21 20:58:38 +01:00
|
|
|
$(call cmd_l,ar,$@) $(ar) rcs $(arflags) $@ $^
|
|
|
|
|
|
|
|
# Assembler sources
|
|
|
|
src/%.s.o: ../src/%.s src/%.s.d
|
|
|
|
@ mkdir -p $(dir $@)
|
|
|
|
$(call cmd_b,as,$*.s) $(gcc) -c $< -o $@ $(sflags)
|
|
|
|
src/%.S.o: ../src/%.S src/%.S.d
|
|
|
|
@ mkdir -p $(dir $@)
|
|
|
|
$(call cmd_b,as,$*.S) $(gcc) -c $< -o $@ $(sflags)
|
|
|
|
|
|
|
|
# C sources
|
|
|
|
src/%.c.o: ../src/%.c src/%.c.d
|
|
|
|
@ mkdir -p $(dir $@)
|
|
|
|
$(call cmd_b,gcc,$*.c) $(gcc) -c $< -o $@ $(dflags) $(cflags)
|
|
|
|
|
|
|
|
# Special files
|
2019-05-04 19:27:52 +02:00
|
|
|
$(call src2obj,../src/font5x7.png): ../src/font5x7.png
|
2019-02-21 20:58:38 +01:00
|
|
|
@ mkdir -p $(dir $@)
|
2020-02-23 15:49:55 +01:00
|
|
|
$(call cmd_m,fxconv,font5x7.png) fxconv -f $< -o $@ \
|
2019-09-12 17:59:24 +02:00
|
|
|
--fx --toolchain=$(CONFIG.TOOLCHAIN) name:gint_font5x7 \
|
2019-05-04 19:27:52 +02:00
|
|
|
charset:ascii grid.size:5x7 grid.padding:1 grid.border:0
|
2019-06-23 23:27:44 +02:00
|
|
|
$(call src2obj,../src/font8x9.png): ../src/font8x9.png
|
|
|
|
@ mkdir -p $(dir $@)
|
2020-02-23 15:49:55 +01:00
|
|
|
$(call cmd_m,fxconv,font8x9.png) fxconv -f $< -o $@ \
|
2019-09-12 17:59:24 +02:00
|
|
|
--cg --toolchain=$(CONFIG.TOOLCHAIN) name:gint_font8x9 \
|
2019-06-23 23:27:44 +02:00
|
|
|
charset:print grid.size:8x11 grid.padding:1 grid.border:0 \
|
|
|
|
proportional:true
|
2019-02-21 20:58:38 +01:00
|
|
|
|
|
|
|
# Version symbol. ld generates a .stack section for unknown reasons; I remove
|
|
|
|
# it in the linker script.
|
2020-06-14 08:30:09 +02:00
|
|
|
version.o: $(gitfile)
|
2019-02-21 20:58:38 +01:00
|
|
|
@ mkdir -p $(dir $@)
|
|
|
|
@ echo "_GINT_VERSION = $(version_hash);" > $@.txt
|
|
|
|
$(call cmd_b,ld,$@) $(ld) -r -R $@.txt -o $@
|
2019-06-15 07:04:38 +02:00
|
|
|
|
2019-02-21 20:58:38 +01:00
|
|
|
#
|
|
|
|
# Cleaning
|
|
|
|
#
|
|
|
|
|
|
|
|
clean:
|
|
|
|
@ rm -rf src version.o{,txt}
|
|
|
|
distclean: clean
|
|
|
|
@ rm -rf Makefile $(CONFIG) $(target)
|
|
|
|
|
|
|
|
#
|
|
|
|
# Installing
|
|
|
|
#
|
|
|
|
|
2019-07-01 17:22:12 +02:00
|
|
|
m644 := -m 644
|
|
|
|
|
|
|
|
# Disable -m on Mac OS
|
|
|
|
ifeq "$(shell uname)" "Darwin"
|
|
|
|
m644 :=
|
|
|
|
endif
|
|
|
|
|
2019-02-21 20:58:38 +01:00
|
|
|
install: $(target)
|
|
|
|
install -d $(PREFIX)
|
2019-07-01 17:22:12 +02:00
|
|
|
install $(target) $(m644) $(PREFIX)
|
|
|
|
install ../$(CONFIG.TARGET.LONG).ld $(m644) $(PREFIX)
|
2019-02-21 20:58:38 +01:00
|
|
|
cp -r ../include/gint $(PREFIX)/include
|
|
|
|
|
|
|
|
uninstall:
|
|
|
|
rm -f $(PREFIX)/$(target)
|
|
|
|
rm -f $(PREFIX)/$(CONFIG.TARGET.LONG).ld
|
|
|
|
rm -rf $(PREFIX)/include/gint
|
|
|
|
|
|
|
|
#
|
|
|
|
# Utilities
|
|
|
|
#
|
|
|
|
|
|
|
|
# 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 src ] && find src -name *.d)
|
|
|
|
src/%.d: ;
|
|
|
|
.PRECIOUS: src/%.d
|
|
|
|
|
|
|
|
.PHONY: all clean distclean
|
|
|
|
|
|
|
|
# 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
|
|
|
|
|
|
|
|
# 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)
|