aboutsummaryrefslogtreecommitdiff
path: root/Makefile
blob: 25f82e8d1010714aafcf38e736d722e631b9a2bd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
C_SOURCES = $(wildcard src/*.c)
C_HEADERS = $(wildcard src/*.h)
C_OBJECTS = ${C_SOURCES:.c=.o}
C_OBJECTD = ${subst src,obj,${C_OBJECTS}}
A_SOURCES = $(wildcard src/*.S)
A_OBJECTS = ${A_SOURCES:.S=.o}
A_OBJECTD = ${subst src,obj,${A_OBJECTS}}

CROSS = arm-none-eabi
CC = ${CROSS}-gcc
AS = ${CROSS}-as
OBJCOPY = ${CROSS}-objcopy
OBJDUMP = ${CROSS}-objdump
QEMU = qemu-system-arm
GDB = gdb-multiarch
CFLAGS = -mcpu=cortex-a7 -fpic -ffreestanding -std=gnu99 -O2 -Wall -Wextra -nostdlib -g
AFLAGS = -mcpu=cortex-a7
QFLAGS = -M raspi2 -cpu arm1176 -m 1G -serial mon:stdio -nographic

.PHONY: clean run run-debug debug export

default: clean build/kernel7.img

build/kernel7.img: build/kernel.elf
	${OBJCOPY} $< -O binary $@

build/kernel.list: build/kernel-g.elf
	${OBJDUMP} -D $< > $@

build/kernel-g.elf: ${A_OBJECTD} ${C_OBJECTD}
	${CC} -T linker.ld -o $@ ${CFLAGS} $^ -lgcc

build/kernel.elf: ${A_OBJECTD} ${C_OBJECTD}
	${CC} -T linker.ld -o $@ -ffreestanding -O2 -nostdlib $^ -lgcc

export: build/kernel.list
	cp build/kernel.elf /mnt/c/Local/

obj/%.o: src/%.S
	${AS} ${AFLAGS} -g -c $< -o $@

run: build/kernel.elf
	${QEMU} -kernel $< ${QFLAGS}

run-debug: build/kernel-g.elf
	${QEMU} -kernel $< -s -S ${QFLAGS}

debug: build/kernel-g.elf build/kernel.list
	${GDB} $< -command=gdbinit

clean:
	rm -f obj/*.o build/*.elf build/*.list build/*.img