# Aedrix root Makefile # Copyright (C) 2012 Aaron Lindsay # Config options for the code itself (should be separated from the Makefile sometime) ARCH = arm # Config options concerning the build process itself VERBOSE = 0 # 1 shows all compiler flags, 0 shows cleaner output # Define the tools to be used TOOL_PREFIX = arm-elf- AS = $(TOOL_PREFIX)as CC = $(TOOL_PREFIX)gcc LD = $(TOOL_PREFIX)ld OBJCPY = $(TOOL_PREFIX)objcopy OBJDMP = $(TOOL_PREFIX)objdump # Define the flags we'll need for our tools INCLUDES = -I include KCFLAGS = -g -Wall -Wextra -Werror -nostdlib -nostartfiles -fno-builtin -std=gnu99 $(INCLUDES) KLDFLAGS = -T link.ld -L /usr/lib/gcc/arm-elf/4.7.0/ EXTRA_LIBS = -lgcc KOBJS = include boot/Makefile.inc include kernel/Makefile.inc include devices/Makefile.inc .PHONY: all clean boot all: aedrix-kernel.img aedrix-kernel.elf aedrix-kernel.elf: $(KOBJS) $(if $(VERBOSE:1=),@echo ' LD $@') $(if $(VERBOSE:1=),@)$(LD) $(KLDFLAGS) -o $@ $(KOBJS) $(EXTRA_LIBS) aedrix-kernel.objdump: aedrix-kernel.elf $(if $(VERBOSE:1=),@echo ' OBJDMP $@') $(if $(VERBOSE:1=),@)$(OBJDMP) -D $< > $@ aedrix-kernel.img: aedrix-kernel.elf $(if $(VERBOSE:1=),@echo ' OBJCPY $@') $(if $(VERBOSE:1=),@)$(OBJCPY) $< -O binary $@ %.o: %.c $(if $(VERBOSE:1=),@echo ' CC $@') $(if $(VERBOSE:1=),@)$(CC) $(KCFLAGS) -c -o $@ $< # Assembly files without preprocessor directives %.o: %.s $(if $(VERBOSE:1=),@echo ' AS $@') $(if $(VERBOSE:1=),@)$(AS) -o $@ $< # Assembly files with preprocessor directives %.o: %.S $(if $(VERBOSE:1=),@echo ' AS $@') $(if $(VERBOSE:1=),@)$(AS) -o $@ $< clean: @echo ' CLEAN *.o' @rm -f $(KOBJS) @echo ' CLEAN aedrix-kernel.elf' @rm -f aedrix-kernel.elf @echo ' CLEAN aedrix-kernel.objdump' @rm -f aedrix-kernel.objdump @echo ' CLEAN aedrix-kernel.img' @rm -f aedrix-kernel.img boot: aedrix-kernel.elf @qemu-system-arm -m 1024 -M vexpress-a9 -kernel aedrix-kernel.elf -serial stdio