gcc: RISC-V 6.3.0

issue #2423
This commit is contained in:
Sebastian Sumpf 2017-05-03 15:40:44 +02:00 committed by Christian Helmuth
parent 664702d8b5
commit 496671e523
7 changed files with 10811 additions and 11831 deletions

View File

@ -1,6 +1,6 @@
INC_DIR += $(REP_DIR)/src/core/spec/riscv INC_DIR += $(REP_DIR)/src/core/spec/riscv
CC_OPT += -fno-delete-null-pointer-checks -msoft-float CC_OPT += -fno-delete-null-pointer-checks
# add C++ sources # add C++ sources
SRC_CC += platform_services.cc SRC_CC += platform_services.cc

View File

@ -1 +1 @@
8943c53d0247a0a69fb62be66a224348170af9be e062a6fcfe6dcbfcba8bbb58f833669766487b56

View File

@ -1,20 +1,12 @@
config.patch commit 3f0b1ef2e5aebf896033ee5f78635d349807fc08
Author: Sebastian Sumpf <sebastian.sumpf@genode-labs.com>
From: Christian Prochaska <christian.prochaska@genode-labs.com> Date: Wed May 3 14:15:07 2017 +0200
---
gcc/config.gcc | 2 +-
gcc/config/arm/unknown-elf.h | 16 ++++++++++++++++
gcc/config/i386/x86-64.h | 23 +++++++++++++++++++++--
libgcc/config.host | 12 ++++++++++--
4 files changed, 48 insertions(+), 5 deletions(-)
diff --git a/gcc/config.gcc b/gcc/config.gcc diff --git a/gcc/config.gcc b/gcc/config.gcc
index 1d5b23f..1840148 100644 index 263739c..2bc831e 100644
--- a/gcc/config.gcc --- a/gcc/config.gcc
+++ b/gcc/config.gcc +++ b/gcc/config.gcc
@@ -1119,7 +1119,7 @@ arm*-*-eabi* | arm*-*-symbianelf* | arm*-*-rtems*) @@ -1123,7 +1123,7 @@ arm*-*-eabi* | arm*-*-symbianelf* | arm*-*-rtems*)
case ${target} in case ${target} in
arm*-*-eabi*) arm*-*-eabi*)
tm_file="$tm_file newlib-stdint.h" tm_file="$tm_file newlib-stdint.h"
@ -23,6 +15,7 @@ index 1d5b23f..1840148 100644
use_gcc_stdint=wrap use_gcc_stdint=wrap
;; ;;
arm*-*-rtems*) arm*-*-rtems*)
--- a/gcc/config/arm/arm.h --- a/gcc/config/arm/arm.h
+++ b/gcc/config/arm/arm.h +++ b/gcc/config/arm/arm.h
@@ -671,11 +671,11 @@ @@ -671,11 +671,11 @@
@ -39,6 +32,17 @@ index 1d5b23f..1840148 100644
#endif #endif
/* AAPCS requires that structure alignment is affected by bitfields. */ /* AAPCS requires that structure alignment is affected by bitfields. */
@@ -2064,7 +2064,7 @@ riscv*-*-elf*)
xyes) tmake_file="${tmake_file} riscv/t-elf-multilib" ;;
*) echo "Unknown value for enable_multilib"; exit 1
esac
- tmake_file="${tmake_file} riscv/t-riscv"
+ tmake_file="${tmake_file} riscv/t-riscv t-slibgcc"
gnu_ld=yes
gas=yes
# Force .init_array support. The configure script cannot always
diff --git a/gcc/config/arm/unknown-elf.h b/gcc/config/arm/unknown-elf.h diff --git a/gcc/config/arm/unknown-elf.h b/gcc/config/arm/unknown-elf.h
index fafe057..8bd23e0 100644 index fafe057..8bd23e0 100644
--- a/gcc/config/arm/unknown-elf.h --- a/gcc/config/arm/unknown-elf.h
@ -103,11 +107,25 @@ index 204f128..8f590fe 100644
+/* Don't assume anything about the header files. */ +/* Don't assume anything about the header files. */
+/* https://gcc.gnu.org/bugzilla/show_bug.cgi?id=57699 */ +/* https://gcc.gnu.org/bugzilla/show_bug.cgi?id=57699 */
+#define NO_IMPLICIT_EXTERN_C +#define NO_IMPLICIT_EXTERN_C
diff --git a/gcc/config/riscv/elf.h b/gcc/config/riscv/elf.h
index 391e59f..9271e17 100644
--- a/gcc/config/riscv/elf.h
+++ b/gcc/config/riscv/elf.h
@@ -19,7 +19,8 @@ along with GCC; see the file COPYING3. If not see
#define LINK_SPEC "\
-melf" XLEN_SPEC "lriscv \
-%{shared}"
+%{shared:-shared} \
+%{!static:--eh-frame-hdr}"
/* Link against Newlib libraries, because the ELF backend assumes Newlib.
Handle the circular dependence between libc and libgloss. */
diff --git a/libgcc/config.host b/libgcc/config.host diff --git a/libgcc/config.host b/libgcc/config.host
index 124f2ce..7b25b79 100644 index 40e3038..fd206a4 100644
--- a/libgcc/config.host --- a/libgcc/config.host
+++ b/libgcc/config.host +++ b/libgcc/config.host
@@ -309,7 +309,7 @@ case ${host} in @@ -312,7 +312,7 @@ case ${host} in
tmake_file=t-vxworks tmake_file=t-vxworks
;; ;;
*-*-elf) *-*-elf)
@ -116,7 +134,7 @@ index 124f2ce..7b25b79 100644
;; ;;
esac esac
@@ -414,8 +414,12 @@ arm*-*-eabi* | arm*-*-symbianelf* | arm*-*-rtems*) @@ -417,8 +417,12 @@ arm*-*-eabi* | arm*-*-symbianelf* | arm*-*-rtems*)
tm_file="$tm_file arm/bpabi-lib.h" tm_file="$tm_file arm/bpabi-lib.h"
case ${host} in case ${host} in
arm*-*-eabi* | arm*-*-rtems*) arm*-*-eabi* | arm*-*-rtems*)
@ -130,7 +148,7 @@ index 124f2ce..7b25b79 100644
;; ;;
arm*-*-symbianelf*) arm*-*-symbianelf*)
tmake_file="${tmake_file} arm/t-symbian t-slibgcc-nolc-override" tmake_file="${tmake_file} arm/t-symbian t-slibgcc-nolc-override"
@@ -585,6 +589,10 @@ i[34567]86-*-elf*) @@ -588,6 +592,10 @@ i[34567]86-*-elf*)
tmake_file="$tmake_file i386/t-crtstuff t-crtstuff-pic t-libgcc-pic" tmake_file="$tmake_file i386/t-crtstuff t-crtstuff-pic t-libgcc-pic"
;; ;;
x86_64-*-elf* | x86_64-*-rtems*) x86_64-*-elf* | x86_64-*-rtems*)
@ -141,3 +159,14 @@ index 124f2ce..7b25b79 100644
tmake_file="$tmake_file i386/t-crtstuff t-crtstuff-pic t-libgcc-pic" tmake_file="$tmake_file i386/t-crtstuff t-crtstuff-pic t-libgcc-pic"
;; ;;
i[34567]86-*-dragonfly*) i[34567]86-*-dragonfly*)
@@ -1104,8 +1112,8 @@ riscv*-*-linux*)
md_unwind_header=riscv/linux-unwind.h
;;
riscv*-*-*)
- tmake_file="${tmake_file} riscv/t-softfp${host_address} t-softfp riscv/t-elf riscv/t-elf${host_address}"
- extra_parts="$extra_parts crtbegin.o crtend.o crti.o crtn.o"
+ tmake_file="${tmake_file} riscv/t-softfp${host_address} t-softfp riscv/t-elf riscv/t-elf${host_address} t-crtstuff-pic t-libgcc-pic t-eh-dw2-dip t-slibgcc t-slibgcc-gld t-slibgcc-elf-ver"
+ extra_parts="crtbegin.o crtbeginS.o crtbeginT.o crtend.o crtendS.o"
;;
rs6000-ibm-aix4.[3456789]* | powerpc-ibm-aix4.[3456789]*)
md_unwind_header=rs6000/aix-unwind.h

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -1,3 +1,4 @@
riscv.patch
config.patch config.patch
misc.patch misc.patch
no_short_enums.patch no_short_enums.patch

