OpenCores
URL https://opencores.org/ocsvn/riscv_vhdl/riscv_vhdl/trunk

Subversion Repositories riscv_vhdl

[/] [riscv_vhdl/] [trunk/] [examples/] [boot/] [makefiles/] [make_boot] - Blame information for rev 5

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 5 sergeykhbr
include util.mak
2
 
3
CC=riscv64-unknown-elf-gcc
4
CPP=riscv64-unknown-elf-gcc
5
OBJDUMP=riscv64-unknown-elf-objdump
6
 
7
FPU_ENABLED=0
8
 
9
CFLAGS= -c -g -static -std=gnu99 -O0 -fno-common -fno-builtin-printf
10
ifeq ($(FPU_ENABLED), 1)
11
  CFLAGS += -march=RV64IMFD -DFPU_ENABLED
12
else
13
#  CFLAGS += -march=RV64IMA
14
#  CFLAGS += -msoft-float
15
endif
16
 
17
 
18
LDFLAGS=-T test.ld -nostdlib -nostartfiles
19
INCL_KEY=-I
20
DIR_KEY=-B
21
 
22
 
23
# include sub-folders list
24
INCL_PATH=\
25
        $(TOP_DIR)../common \
26
        $(TOP_DIR)src
27
 
28
# source files directories list:
29
SRC_PATH =\
30
        $(TOP_DIR)src
31
 
32
LIB_NAMES =\
33
        gcc \
34
        c \
35
        m
36
 
37
VPATH = $(SRC_PATH)
38
 
39
SOURCES = main \
40
        trap \
41
        crt
42
 
43
OBJ_FILES = $(addsuffix .o,$(SOURCES))
44
EXECUTABLE = bootimage
45
DUMPFILE = $(EXECUTABLE).dump
46
HEXFILE = $(EXECUTABLE).hex
47
LSTFILE = $(EXECUTABLE).lst
48
 
49
all: boot
50
 
51
.PHONY: $(EXECUTABLE) $(DUMPFILE)
52
 
53
 
54
boot: $(EXECUTABLE) $(DUMPFILE) $(HEXFILE)
55
$(HEXFILE): $(EXECUTABLE)
56
        echo elf2raw64 $(addprefix $(ELF_DIR)/,$<) -h -f 8192 -l 8 -b 0x00000000 -o $(addprefix $(ELF_DIR)/,$(EXECUTABLE).hex)
57
        elf2raw64 $(addprefix $(ELF_DIR)/,$<) -h -f 8192 -l 8 -b 0x00000000 -o $(addprefix $(ELF_DIR)/,$(EXECUTABLE).hex)
58
 
59
$(DUMPFILE): $(EXECUTABLE)
60
        echo $(OBJDUMP) --disassemble-all --disassemble-zeroes --section=.text --section=.text.startup --section=.data $(addprefix $(ELF_DIR)/,$<) > $(addprefix $(ELF_DIR)/,$@)
61
        $(OBJDUMP) --disassemble-all --disassemble-zeroes --section=.text --section=.text.startup --section=.data $(addprefix $(ELF_DIR)/,$<) > $(addprefix $(ELF_DIR)/,$@)
62
        $(OBJDUMP) -S $(addprefix $(ELF_DIR)/,$<) > $(addprefix $(ELF_DIR)/,$(LSTFILE))
63
 
64
 
65
$(EXECUTABLE): $(OBJ_FILES)
66
        echo $(CPP) $(LDFLAGS) $(addprefix $(OBJ_DIR)/,$(OBJ_FILES)) -o $(addprefix $(ELF_DIR)/,$@) $(addprefix -l,$(LIB_NAMES))
67
        $(CPP) $(LDFLAGS) $(addprefix $(OBJ_DIR)/,$(OBJ_FILES)) -o $(addprefix $(ELF_DIR)/,$@) $(addprefix -l,$(LIB_NAMES))
68
        $(ECHO) "\n  Shared Library has been built successfully.\n"
69
 
70
#.cpp.o:
71
%.o: %.cpp
72
        echo $(CPP) $(CFLAGS) $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
73
        $(CPP) $(CFLAGS) $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
74
 
75
#.c.o:
76
%.o: %.c
77
        echo $(CC) $(CFLAGS) $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
78
        $(CC) $(CFLAGS) $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
79
 
80
%.o: %.S
81
        echo $(CC) $(CFLAGS) -D__ASSEMBLY__=1 $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
82
        $(CC) $(CFLAGS) -D__ASSEMBLY__=1 $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
83
 
84
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.