You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
217 lines
6.6 KiB
217 lines
6.6 KiB
# we assume that the utilities from RISC-V cross-compiler (i.e., riscv64-unknown-elf-gcc and etc.)
|
|
# are in your system PATH. To check if your environment satisfies this requirement, simple use
|
|
# `which` command as follows:
|
|
# $ which riscv64-unknown-elf-gcc
|
|
# if you have an output path, your environment satisfy our requirement.
|
|
|
|
# --------------------- macros --------------------------
|
|
CROSS_PREFIX := riscv64-unknown-elf-
|
|
CC := $(CROSS_PREFIX)gcc
|
|
AR := $(CROSS_PREFIX)ar
|
|
RANLIB := $(CROSS_PREFIX)ranlib
|
|
|
|
SRC_DIR := .
|
|
OBJ_DIR := obj
|
|
SPROJS_INCLUDE := -I.
|
|
|
|
HOSTFS_ROOT := hostfs_root
|
|
ifneq (,)
|
|
march := -march=
|
|
is_32bit := $(findstring 32,$(march))
|
|
mabi := -mabi=$(if $(is_32bit),ilp32,lp64)
|
|
endif
|
|
|
|
CFLAGS := -Wall -Werror -fno-builtin -nostdlib -D__NO_INLINE__ -mcmodel=medany -g -Og -std=gnu99 -Wno-unused -Wno-attributes -fno-delete-null-pointer-checks -fno-PIE $(march)
|
|
COMPILE := $(CC) -MMD -MP $(CFLAGS) $(SPROJS_INCLUDE)
|
|
|
|
#--------------------- utils -----------------------
|
|
UTIL_CPPS := util/*.c
|
|
|
|
UTIL_CPPS := $(wildcard $(UTIL_CPPS))
|
|
UTIL_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(UTIL_CPPS)))
|
|
|
|
|
|
UTIL_LIB := $(OBJ_DIR)/util.a
|
|
|
|
#--------------------- kernel -----------------------
|
|
KERNEL_LDS := kernel/kernel.lds
|
|
KERNEL_CPPS := \
|
|
kernel/*.c \
|
|
kernel/machine/*.c \
|
|
kernel/util/*.c
|
|
|
|
KERNEL_ASMS := \
|
|
kernel/*.S \
|
|
kernel/machine/*.S \
|
|
kernel/util/*.S
|
|
|
|
KERNEL_CPPS := $(wildcard $(KERNEL_CPPS))
|
|
KERNEL_ASMS := $(wildcard $(KERNEL_ASMS))
|
|
KERNEL_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(KERNEL_CPPS)))
|
|
KERNEL_OBJS += $(addprefix $(OBJ_DIR)/, $(patsubst %.S,%.o,$(KERNEL_ASMS)))
|
|
|
|
KERNEL_TARGET = $(OBJ_DIR)/riscv-pke
|
|
|
|
|
|
#--------------------- spike interface library -----------------------
|
|
SPIKE_INF_CPPS := spike_interface/*.c
|
|
|
|
SPIKE_INF_CPPS := $(wildcard $(SPIKE_INF_CPPS))
|
|
SPIKE_INF_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(SPIKE_INF_CPPS)))
|
|
|
|
|
|
SPIKE_INF_LIB := $(OBJ_DIR)/spike_interface.a
|
|
|
|
|
|
#--------------------- user -----------------------
|
|
USER_CPPS := user/app_shell.c user/user_lib.c
|
|
|
|
USER_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(USER_CPPS)))
|
|
|
|
USER_TARGET := $(HOSTFS_ROOT)/bin/app_shell
|
|
|
|
USER_E_CPPS := user/app_ls.c user/user_lib.c
|
|
|
|
USER_E_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(USER_E_CPPS)))
|
|
|
|
USER_E_TARGET := $(HOSTFS_ROOT)/bin/app_ls
|
|
|
|
USER_M_CPPS := user/app_mkdir.c user/user_lib.c
|
|
|
|
USER_M_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(USER_M_CPPS)))
|
|
|
|
USER_M_TARGET := $(HOSTFS_ROOT)/bin/app_mkdir
|
|
|
|
USER_T_CPPS := user/app_touch.c user/user_lib.c
|
|
|
|
USER_T_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(USER_T_CPPS)))
|
|
|
|
USER_T_TARGET := $(HOSTFS_ROOT)/bin/app_touch
|
|
|
|
USER_C_CPPS := user/app_cat.c user/user_lib.c
|
|
|
|
USER_C_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(USER_C_CPPS)))
|
|
|
|
USER_C_TARGET := $(HOSTFS_ROOT)/bin/app_cat
|
|
|
|
USER_O_CPPS := user/app_echo.c user/user_lib.c
|
|
|
|
USER_O_OBJS := $(addprefix $(OBJ_DIR)/, $(patsubst %.c,%.o,$(USER_O_CPPS)))
|
|
|
|
USER_O_TARGET := $(HOSTFS_ROOT)/bin/app_echo
|
|
#------------------------targets------------------------
|
|
$(OBJ_DIR):
|
|
@-mkdir -p $(OBJ_DIR)
|
|
@-mkdir -p $(dir $(UTIL_OBJS))
|
|
@-mkdir -p $(dir $(SPIKE_INF_OBJS))
|
|
@-mkdir -p $(dir $(KERNEL_OBJS))
|
|
@-mkdir -p $(dir $(USER_OBJS))
|
|
@-mkdir -p $(dir $(USER_E_OBJS))
|
|
@-mkdir -p $(dir $(USER_M_OBJS))
|
|
@-mkdir -p $(dir $(USER_T_OBJS))
|
|
@-mkdir -p $(dir $(USER_C_OBJS))
|
|
@-mkdir -p $(dir $(USER_O_OBJS))
|
|
|
|
$(OBJ_DIR)/%.o : %.c
|
|
@echo "compiling" $<
|
|
@$(COMPILE) -c $< -o $@
|
|
|
|
$(OBJ_DIR)/%.o : %.S
|
|
@echo "compiling" $<
|
|
@$(COMPILE) -c $< -o $@
|
|
|
|
$(UTIL_LIB): $(OBJ_DIR) $(UTIL_OBJS)
|
|
@echo "linking " $@ ...
|
|
@$(AR) -rcs $@ $(UTIL_OBJS)
|
|
@echo "Util lib has been build into" \"$@\"
|
|
|
|
$(SPIKE_INF_LIB): $(OBJ_DIR) $(UTIL_OBJS) $(SPIKE_INF_OBJS)
|
|
@echo "linking " $@ ...
|
|
@$(AR) -rcs $@ $(SPIKE_INF_OBJS) $(UTIL_OBJS)
|
|
@echo "Spike lib has been build into" \"$@\"
|
|
|
|
$(KERNEL_TARGET): $(OBJ_DIR) $(UTIL_LIB) $(SPIKE_INF_LIB) $(KERNEL_OBJS) $(KERNEL_LDS)
|
|
@echo "linking" $@ ...
|
|
@$(COMPILE) $(KERNEL_OBJS) $(UTIL_LIB) $(SPIKE_INF_LIB) -o $@ -T $(KERNEL_LDS)
|
|
@echo "PKE core has been built into" \"$@\"
|
|
|
|
$(USER_TARGET): $(OBJ_DIR) $(UTIL_LIB) $(USER_OBJS)
|
|
@echo "linking" $@ ...
|
|
-@mkdir -p $(HOSTFS_ROOT)/bin
|
|
@$(COMPILE) --entry=main $(USER_OBJS) $(UTIL_LIB) -o $@
|
|
@echo "User app has been built into" \"$@\"
|
|
@cp $@ $(OBJ_DIR)
|
|
|
|
$(USER_E_TARGET): $(OBJ_DIR) $(UTIL_LIB) $(USER_E_OBJS)
|
|
@echo "linking" $@ ...
|
|
-@mkdir -p $(HOSTFS_ROOT)/bin
|
|
@$(COMPILE) --entry=main $(USER_E_OBJS) $(UTIL_LIB) -o $@
|
|
@echo "User app has been built into" \"$@\"
|
|
|
|
$(USER_M_TARGET): $(OBJ_DIR) $(UTIL_LIB) $(USER_M_OBJS)
|
|
@echo "linking" $@ ...
|
|
-@mkdir -p $(HOSTFS_ROOT)/bin
|
|
@$(COMPILE) --entry=main $(USER_M_OBJS) $(UTIL_LIB) -o $@
|
|
@echo "User app has been built into" \"$@\"
|
|
|
|
$(USER_T_TARGET): $(OBJ_DIR) $(UTIL_LIB) $(USER_T_OBJS)
|
|
@echo "linking" $@ ...
|
|
-@mkdir -p $(HOSTFS_ROOT)/bin
|
|
@$(COMPILE) --entry=main $(USER_T_OBJS) $(UTIL_LIB) -o $@
|
|
@echo "User app has been built into" \"$@\"
|
|
|
|
$(USER_C_TARGET): $(OBJ_DIR) $(UTIL_LIB) $(USER_C_OBJS)
|
|
@echo "linking" $@ ...
|
|
-@mkdir -p $(HOSTFS_ROOT)/bin
|
|
@$(COMPILE) --entry=main $(USER_C_OBJS) $(UTIL_LIB) -o $@
|
|
@echo "User app has been built into" \"$@\"
|
|
|
|
$(USER_O_TARGET): $(OBJ_DIR) $(UTIL_LIB) $(USER_O_OBJS)
|
|
@echo "linking" $@ ...
|
|
-@mkdir -p $(HOSTFS_ROOT)/bin
|
|
@$(COMPILE) --entry=main $(USER_O_OBJS) $(UTIL_LIB) -o $@
|
|
@echo "User app has been built into" \"$@\"
|
|
|
|
-include $(wildcard $(OBJ_DIR)/*/*.d)
|
|
-include $(wildcard $(OBJ_DIR)/*/*/*.d)
|
|
|
|
.DEFAULT_GOAL := $(all)
|
|
|
|
all: $(KERNEL_TARGET) $(USER_TARGET) $(USER_E_TARGET) $(USER_M_TARGET) $(USER_T_TARGET) $(USER_C_TARGET) $(USER_O_TARGET)
|
|
.PHONY:all
|
|
|
|
run: $(KERNEL_TARGET) $(USER_TARGET) $(USER_E_TARGET) $(USER_M_TARGET) $(USER_T_TARGET) $(USER_C_TARGET) $(USER_O_TARGET)
|
|
@echo "********************HUST PKE********************"
|
|
spike $(KERNEL_TARGET) /bin/app_shell
|
|
|
|
# need openocd!
|
|
gdb:$(KERNEL_TARGET) $(USER_TARGET)
|
|
spike --rbb-port=9824 -H $(KERNEL_TARGET) $(USER_TARGET) &
|
|
@sleep 1
|
|
openocd -f ./.spike.cfg &
|
|
@sleep 1
|
|
riscv64-unknown-elf-gdb -command=./.gdbinit
|
|
|
|
# clean gdb. need openocd!
|
|
gdb_clean:
|
|
@-kill -9 $$(lsof -i:9824 -t)
|
|
@-kill -9 $$(lsof -i:3333 -t)
|
|
@sleep 1
|
|
|
|
objdump:
|
|
riscv64-unknown-elf-objdump -d $(KERNEL_TARGET) > $(OBJ_DIR)/kernel_dump
|
|
riscv64-unknown-elf-objdump -d $(USER_TARGET) > $(OBJ_DIR)/user_dump
|
|
|
|
cscope:
|
|
find ./ -name "*.c" > cscope.files
|
|
find ./ -name "*.h" >> cscope.files
|
|
find ./ -name "*.S" >> cscope.files
|
|
find ./ -name "*.lds" >> cscope.files
|
|
cscope -bqk
|
|
|
|
format:
|
|
@python ./format.py ./
|
|
|
|
clean:
|
|
rm -fr ${OBJ_DIR} ${HOSTFS_ROOT}/bin
|