more debugging, and serial port
[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 = -marm -fpic -ffreestanding -nostdinc
22 #arch = -mcpu=arm1176jzf-s
23 arch = -mcpu=cortex-a7
24
25 CFLAGS = $(arch) $(warn) $(opt) $(dbg) $(gccopt) $(inc) $(def)
26 ASFLAGS = $(arch) $(dbg) $(inc)
27 LDFLAGS = -nostdlib -T rpikern.ld -print-gc-sections
28
29 QEMU_FLAGS = -m 256 -M raspi2 -serial stdio -d guest_errors
30
31
32 $(bin): $(elf)
33         $(OBJCOPY) -O binary $< $@
34
35 $(elf): $(obj)
36         $(LD) -o $@ $(obj) -Map link.map $(LDFLAGS)
37
38 -include $(dep)
39
40 %.d: %.c
41         @echo 'gen dep $@ ...'
42         @$(CPP) $(CFLAGS) $< -MM -MT $(@:.d=.o) >$@
43
44 .PHONY: clean
45 clean:
46         rm -f $(obj) $(bin) $(elf) link.map
47
48 .PHONY: cleandep
49 cleandep:
50         rm -f $(dep)
51
52 .PHONY: run
53 run: $(elf)
54         qemu-system-arm $(QEMU_FLAGS) -kernel $(elf)
55
56 .PHONY: disasm
57 disasm: $(elf)
58         $(toolprefix)objdump -d $<