initial commit
[rpikern] / Makefile
1 csrc = $(wildcard src/*.c) $(wildcard src/libc/*.c)
2 ssrc = $(wildcard src/*.s) $(wildcard src/libc/*.s)
3 Ssrc = $(wildcard src/*.S) $(wildcard src/libc/*.S)
4 obj = $(csrc:.c=.o) $(ssrc:.s=.o) $(Ssrc:.S=.o)
5 dep = $(csrc:.c=.d)
6 elf = rpikern.elf
7 bin = rpikern.bin
8
9 ifneq ($(shell uname -m | sed 's/^arm.*/arm/'), arm)
10         toolprefix = arm-linux-gnueabihf-
11         CPP = $(toolprefix)cpp
12         CC = $(toolprefix)gcc
13         AS = $(toolprefix)as
14         LD = $(toolprefix)ld
15         OBJCOPY = $(toolprefix)objcopy
16 endif
17
18 warn = -pedantic -Wall
19 dbg = -g
20 inc = -Isrc/libc
21 gccopt = -fpic -ffreestanding -nostdinc
22 arch = -mcpu=arm1176jzf-s
23
24 CFLAGS = $(arch) $(warn) $(opt) $(dbg) $(gccopt) $(inc) $(def)
25 ASFLAGS = $(arch) $(dbg) $(inc)
26 LDFLAGS = -nostdlib -T rpikern.ld -print-gc-sections
27
28 QEMU_FLAGS = -m 256 -M raspi2 -serial stdio
29
30
31 $(bin): $(elf)
32         $(OBJCOPY) -O binary $< $@
33
34 $(elf): $(obj)
35         $(LD) -o $@ $(obj) -Map link.map $(LDFLAGS)
36
37 -include $(dep)
38
39 %.d: %.c
40         @echo 'gen dep $@ ...'
41         @$(CPP) $(CFLAGS) $< -MM -MT $(@:.d=.o) >$@
42
43 .PHONY: clean
44 clean:
45         rm -f $(obj) $(bin) $(elf) link.map
46
47 .PHONY: cleandep
48 cleandep:
49         rm -f $(dep)
50
51 .PHONY: debug
52 debug: $(elf)
53         qemu-system-arm $(QEMU_FLAGS) -kernel $(elf)