View File

@ -175,7 +175,9 @@ LOCAL_LIB_INSTALL_LOCATION = $(shell pwd)/build/lib-install
TARGET_NAME_x86 = x86_64-pc-elf TARGET_NAME_x86 = x86_64-pc-elf
TARGET_NAME_arm = arm-none-eabi TARGET_NAME_arm = arm-none-eabi
TARGET_NAME_riscv = riscv-unknown-elf TARGET_NAME_riscv = riscv64-unknown-elf
GCC_CONFIG_riscv = --with-arch=rv64imac
ifneq ($(VERBOSE),) ifneq ($(VERBOSE),)
CONFIG_QUIET = --quiet CONFIG_QUIET = --quiet
@ -189,6 +191,19 @@ COMMON_BOOTSTRAP_CONFIG = $(CONFIG_QUIET) \
BINUTILS_BOOTSTRAP_CONFIG += $(COMMON_BOOTSTRAP_CONFIG) BINUTILS_BOOTSTRAP_CONFIG += $(COMMON_BOOTSTRAP_CONFIG)
ifeq ($(PLATFORM),riscv)
LANGUAGES = c,c++
GDB_INSTALLED_BINARIES =
LIB_GCC = cd $(INSTALL_LOCATION)/lib/gcc/riscv64-unknown-elf/$(GCC_VERSION)/rv64imac/lp64 && \
sudo ln -sf ../../include include
INSTALL_ADA =
else
LANGUAGES = c,c++,ada
GDB_INSTALLED_BINARIES = $(LOCAL_INSTALL_LOCATION)/bin/genode-$(PLATFORM)-gdb
LIB_GCC =
INSTALL_ADA = sudo cp $(LOCAL_BOOTSTRAP_INSTALL_LOCATION)/bin/gnatmake $(INSTALL_LOCATION)/bin/genode-$(PLATFORM)-gnatmake
endif
GCC_BOOTSTRAP_CONFIG += $(COMMON_BOOTSTRAP_CONFIG) \ GCC_BOOTSTRAP_CONFIG += $(COMMON_BOOTSTRAP_CONFIG) \
--enable-languages=c,c++,ada \ --enable-languages=c,c++,ada \
--disable-bootstrap \ --disable-bootstrap \
@ -237,7 +252,7 @@ BINUTILS_CONFIG += $(BINUTILS_CONFIG_$(PLATFORM))
GDB_CONFIG += $(COMMON_CONFIG) --disable-werror GDB_CONFIG += $(COMMON_CONFIG) --disable-werror
GCC_CONFIG += $(COMMON_CONFIG) \ GCC_CONFIG += $(COMMON_CONFIG) \
--enable-languages=c,c++,go,ada \ --enable-languages=$(LANGUAGES),go \
--disable-libgo \ --disable-libgo \
--disable-gotools \ --disable-gotools \
--disable-libssp \ --disable-libssp \
@ -300,11 +315,6 @@ GCC_BINARIES = build/$(PLATFORM)/gcc/gcc/g++-cross
GCC_INSTALLED_BINARIES = $(LOCAL_INSTALL_LOCATION)/bin/genode-$(PLATFORM)-g++ GCC_INSTALLED_BINARIES = $(LOCAL_INSTALL_LOCATION)/bin/genode-$(PLATFORM)-g++
GDB_BINARIES = build/$(PLATFORM)/gdb/gdb/gdb GDB_BINARIES = build/$(PLATFORM)/gdb/gdb/gdb
ifeq ($(PLATFORM),riscv)
GDB_INSTALLED_BINARIES =
else
GDB_INSTALLED_BINARIES = $(LOCAL_INSTALL_LOCATION)/bin/genode-$(PLATFORM)-gdb
endif
build_all: $(GCC_INSTALLED_BINARIES) $(GDB_INSTALLED_BINARIES) build_all: $(GCC_INSTALLED_BINARIES) $(GDB_INSTALLED_BINARIES)
@ -492,4 +502,5 @@ cleanall: clean
install: build_all install: build_all
$(ECHO) "$(BRIGHT_COL)installing tool chain to '$(INSTALL_LOCATION)'...$(DEFAULT_COL)" $(ECHO) "$(BRIGHT_COL)installing tool chain to '$(INSTALL_LOCATION)'...$(DEFAULT_COL)"
$(VERBOSE)sudo cp -a --remove-destination --no-target-directory $(LOCAL_INSTALL_LOCATION) $(INSTALL_LOCATION) $(VERBOSE)sudo cp -a --remove-destination --no-target-directory $(LOCAL_INSTALL_LOCATION) $(INSTALL_LOCATION)
$(VERBOSE)sudo cp $(LOCAL_BOOTSTRAP_INSTALL_LOCATION)/bin/gnatmake $(INSTALL_LOCATION)/bin/genode-$(PLATFORM)-gnatmake $(VERBOSE)$(INSTALL_ADA)
$(VERBOSE)$(LIB_GCC)