bios: fix riscv processor print
[litex.git] / litex / soc / software / common.mak
1 TARGET_PREFIX=$(TRIPLE)-
2
3 RM ?= rm -f
4 PYTHON ?= python
5
6 ifeq ($(CLANG),1)
7 CC_normal := clang -target $(TRIPLE) -integrated-as
8 CX_normal := clang++ -target $(TRIPLE) -integrated-as
9 else
10 CC_normal := $(TARGET_PREFIX)gcc -std=gnu99
11 CX_normal := $(TARGET_PREFIX)g++
12 endif
13 AR_normal := $(TARGET_PREFIX)ar
14 LD_normal := $(TARGET_PREFIX)ld
15 OBJCOPY_normal := $(TARGET_PREFIX)objcopy
16
17 CC_quiet = @echo " CC " $@ && $(CC_normal)
18 CX_quiet = @echo " CX " $@ && $(CX_normal)
19 AR_quiet = @echo " AR " $@ && $(AR_normal)
20 LD_quiet = @echo " LD " $@ && $(LD_normal)
21 OBJCOPY_quiet = @echo " OBJCOPY " $@ && $(OBJCOPY_normal)
22
23 ifeq ($(V),1)
24 CC = $(CC_normal)
25 CX = $(CX_normal)
26 AR = $(AR_normal)
27 LD = $(LD_normal)
28 OBJCOPY = $(OBJCOPY_normal)
29 else
30 CC = $(CC_quiet)
31 CX = $(CX_quiet)
32 AR = $(AR_quiet)
33 LD = $(LD_quiet)
34 OBJCOPY = $(OBJCOPY_quiet)
35 endif
36
37 # http://scottmcpeak.com/autodepend/autodepend.html
38 # Generate *.d Makefile dependencies fragments, include using;
39 # -include $(OBJECTS:.o=.d)
40 DEPFLAGS += -MD -MP
41
42 # Toolchain options
43 #
44 INCLUDES = -I$(SOC_DIRECTORY)/software/include/base -I$(SOC_DIRECTORY)/software/include -I$(SOC_DIRECTORY)/common -I$(BUILDINC_DIRECTORY)
45 COMMONFLAGS = $(DEPFLAGS) -Os $(CPUFLAGS) -g3 -fomit-frame-pointer -Wall -fno-builtin -nostdinc $(INCLUDES)
46 CFLAGS = $(COMMONFLAGS) -fexceptions -Wstrict-prototypes -Wold-style-definition -Wmissing-prototypes
47 CXXFLAGS = $(COMMONFLAGS) -std=c++11 -I$(SOC_DIRECTORY)/software/include/basec++ -fexceptions -fno-rtti -ffreestanding
48 LDFLAGS = -nostdlib -nodefaultlibs -L$(BUILDINC_DIRECTORY)
49
50 define compilexx
51 $(CX) -c $(CXXFLAGS) $(1) $< -o $@
52 endef
53
54 define compile
55 $(CC) -c $(CFLAGS) $(1) $< -o $@
56 endef
57
58 define assemble
59 $(CC) -c $(CFLAGS) -o $@ $<
60 endef