libn64: Reorganize headers/files.
[n64chain.git] / libn64 / Makefile
1 #
2 # libn64/Makefile: Makefile for libn64.
3 #
4 # n64chain: A (free) open-source N64 development toolchain.
5 # Copyright 2014-16 Tyler J. Stachecki <stachecki.tyler@gmail.com>
6 #
7 # This file is subject to the terms and conditions defined in
8 # 'LICENSE', which is part of this source code package.
9 #
10
11 ifdef SystemRoot
12 FIXPATH = $(subst /,\,$1)
13 RM = del /Q
14 else
15 FIXPATH = $1
16 RM = rm -f
17 endif
18
19 AS = $(call FIXPATH,$(CURDIR)/../tools/bin/mips64-elf-as)
20 AR = $(call FIXPATH,$(CURDIR)/../tools/bin/mips64-elf-gcc-ar)
21 CC = $(call FIXPATH,$(CURDIR)/../tools/bin/mips64-elf-gcc)
22
23 CFLAGS = -Wall -Wextra -pedantic -std=c99 -I. -Iinclude -Ipriv_include
24 OPTFLAGS = -Os -march=vr4300 -mabi=eabi -mgp32 -mlong32 \
25 -flto -ffat-lto-objects -ffunction-sections -fdata-sections \
26 -G4 -mno-extern-sdata -mgpopt
27
28 ASMFILES = $(call FIXPATH,\
29 os/asm/boot.s \
30 os/asm/context.s \
31 os/asm/exception.s \
32 os/asm/syscall.s \
33 )
34
35 CFILES = $(call FIXPATH,\
36 os/fbtext.c \
37 os/kthread.c \
38 os/main.c \
39 os/mm.c \
40 os/panic.c \
41 os/thread.c \
42 rcp/vi.c \
43 )
44
45 OBJFILES = \
46 $(CFILES:.c=.o) \
47 $(ASMFILES:.s=.o)
48
49 DEPFILES = $(OBJFILES:.o=.d)
50
51 #
52 # Primary targets.
53 #
54 libn64.a: $(OBJFILES)
55 @echo $(call FIXPATH,"Building: libn64/$@")
56 @$(AR) rcs $@ $^
57
58 #
59 # Generic compilation/assembly targets.
60 #
61 %.o: %.s
62 @echo $(call FIXPATH,"Assembling: libn64/$<")
63 @$(CC) -x assembler-with-cpp $(CFLAGS) $(OPTFLAGS) -MMD -c $< -o $@
64
65 %.o: %.c
66 @echo $(call FIXPATH,"Compiling: libn64/$<")
67 @$(CC) $(CFLAGS) $(OPTFLAGS) -MMD -c $< -o $@
68
69 #
70 # Clean project target.
71 #
72 .PHONY: clean
73 clean:
74 @echo "Cleaning libn64..."
75 @$(RM) libn64.a $(DEPFILES) $(OBJFILES)
76