2021-08-16 12:56:46 +02:00
|
|
|
# small makefile for compiling the kernel
|
2021-06-21 11:12:33 +02:00
|
|
|
|
|
|
|
# kernel lib dir
|
|
|
|
KLIBDIR=kinclude
|
|
|
|
# object file dir
|
|
|
|
ODIR=obj
|
|
|
|
# target dir
|
|
|
|
TARGET=out
|
|
|
|
|
|
|
|
GCC_PREF=riscv32-unknown-elf-
|
|
|
|
|
|
|
|
CC=$(GCC_PREF)gcc
|
|
|
|
OBJDUMP=$(GCC_PREF)objdump
|
2021-08-21 12:17:04 +02:00
|
|
|
CFLAGS=-I$(KLIBDIR) -MD -mcmodel=medany -Wall -Wextra -pedantic-errors -Wno-builtin-declaration-mismatch
|
2021-07-16 19:54:08 +02:00
|
|
|
KERNEL_CFLAGS=-nostdlib -T linker.ld
|
2021-08-16 12:56:46 +02:00
|
|
|
ARCH = rv32im # here you
|
2021-07-16 22:26:55 +02:00
|
|
|
|
|
|
|
### Build configuration:
|
|
|
|
|
2021-08-21 11:08:03 +02:00
|
|
|
# comment out if you don't have any text IO device memory mapped
|
|
|
|
CFLAGS += -DTEXT_IO_ADDR=0xff0000 -DTEXT_IO_BUFLEN=64
|
|
|
|
|
2021-08-17 09:07:00 +02:00
|
|
|
# uncomment these to build with only the rv32i standard
|
|
|
|
#CFLAGS += -D__risc_no_ext=1
|
|
|
|
#ARCH = rv32i
|
2021-07-16 22:26:55 +02:00
|
|
|
|
|
|
|
# configure if mtime is memory-mapped or inside a CSR:
|
|
|
|
# replace 0xFF11FF22FF33 with the correct address
|
2021-08-17 09:07:00 +02:00
|
|
|
#CFLAGS += -DTIMECMP_IN_MEMORY=1 -DTIMECMP_MEM_ADDR=0xFF11FF22
|
2021-07-16 22:26:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
### End configuration
|
|
|
|
CFLAGS += -march=$(ARCH)
|
2021-06-21 11:12:33 +02:00
|
|
|
|
|
|
|
# dependencies that need to be built:
|
2021-08-21 11:12:44 +02:00
|
|
|
_DEPS = ecall.c csr.c sched.c io.c malloc.c
|
2021-06-21 11:12:33 +02:00
|
|
|
|
|
|
|
# dependencies as object files:
|
2021-08-21 11:12:44 +02:00
|
|
|
_OBJ = ecall.o sched.o boot.o csr.o io.o malloc.o
|
2021-06-21 11:12:33 +02:00
|
|
|
|
|
|
|
|
|
|
|
DEPS = $(patsubst %,$(KLIBDIR)/%,$(_DEPS))
|
|
|
|
OBJ = $(patsubst %,$(ODIR)/%,$(_OBJ))
|
|
|
|
|
|
|
|
|
2021-08-16 12:56:46 +02:00
|
|
|
.PHONY: clean
|
|
|
|
.PHONY: directories
|
|
|
|
.PHONY: kernel
|
|
|
|
|
|
|
|
directories:
|
|
|
|
mkdir -p $(ODIR) $(TARGET)
|
|
|
|
|
2021-07-16 22:26:55 +02:00
|
|
|
$(ODIR)/boot.o: $(KLIBDIR)/boot.S
|
2021-08-16 12:56:46 +02:00
|
|
|
$(CC) -c -o $@ $(KLIBDIR)/boot.S $(CFLAGS) -D__assembly
|
2021-06-21 11:12:33 +02:00
|
|
|
|
2021-07-16 22:26:55 +02:00
|
|
|
$(ODIR)/%.o: $(KLIBDIR)/%.c $(KLIBDIR)/%.h
|
2021-06-21 11:12:33 +02:00
|
|
|
$(CC) -c -o $@ $(KLIBDIR)/$*.c $(CFLAGS)
|
|
|
|
|
2021-08-16 12:56:46 +02:00
|
|
|
_kernel: $(OBJ)
|
|
|
|
$(CC) -o $(TARGET)/kernel $^ kernel.c $(CFLAGS) $(KERNEL_CFLAGS)
|
|
|
|
|
|
|
|
kernel: directories _kernel
|
2021-06-21 11:12:33 +02:00
|
|
|
|
|
|
|
kernel-dump: kernel
|
2021-08-17 09:15:29 +02:00
|
|
|
$(OBJDUMP) -SFldft $(TARGET)/kernel > $(TARGET)/kernel-objects
|
2021-06-21 11:12:33 +02:00
|
|
|
|
2021-08-16 12:56:46 +02:00
|
|
|
all: kernel-dump
|
|
|
|
|
2021-06-21 11:12:33 +02:00
|
|
|
|
|
|
|
clean:
|
2021-07-16 22:26:55 +02:00
|
|
|
rm -rf $(ODIR) *~ $(KLIBDIR)/*~ $(TARGET)
|
|
|
|
|
|
|
|
-include $(OBJ:.o=.d)
|