mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
patches for custom toolchain
Signed-off-by: xhe <xw897002528@gmail.com>
This commit is contained in:
parent
3dbe349dd9
commit
89fdb49884
3 changed files with 16 additions and 2 deletions
|
@ -50,6 +50,7 @@ class CPUNone(CPU):
|
|||
}
|
||||
|
||||
CPU_GCC_TRIPLE_RISCV64 = (
|
||||
"riscv64-pc-linux-musl",
|
||||
"riscv64-unknown-elf",
|
||||
"riscv64-unknown-linux-gnu",
|
||||
"riscv64-elf",
|
||||
|
|
|
@ -89,9 +89,15 @@ def get_cpu_mak(cpu, compile_software):
|
|||
raise OSError(msg)
|
||||
return r
|
||||
|
||||
selected_triple = select_triple(triple)
|
||||
if not clang:
|
||||
binutils_version = re.match("GNU ar \(GNU Binutils\) (.+)\.(.+)", os.popen(selected_triple + "-ar -V").read())
|
||||
if int(binutils_version.group(1)) >= 2 and int(binutils_version.group(2)) >= 37 and (not re.search("zicsr", flags)):
|
||||
flags = re.compile("-march=([^ ]+)").sub("-march=\\1_zicsr", flags)
|
||||
|
||||
# Return informations.
|
||||
return [
|
||||
("TRIPLE", select_triple(triple)),
|
||||
("TRIPLE", selected_triple),
|
||||
("CPU", cpu.name),
|
||||
("CPUFAMILY", cpu.family),
|
||||
("CPUFLAGS", flags),
|
||||
|
|
|
@ -14,6 +14,7 @@ CX_normal := $(CCACHE) clang++ -target $(TRIPLE) -integrated-as
|
|||
else
|
||||
CC_normal := $(CCACHE) $(TARGET_PREFIX)gcc -std=gnu99
|
||||
CX_normal := $(CCACHE) $(TARGET_PREFIX)g++
|
||||
GCC_INSTALLATION_PATH := $(patsubst %/libgcc.a,%,$(shell $(CC) -print-libgcc-file-name))
|
||||
endif
|
||||
AR_normal := $(TARGET_PREFIX)gcc-ar
|
||||
LD_normal := $(TARGET_PREFIX)ld
|
||||
|
@ -54,7 +55,13 @@ INCLUDES = -I$(PICOLIBC_DIRECTORY)/newlib/libc/tinystdio \
|
|||
-I$(BUILDINC_DIRECTORY) \
|
||||
-I$(BUILDINC_DIRECTORY)/../libc \
|
||||
-I$(CPU_DIRECTORY)
|
||||
COMMONFLAGS = $(DEPFLAGS) -Os $(CPUFLAGS) -g3 -fomit-frame-pointer -Wall -fno-builtin -fno-stack-protector -flto $(INCLUDES)
|
||||
COMMONFLAGS = $(DEPFLAGS) -Os $(CPUFLAGS) -g3 -fomit-frame-pointer -Wall -fno-builtin -fno-stack-protector $(INCLUDES)
|
||||
ifneq (,$(GCC_INSTALLATION_PATH))
|
||||
COMMONFLAGS += -nostdinc -I$(GCC_INSTALLATION_PATH)/include -I$(GCC_INSTALLATION_PATH)/include-fixed
|
||||
endif
|
||||
ifeq (,$(findstring musl,$(TRIPLE)))
|
||||
COMMONFLAGS += -flto
|
||||
endif
|
||||
ifneq ($(CPUFAMILY), arm)
|
||||
COMMONFLAGS += -fexceptions
|
||||
endif
|
||||
|
|
Loading…
Reference in a new issue