This repository has been archived by the owner on Feb 27, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
73 lines (52 loc) · 1.7 KB
/
Makefile
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
include src/Makefile.testcase
.PHONY: clean
ifndef CROSS_COMPILE
CROSS_COMPILE := mips-sde-elf-
endif
ifndef TESTCASE_SRC_DIR
TESTCASE_SRC_DIR := src/inst/
endif
ifndef TESTCASE_BUILD_DIR
TESTCASE_BUILD_DIR := build/
endif
TEST_INC_DIR := src/include
DEBUG := false
CC := $(CROSS_COMPILE)gcc
AS := $(CROSS_COMPILE)as
LD := $(CROSS_COMPILE)ld
OBJCOPY := $(CROSS_COMPILE)objcopy
OBJDUMP := $(CROSS_COMPILE)objdump
CFLAGS := -I$(TEST_INC_DIR) -mips1 -EL
ifeq ($(DEBUG), true)
CFLAGS += -g
endif
OBJECTS := $(TESTCASE_BUILD_DIR)$(USER_PROGRAM).o
export CROSS_COMPILE
export TESTCASE_SRC_DIR
export TESTCASE_BUILD_DIR
# ********************
# Rules of Compilation
# ********************
all: inst.bin data.bin convert
@./convert inst.bin data.bin
@mv convert $(TESTCASE_BUILD_DIR)
@mv inst_rom.coe $(TESTCASE_BUILD_DIR)$(USER_PROGRAM)_inst.coe
@mv data_ram.coe $(TESTCASE_BUILD_DIR)$(USER_PROGRAM)_data.coe
@mv $(TESTCASE_BUILD_DIR)$(USER_PROGRAM)_inst.coe ../../Soc/coe/$(USER_PROGRAM)_inst.coe
@mv $(TESTCASE_BUILD_DIR)$(USER_PROGRAM)_data.coe ../../Soc/coe/$(USER_PROGRAM)_data.coe
$(TESTCASE_BUILD_DIR)$(USER_PROGRAM).o: $(TESTCASE_SRC_DIR)$(USER_PROGRAM).S
@mkdir -p $(TESTCASE_BUILD_DIR)
$(CC) $(CFLAGS) -D_KERNEL -DCONFIG_PAGE_SIZE_16KB -fno-builtin -mips32r2 -msoft-float -c $< -o $@ -nostdinc -nostdlib
$(TESTCASE_BUILD_DIR)$(USER_PROGRAM): default.ld $(OBJECTS)
$(LD) -T default.ld $(CFLAGS) $(OBJECTS) -o $@
$(OBJDUMP) -alD $@ > [email protected]
inst.bin: $(TESTCASE_BUILD_DIR)$(USER_PROGRAM)
$(OBJCOPY) -O binary -j .text $< $@
data.bin: $(TESTCASE_BUILD_DIR)$(USER_PROGRAM)
$(OBJCOPY) -O binary -j .data $< $@
convert: convert.c
gcc $< -o $@
clean:
rm -f ../../Soc/coe/*.coe
rm -f *.bin
rm -rf build/