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

Subversion Repositories riscv_vhdl

[/] [riscv_vhdl/] [trunk/] [examples/] [helloworld/] [makefiles/] [make_example] - Blame information for rev 5

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 5 sergeykhbr
include makeutil.mak
2
 
3
CC=riscv64-unknown-elf-gcc
4
CPP=riscv64-unknown-elf-gcc
5
OBJDUMP=riscv64-unknown-elf-objdump
6
 
7
CFLAGS= -c -fPIC -g -O0
8
LDFLAGS=-static -T app.ld -nostartfiles
9
INCL_KEY=-I
10
DIR_KEY=-B
11
 
12
 
13
# include sub-folders list
14
INCL_PATH=\
15
        $(TOP_DIR)common \
16
        $(TOP_DIR)helloworld/src
17
 
18
# source files directories list:
19
SRC_PATH = \
20
        $(TOP_DIR)helloworld/src
21
 
22
LIB_NAMES = \
23
        gcc \
24
        stdc++ \
25
        c \
26
        m
27
 
28
VPATH = $(SRC_PATH)
29
 
30
SOURCES = \
31
        main \
32
        helloworld
33
 
34
OBJ_FILES = $(addsuffix .o,$(SOURCES))
35
EXECUTABLE = helloworld
36
DUMPFILE = $(EXECUTABLE).dump
37
HEXFILE = $(EXECUTABLE).hex
38
LSTFILE = $(EXECUTABLE).lst
39
 
40
all: example
41
 
42
.PHONY: $(EXECUTABLE)
43
 
44
 
45
example: $(EXECUTABLE) $(DUMPFILE) $(HEXFILE)
46
 
47
$(HEXFILE): $(EXECUTABLE)
48
        echo elf2raw64 $(addprefix $(ELF_DIR)/,$<) -h -f 262144 -l 8 -o $(addprefix $(ELF_DIR)/,$(EXECUTABLE).hex)
49
        elf2raw64 $(addprefix $(ELF_DIR)/,$<) -h -f 262144 -l 8 -o $(addprefix $(ELF_DIR)/,$(EXECUTABLE).hex)
50
 
51
$(DUMPFILE): $(EXECUTABLE)
52
        echo $(OBJDUMP) --disassemble-all --disassemble-zeroes --section=.text --section=.text.startup --section=.data $(addprefix $(ELF_DIR)/,$<) > $(addprefix $(ELF_DIR)/,$@)
53
        $(OBJDUMP) --disassemble-all --disassemble-zeroes --section=.text --section=.text.startup --section=.data $(addprefix $(ELF_DIR)/,$<) > $(addprefix $(ELF_DIR)/,$@)
54
        $(OBJDUMP) -S $(addprefix $(ELF_DIR)/,$<) > $(addprefix $(ELF_DIR)/,$(LSTFILE))
55
 
56
$(EXECUTABLE): $(OBJ_FILES)
57
        echo $(CPP) $(LDFLAGS) $(addprefix $(OBJ_DIR)/,$(OBJ_FILES)) -o $(addprefix $(ELF_DIR)/,$@) $(addprefix -l,$(LIB_NAMES))
58
        $(CPP) $(LDFLAGS) $(addprefix $(OBJ_DIR)/,$(OBJ_FILES)) -o $(addprefix $(ELF_DIR)/,$@) $(addprefix -l,$(LIB_NAMES))
59
        $(ECHO) "\n  helloworld has been built successfully.\n"
60
 
61
%.o: %.cpp
62
        echo $(CPP) $(CFLAGS) $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
63
        $(CPP) $(CFLAGS) $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
64
 
65
%.o: %.c
66
        echo $(CC) $(CFLAGS) $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
67
        $(CC) $(CFLAGS) $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
68
 
69
%.o: %.S
70
        echo $(CC) $(CFLAGS) -D__ASSEMBLY__=1 $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)
71
        $(CC) $(CFLAGS) -D__ASSEMBLY__=1 $(addprefix $(INCL_KEY),$(INCL_PATH)) $< -o $(addprefix $(OBJ_DIR)/,$@)

powered by: WebSVN 2.1.0

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