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
|
|
|
#
|
|
|
|
#---
|
|
|
|
|
2017-01-22 18:35:02 +01:00
|
|
|
include Makefile.cfg
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
#---
|
2017-02-25 19:02:07 +01:00
|
|
|
# Project variables
|
2016-07-14 21:10:51 +02:00
|
|
|
#---
|
|
|
|
|
|
|
|
# Modules
|
2017-02-25 19:02:07 +01:00
|
|
|
modules-gint = bopti clock core display events gray keyboard mmu rtc \
|
|
|
|
screen tales timer
|
|
|
|
modules-libc = setjmp stdio stdlib string time
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
# Targets
|
|
|
|
target-lib = libgint.a
|
|
|
|
target-std = libc.a
|
2017-02-25 19:02:07 +01:00
|
|
|
target-g1a = gintdemo.g1a
|
|
|
|
target-dbg = gintdbg.g1a
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
# Tools
|
2016-11-05 22:00:23 +01:00
|
|
|
cc = sh3eb-elf-gcc
|
|
|
|
as = sh3eb-elf-as
|
|
|
|
ar = sh3eb-elf-ar
|
|
|
|
ob = sh3eb-elf-objcopy
|
|
|
|
wr = g1a-wrapper
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
# Flags for gint
|
|
|
|
lib-cflags = -m3 -mb -nostdlib -I include -ffreestanding -std=c11 -Os \
|
|
|
|
-Wall -Wextra @gcc.cfg
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
# Demo application (could be done better)
|
|
|
|
demo-src = $(notdir $(wildcard demo/*.[cs]))
|
2016-07-28 18:12:07 +02:00
|
|
|
demo-dep = $(wildcard demo/*.h)
|
2016-07-14 21:10:51 +02:00
|
|
|
demo-icon = demo/icon.bmp
|
|
|
|
demo-res = $(notdir $(wildcard demo/resources/*))
|
|
|
|
demo-obj = $(patsubst %,build/demo_%.o,$(demo-src) $(demo-res))
|
|
|
|
demo-elf = build/gintdemo.elf
|
|
|
|
demo-bin = build/gintdemo.bin
|
2017-02-25 19:02:07 +01:00
|
|
|
demo-ldflags = $(demo-cflags) -T demo/gintdemo.ld -L. -lgint -lc -lgcc
|
|
|
|
demo-cflags = -m3 -mb -nostdlib -I include -ffreestanding -std=c11 -Os \
|
|
|
|
-Wall -Wextra
|
|
|
|
|
|
|
|
# Debugger application (displays past diagnostics without running gint)
|
|
|
|
debug-src = $(notdir $(wildcard debug/*.[cs]))
|
|
|
|
debug-dep = $(wildcard debug/*.h)
|
|
|
|
debug-icon = debug/icon.bmp
|
|
|
|
debug-obj = $(debug-src:%=build/debug_%.o)
|
|
|
|
debug-elf = build/gintdbg.elf
|
|
|
|
debug-bin = build/gintdbg.bin
|
|
|
|
debug-ldflags = $(debug-cflags) -T debug/addin.ld -L debug -lfx -lgcc
|
|
|
|
debug-cflags = -m3 -mb -nostdlib -ffreestanding -I debug/include -I \
|
|
|
|
include -std=c11 -Os -Wall -Wextra
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
# Specific objects
|
2017-02-25 20:10:48 +01:00
|
|
|
obj-lib-spec = build/display_font_system.bmp.o
|
2016-07-25 09:04:22 +02:00
|
|
|
obj-std-spec =
|
|
|
|
|
2016-11-05 22:00:23 +01:00
|
|
|
# Configuration files
|
2017-02-25 19:02:07 +01:00
|
|
|
config = gcc.cfg
|
2017-01-22 18:35:02 +01:00
|
|
|
ifeq ($(wildcard $(config)),)
|
|
|
|
$(error "Configuration files are missing. Did you ./configure ?")
|
|
|
|
endif
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2016-12-22 23:08:44 +01:00
|
|
|
# Target folder
|
|
|
|
folder := $(shell fxsdk --folder)
|
2016-12-22 18:36:39 +01:00
|
|
|
ifndef folder
|
2016-12-22 23:08:44 +01:00
|
|
|
$(error "Could not get the fxSDK storage folder. Did you install fxSDK \
|
|
|
|
properly?")
|
2016-12-22 18:36:39 +01:00
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-07-14 21:10:51 +02:00
|
|
|
#---
|
2017-02-25 19:02:07 +01:00
|
|
|
# Automatic variables
|
2016-07-14 21:10:51 +02:00
|
|
|
#---
|
|
|
|
|
|
|
|
# Modules are subfolders of src/.
|
|
|
|
modules = $(modules-gint) $(modules-libc)
|
|
|
|
|
|
|
|
define n
|
|
|
|
# This is a newline character.
|
|
|
|
|
|
|
|
endef
|
|
|
|
|
|
|
|
# Module-scope variables.
|
|
|
|
$(foreach mod, $(modules), $(eval \
|
|
|
|
mod-$(mod)-c = $(notdir $(wildcard src/$(mod)/*.c)) $n\
|
|
|
|
mod-$(mod)-asm = $(notdir $(wildcard src/$(mod)/*.s)) $n\
|
|
|
|
mod-$(mod)-src = $$(mod-$(mod)-c)$$(mod-$(mod)-asm) $n\
|
|
|
|
mod-$(mod)-obj = $$(patsubst %,build/$(mod)_%.o,$$(mod-$(mod)-src)) \
|
|
|
|
))
|
|
|
|
|
|
|
|
# Target-scope variables.
|
2016-07-25 09:04:22 +02:00
|
|
|
obj-std = $(foreach mod,$(modules-libc),$(mod-$(mod)-obj)) $(obj-std-spec)
|
|
|
|
obj-lib = $(foreach mod,$(modules-gint),$(mod-$(mod)-obj)) $(obj-lib-spec)
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
# Dependencies.
|
2016-07-25 09:04:22 +02:00
|
|
|
hdr-dep = $(wildcard include/*.h include/internals/*.h)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#---
|
|
|
|
# Rule templates.
|
|
|
|
#---
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2016-07-06 11:28:51 +02:00
|
|
|
# C source file template:
|
|
|
|
# $1 module name
|
2016-07-14 21:10:51 +02:00
|
|
|
# $2 filename
|
2016-07-28 18:12:07 +02:00
|
|
|
# $3 dependencies
|
2016-07-06 11:28:51 +02:00
|
|
|
define rule-c-source
|
2016-11-05 22:00:23 +01:00
|
|
|
build/$1_$2.o: src/$1/$2 $3 $(config)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[34;1msrc \u00bb\e[0m cc $$<\n')
|
2017-02-25 19:02:07 +01:00
|
|
|
$(if $(VERBOSE),,@) $(cc) -c $$< -o $$@ $(lib-cflags)
|
2016-07-14 21:10:51 +02:00
|
|
|
endef
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
# Asm source file template:
|
2016-07-14 21:10:51 +02:00
|
|
|
# $1 module name
|
|
|
|
# $2 filename
|
|
|
|
define rule-asm-source
|
2016-11-05 22:00:23 +01:00
|
|
|
build/$1_$2.o: src/$1/$2 $(config)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[34;1msrc \u00bb\e[0m as $$<\n')
|
|
|
|
$(if $(VERBOSE),,@) $(as) -c $$< -o $$@
|
2016-07-06 11:28:51 +02:00
|
|
|
endef
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
|
|
|
|
#---
|
|
|
|
# Building.
|
|
|
|
#---
|
|
|
|
|
|
|
|
# Generic rules
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
all-lib: $(config) $(target-std) $(target-lib)
|
|
|
|
|
|
|
|
all: $(config) $(target-std) $(target-lib) $(target-g1a) $(target-dbg)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
build:
|
2016-11-11 10:43:13 +01:00
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mdir \u00bb\e[0m mkdir $@\n')
|
|
|
|
$(if $(VERBOSE),,@) mkdir -p $@
|
|
|
|
|
|
|
|
$(obj-std) $(obj-lib) $(demo-obj): | build
|
2016-11-05 22:00:23 +01:00
|
|
|
|
2017-01-22 18:35:02 +01:00
|
|
|
$(target-std): $(obj-std)
|
2016-11-05 22:00:23 +01:00
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mlib \u00bb\e[0m ar $@\n')
|
|
|
|
$(if $(VERBOSE),,@) $(ar) rcs $@ $(obj-std)
|
|
|
|
@ printf '\e[32;1mmsg \u00bb\e[0m Succesfully built libc ('
|
|
|
|
@ printf $$(stat -c %s $@)
|
|
|
|
@ printf ' bytes)\n\n'
|
|
|
|
|
|
|
|
$(target-lib): $(config) $(target-std) $(obj-lib)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mlib \u00bb\e[0m ar $@\n')
|
|
|
|
$(if $(VERBOSE),,@) $(ar) rcs $@ $(obj-lib)
|
|
|
|
@ printf '\e[32;1mmsg \u00bb\e[0m Succesfully built libgint ('
|
|
|
|
@ printf $$(stat -c %s $@)
|
|
|
|
@ printf ' bytes)\n\n'
|
|
|
|
|
|
|
|
$(target-g1a): $(config) $(target-std) $(target-lib) $(demo-obj)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mexe \u00bb\e[0m ld -o $(demo-elf)\n')
|
2017-02-25 19:02:07 +01:00
|
|
|
$(if $(VERBOSE),,@) $(cc) -o $(demo-elf) $(demo-obj) $(demo-ldflags)
|
2016-11-05 22:00:23 +01:00
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mexe \u00bb\e[0m objcopy -o $(demo-bin)\n')
|
|
|
|
$(if $(VERBOSE),,@) $(ob) -R .comment -R .bss -O binary $(demo-elf) $(demo-bin)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mexe \u00bb\e[0m g1a-wrapper -o $@\n')
|
|
|
|
$(if $(VERBOSE),,@) $(wr) $(demo-bin) -o $@ -i $(demo-icon)
|
|
|
|
@ printf '\e[32;1mmsg \u00bb\e[0m Succesfully built demo application ('
|
|
|
|
@ printf $$(stat -c %s $@)
|
|
|
|
@ printf ' bytes)\n\n'
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
$(target-dbg): $(config) $(debug-obj)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mexe \u00bb\e[0m ld -o $(debug-elf)\n')
|
|
|
|
$(if $(VERBOSE),,@) $(cc) -o $(debug-elf) $(debug-obj) $(debug-ldflags)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mexe \u00bb\e[0m objcopy -o $(debug-bin)\n')
|
|
|
|
$(if $(VERBOSE),,@) $(ob) -R .comment -R .bss -O binary $(debug-elf) $(debug-bin)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[35;1mexe \u00bb\e[0m g1a-wrapper -o $@\n')
|
|
|
|
$(if $(VERBOSE),,@) $(wr) $(debug-bin) -o $@ -i $(debug-icon)
|
|
|
|
@ printf '\e[32;1mmsg \u00bb\e[0m Succesfully built debug application ('
|
|
|
|
@ printf $$(stat -c %s $@)
|
|
|
|
@ printf ' bytes)\n\n'
|
|
|
|
|
2016-07-14 21:10:51 +02:00
|
|
|
# Automated rules
|
|
|
|
|
|
|
|
$(foreach mod,$(modules), \
|
|
|
|
$(foreach source,$(mod-$(mod)-c), $(eval \
|
2016-07-28 18:12:07 +02:00
|
|
|
$(call rule-c-source,$(mod),$(source),$(hdr-dep)))) \
|
2016-07-14 21:10:51 +02:00
|
|
|
$(foreach source,$(mod-$(mod)-asm), $(eval \
|
|
|
|
$(call rule-asm-source,$(mod),$(source)))) \
|
|
|
|
)
|
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
# Specific rules
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
# Optimizing this one makes the interrupt handler raise illegal slot exception
|
|
|
|
# on rte; lds.l @r15+, mach. This is totally weird but I haven't understood
|
|
|
|
# why for now.
|
2016-07-25 09:04:22 +02:00
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
build/display_font_%.bmp.o: src/display/font_%.bmp
|
2016-11-05 22:00:23 +01:00
|
|
|
$(if $(VERBOSE),,@ printf '\e[36;1mres \u00bb\e[0m fxconv $<\n')
|
2017-02-25 19:02:07 +01:00
|
|
|
$(if $(VERBOSE),,@) fxconv $< -o $@ --font -n $(<:src/display/font_%.bmp=gint_font_%)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
# Demo application
|
|
|
|
|
2016-11-05 22:00:23 +01:00
|
|
|
build/demo_%.c.o: demo/%.c $(hdr-dep) $(demo-dep) $(config)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[34;1msrc \u00bb\e[0m cc $<\n')
|
2017-02-25 19:02:07 +01:00
|
|
|
$(if $(VERBOSE),,@) $(cc) -c $< -o $@ $(demo-cflags)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
build/demo_font_%.bmp.o: demo/resources/font_%.bmp
|
2016-11-05 22:00:23 +01:00
|
|
|
$(if $(VERBOSE),,@ printf '\e[36;1mres \u00bb\e[0m fxconv $<\n')
|
|
|
|
$(if $(VERBOSE),,@) fxconv $< -o $@ --font -n $(patsubst demo/resources/%.bmp,res_%,$<)
|
2016-07-25 09:04:22 +02:00
|
|
|
|
2016-07-14 21:10:51 +02:00
|
|
|
build/demo_%.bmp.o: demo/resources/%.bmp
|
2016-11-05 22:00:23 +01:00
|
|
|
$(if $(VERBOSE),,@ printf '\e[36;1mres \u00bb\e[0m fxconv $<\n')
|
|
|
|
$(if $(VERBOSE),,@) fxconv $< -o $@ -n $(patsubst demo/resources/%.bmp,res_%,$<)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
# Debug application
|
|
|
|
|
|
|
|
build/debug_%.s.o: debug/%.s $(config)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[34;1msrc \u00bb\e[0m as $<\n')
|
|
|
|
$(if $(VERBOSE),,@) $(as) -c $< -o $@
|
|
|
|
|
|
|
|
build/debug_%.c.o: debug/%.c $(hdr-dep) $(debug-dep) $(config)
|
|
|
|
$(if $(VERBOSE),,@ printf '\e[34;1msrc \u00bb\e[0m cc $<\n')
|
|
|
|
$(if $(VERBOSE),,@) $(cc) -c $< -o $@ $(debug-cflags)
|
|
|
|
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
|
|
|
|
#---
|
2017-02-25 19:02:07 +01:00
|
|
|
# Cleaning and install
|
2016-07-14 21:10:51 +02:00
|
|
|
#---
|
|
|
|
|
|
|
|
clean:
|
2016-11-11 10:43:13 +01:00
|
|
|
@ rm -rf build
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
mrproper: clean
|
|
|
|
@ rm -f $(target-g1a) $(target-lib) $(target-std)
|
2016-11-05 22:00:23 +01:00
|
|
|
@ rm -f $(config)
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
distclean: mrproper
|
|
|
|
|
2016-12-25 11:45:05 +01:00
|
|
|
install: $(target-std) $(target-lib)
|
2016-12-22 18:36:39 +01:00
|
|
|
mkdir -p $(folder)
|
|
|
|
install -m 644 $^ $(folder)
|
|
|
|
install -m 644 -T demo/gintdemo.ld $(folder)/linker.ld
|
|
|
|
mkdir -p $(folder)/gint
|
|
|
|
install -m 644 include/*.h $(folder)/gint
|
2017-01-22 18:35:02 +01:00
|
|
|
ifdef config_ext
|
|
|
|
install -m 644 include/extended/*.h $(folder)/gint
|
|
|
|
endif
|
2016-12-22 18:36:39 +01:00
|
|
|
@ printf '\e[32;1mmsg \u00bb\e[0m All installed!\n'
|
2016-07-14 21:10:51 +02:00
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
install-demo:
|
2016-12-25 11:45:05 +01:00
|
|
|
p7 send -f $(target-g1a)
|
2017-02-25 19:02:07 +01:00
|
|
|
install-debug:
|
|
|
|
p7 send -f $(target-dbg)
|
2016-12-25 11:45:05 +01:00
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
.PHONY: all-lib all help
|
|
|
|
.PHONY: clean mrproper distclean
|
|
|
|
.PHONY: install install-demo install-debug
|