From e35b896f39231390446be7710953ccffc26578e8 Mon Sep 17 00:00:00 2001 From: Dingli Zhang Date: Mon, 2 Sep 2024 13:20:49 +0000 Subject: [PATCH 1/2] 8199138: Add RISC-V support to Zero --- common/autoconf/build-aux/config.guess | 8 ++ common/autoconf/generated-configure.sh | 156 ++++++++++++++----------- common/autoconf/platform.m4 | 6 + hotspot/src/os/linux/vm/os_linux.cpp | 8 +- 4 files changed, 106 insertions(+), 72 deletions(-) diff --git a/common/autoconf/build-aux/config.guess b/common/autoconf/build-aux/config.guess index 288edb6e0e3..b32ca48dd54 100644 --- a/common/autoconf/build-aux/config.guess +++ b/common/autoconf/build-aux/config.guess @@ -95,4 +95,12 @@ if [ "x$OUT" = x ]; then fi fi +# Test and fix riscv64. +if [ "x$OUT" = x ]; then + if [ `uname -s` = Linux ]; then + if [ `uname -m` = riscv64 ]; then + OUT=riscv64-unknown-linux-gnu + fi + fi +fi echo $OUT diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index ad3f7f232ea..e0df4ff785d 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -2566,7 +2566,7 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int -main (void) +main () { static int test_array [1 - 2 * !(($2) >= 0)]; test_array [0] = 0; @@ -2583,7 +2583,7 @@ if ac_fn_cxx_try_compile "$LINENO"; then : /* end confdefs.h. */ $4 int -main (void) +main () { static int test_array [1 - 2 * !(($2) <= $ac_mid)]; test_array [0] = 0; @@ -2610,7 +2610,7 @@ else /* end confdefs.h. */ $4 int -main (void) +main () { static int test_array [1 - 2 * !(($2) < 0)]; test_array [0] = 0; @@ -2627,7 +2627,7 @@ if ac_fn_cxx_try_compile "$LINENO"; then : /* end confdefs.h. */ $4 int -main (void) +main () { static int test_array [1 - 2 * !(($2) >= $ac_mid)]; test_array [0] = 0; @@ -2662,7 +2662,7 @@ while test "x$ac_lo" != "x$ac_hi"; do /* end confdefs.h. */ $4 int -main (void) +main () { static int test_array [1 - 2 * !(($2) <= $ac_mid)]; test_array [0] = 0; @@ -2687,12 +2687,12 @@ esac cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 -static long int longval (void) { return $2; } -static unsigned long int ulongval (void) { return $2; } +static long int longval () { return $2; } +static unsigned long int ulongval () { return $2; } #include #include int -main (void) +main () { FILE *f = fopen ("conftest.val", "w"); @@ -2799,7 +2799,7 @@ else #define $2 innocuous_$2 /* System header to define __stub macros and hopefully few prototypes, - which can conflict with char $2 (void); below. + which can conflict with char $2 (); below. Prefer to if __STDC__ is defined, since exists even on freestanding compilers. */ @@ -2817,7 +2817,7 @@ else #ifdef __cplusplus extern "C" #endif -char $2 (void); +char $2 (); /* The GNU C library defines this for functions which it implements to always fail with ENOSYS. Some functions are actually named something starting with __ and the normal name is an alias. */ @@ -2826,7 +2826,7 @@ choke me #endif int -main (void) +main () { return $2 (); ; @@ -4432,7 +4432,7 @@ VS_TOOLSET_SUPPORTED_2022=true #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1716396030 +DATE_WHEN_GENERATED=1725282959 ############################################################################### # @@ -13928,6 +13928,12 @@ test -n "$target_alias" && VAR_CPU_BITS=64 VAR_CPU_ENDIAN=little ;; + riscv64) + VAR_CPU=riscv64 + VAR_CPU_ARCH=riscv + VAR_CPU_BITS=64 + VAR_CPU_ENDIAN=little + ;; *) as_fn_error $? "unsupported cpu $build_cpu" "$LINENO" 5 ;; @@ -14072,6 +14078,12 @@ $as_echo "$OPENJDK_BUILD_OS-$OPENJDK_BUILD_CPU" >&6; } VAR_CPU_BITS=64 VAR_CPU_ENDIAN=little ;; + riscv64) + VAR_CPU=riscv64 + VAR_CPU_ARCH=riscv + VAR_CPU_BITS=64 + VAR_CPU_ENDIAN=little + ;; *) as_fn_error $? "unsupported cpu $host_cpu" "$LINENO" 5 ;; @@ -28926,7 +28938,7 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int -main (void) +main () { ; @@ -29066,7 +29078,7 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int -main (void) +main () { FILE *f = fopen ("conftest.out", "w"); return ferror (f) || fclose (f) != 0; @@ -29130,7 +29142,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -29181,7 +29193,7 @@ else /* end confdefs.h. */ int -main (void) +main () { #ifndef __GNUC__ choke me @@ -29222,7 +29234,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -29237,7 +29249,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -29253,7 +29265,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -29302,7 +29314,9 @@ struct stat; /* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ struct buf { int x; }; FILE * (*rcsopen) (struct buf *, struct stat *, int); -static char *e (char **p, int i) +static char *e (p, i) + char **p; + int i; { return p[i]; } @@ -29337,7 +29351,7 @@ int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, i int argc; char **argv; int -main (void) +main () { return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; ; @@ -30670,7 +30684,7 @@ else /* end confdefs.h. */ int -main (void) +main () { #ifndef __GNUC__ choke me @@ -30711,7 +30725,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -30726,7 +30740,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -30742,7 +30756,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -33255,7 +33269,7 @@ else /* end confdefs.h. */ int -main (void) +main () { #ifndef __GNUC__ choke me @@ -33296,7 +33310,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -33311,7 +33325,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -33327,7 +33341,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -41873,7 +41887,7 @@ else #include int -main (void) +main () { ; @@ -41943,7 +41957,7 @@ else #define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) int -main (void) +main () { int i; for (i = 0; i < 256; i++) @@ -42241,7 +42255,7 @@ rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext #include int -main (void) +main () { #if ! (defined BYTE_ORDER && defined BIG_ENDIAN \ && defined LITTLE_ENDIAN && BYTE_ORDER && BIG_ENDIAN \ @@ -42261,7 +42275,7 @@ if ac_fn_cxx_try_compile "$LINENO"; then : #include int -main (void) +main () { #if BYTE_ORDER != BIG_ENDIAN not big endian @@ -42287,7 +42301,7 @@ rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext #include int -main (void) +main () { #if ! (defined _LITTLE_ENDIAN || defined _BIG_ENDIAN) bogus endian macros @@ -42304,7 +42318,7 @@ if ac_fn_cxx_try_compile "$LINENO"; then : #include int -main (void) +main () { #ifndef _BIG_ENDIAN not big endian @@ -42346,7 +42360,7 @@ short int ascii_mm[] = extern int foo; int -main (void) +main () { return use_ascii (foo) == use_ebcdic (foo); ; @@ -42372,7 +42386,7 @@ else /* end confdefs.h. */ $ac_includes_default int -main (void) +main () { /* Are we little or big endian? From Harbison&Steele. */ @@ -44215,7 +44229,7 @@ if test "$ac_x_libraries" = no; then /* end confdefs.h. */ #include int -main (void) +main () { XrmInitialize () ; @@ -44301,7 +44315,7 @@ $as_echo_n "checking whether -R must be followed by a space... " >&6; } /* end confdefs.h. */ int -main (void) +main () { ; @@ -44318,7 +44332,7 @@ else /* end confdefs.h. */ int -main (void) +main () { ; @@ -44362,9 +44376,9 @@ rm -f core conftest.err conftest.$ac_objext \ #ifdef __cplusplus extern "C" #endif -char XOpenDisplay (void); +char XOpenDisplay (); int -main (void) +main () { return XOpenDisplay (); ; @@ -44390,9 +44404,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char dnet_ntoa (void); +char dnet_ntoa (); int -main (void) +main () { return dnet_ntoa (); ; @@ -44431,9 +44445,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char dnet_ntoa (void); +char dnet_ntoa (); int -main (void) +main () { return dnet_ntoa (); ; @@ -44491,9 +44505,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char gethostbyname (void); +char gethostbyname (); int -main (void) +main () { return gethostbyname (); ; @@ -44532,9 +44546,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char gethostbyname (void); +char gethostbyname (); int -main (void) +main () { return gethostbyname (); ; @@ -44588,9 +44602,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char connect (void); +char connect (); int -main (void) +main () { return connect (); ; @@ -44637,9 +44651,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char remove (void); +char remove (); int -main (void) +main () { return remove (); ; @@ -44686,9 +44700,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char shmat (void); +char shmat (); int -main (void) +main () { return shmat (); ; @@ -44738,9 +44752,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char IceConnectionNumber (void); +char IceConnectionNumber (); int -main (void) +main () { return IceConnectionNumber (); ; @@ -49704,7 +49718,7 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext int -main (void) +main () { return main (); ; @@ -49794,9 +49808,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char DGifGetCode (void); +char DGifGetCode (); int -main (void) +main () { return DGifGetCode (); ; @@ -49860,9 +49874,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char compress (void); +char compress (); int -main (void) +main () { return compress (); ; @@ -49946,7 +49960,7 @@ $as_echo "system not found" >&6; } /* end confdefs.h. */ #include int -main (void) +main () { return (int)altzone; ; @@ -49987,9 +50001,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char cos (void); +char cos (); int -main (void) +main () { return cos (); ; @@ -50046,9 +50060,9 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext #ifdef __cplusplus extern "C" #endif -char dlopen (void); +char dlopen (); int -main (void) +main () { return dlopen (); ; @@ -50116,7 +50130,7 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu /* end confdefs.h. */ int -main (void) +main () { return 0; ; @@ -50158,7 +50172,7 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu /* end confdefs.h. */ int -main (void) +main () { return 0; ; @@ -55949,7 +55963,7 @@ $as_echo_n "checking if C-compiler supports ccache precompiled headers... " >&6; /* end confdefs.h. */ int -main (void) +main () { ; diff --git a/common/autoconf/platform.m4 b/common/autoconf/platform.m4 index f54942acf20..99c78202244 100644 --- a/common/autoconf/platform.m4 +++ b/common/autoconf/platform.m4 @@ -102,6 +102,12 @@ AC_DEFUN([PLATFORM_EXTRACT_VARS_FROM_CPU], VAR_CPU_BITS=64 VAR_CPU_ENDIAN=little ;; + riscv64) + VAR_CPU=riscv64 + VAR_CPU_ARCH=riscv + VAR_CPU_BITS=64 + VAR_CPU_ENDIAN=little + ;; *) AC_MSG_ERROR([unsupported cpu $1]) ;; diff --git a/hotspot/src/os/linux/vm/os_linux.cpp b/hotspot/src/os/linux/vm/os_linux.cpp index 5629a640f63..a8b58c41a71 100644 --- a/hotspot/src/os/linux/vm/os_linux.cpp +++ b/hotspot/src/os/linux/vm/os_linux.cpp @@ -1949,6 +1949,9 @@ void * os::dll_load(const char *filename, char *ebuf, int ebuflen) #ifndef EM_AARCH64 #define EM_AARCH64 183 /* ARM AARCH64 */ #endif + #ifndef EM_RISCV + #define EM_RISCV 243 /* RISC-V */ + #endif #ifndef EM_LOONGARCH #define EM_LOONGARCH 258 /* LoongArch */ #endif @@ -1976,6 +1979,7 @@ void * os::dll_load(const char *filename, char *ebuf, int ebuflen) {EM_68K, EM_68K, ELFCLASS32, ELFDATA2MSB, (char*)"M68k"}, {EM_AARCH64, EM_AARCH64, ELFCLASS64, ELFDATA2LSB, (char*)"AARCH64"}, {EM_LOONGARCH, EM_LOONGARCH, ELFCLASS64, ELFDATA2LSB, (char*)"LoongArch"}, + {EM_RISCV, EM_RISCV, ELFCLASS64, ELFDATA2LSB, (char*)"RISC-V"}, }; #if (defined IA32) @@ -2010,9 +2014,11 @@ void * os::dll_load(const char *filename, char *ebuf, int ebuflen) static Elf32_Half running_arch_code=EM_AARCH64; #elif (defined LOONGARCH64) static Elf32_Half running_arch_code=EM_LOONGARCH; + #elif (defined RISCV) + static Elf32_Half running_arch_code=EM_RISCV; #else #error Method os::dll_load requires that one of following is defined:\ - IA32, AMD64, IA64, __sparc, __powerpc__, ARM, S390, ALPHA, MIPS, MIPSEL, PARISC, M68K, AARCH64, LOONGARCH64 + IA32, AMD64, IA64, __sparc, __powerpc__, ARM, S390, ALPHA, MIPS, MIPSEL, PARISC, M68K, AARCH64, LOONGARCH64, RISCV #endif // Identify compatability class for VM's architecture and library's architecture From 3cd5a0c1c15e732f5650da1caf369d4eab4146c2 Mon Sep 17 00:00:00 2001 From: Dingli Zhang Date: Tue, 3 Sep 2024 11:31:00 +0000 Subject: [PATCH 2/2] Put EM_RISCV after definition of EM_LOONGARCH --- hotspot/src/os/linux/vm/os_linux.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/hotspot/src/os/linux/vm/os_linux.cpp b/hotspot/src/os/linux/vm/os_linux.cpp index a8b58c41a71..4d5dc7097b3 100644 --- a/hotspot/src/os/linux/vm/os_linux.cpp +++ b/hotspot/src/os/linux/vm/os_linux.cpp @@ -1949,12 +1949,12 @@ void * os::dll_load(const char *filename, char *ebuf, int ebuflen) #ifndef EM_AARCH64 #define EM_AARCH64 183 /* ARM AARCH64 */ #endif - #ifndef EM_RISCV - #define EM_RISCV 243 /* RISC-V */ - #endif #ifndef EM_LOONGARCH #define EM_LOONGARCH 258 /* LoongArch */ #endif + #ifndef EM_RISCV + #define EM_RISCV 243 /* RISC-V */ + #endif static const arch_t arch_array[]={ {EM_386, EM_386, ELFCLASS32, ELFDATA2LSB, (char*)"IA 32"},