aboutsummaryrefslogtreecommitdiff
path: root/java
diff options
context:
space:
mode:
authorGreg Lewis <glewis@FreeBSD.org>2023-02-02 04:49:05 +0000
committerGreg Lewis <glewis@FreeBSD.org>2023-02-02 04:49:05 +0000
commit5d7631b4566ab101b5030fcbc87a55a520f01ae6 (patch)
tree933d82fadb166b1d7fbe578f7e249c9f3ac16e71 /java
parent8d60e0ce5e0d3a439ceee721a29d393e9a5cec57 (diff)
downloadports-5d7631b4566ab101b5030fcbc87a55a520f01ae6.tar.gz
ports-5d7631b4566ab101b5030fcbc87a55a520f01ae6.zip
Diffstat (limited to 'java')
-rw-r--r--java/openjdk18/Makefile5
-rw-r--r--java/openjdk18/files/extra-patch-src_hotspot_share_runtime_arguments.cpp21
-rw-r--r--java/openjdk18/files/patch-src_hotspot_os__cpu_bsd__aarch64_atomic__bsd__aarch64.S31
3 files changed, 26 insertions, 31 deletions
diff --git a/java/openjdk18/Makefile b/java/openjdk18/Makefile
index 1b9120750fae..b06301482dab 100644
--- a/java/openjdk18/Makefile
+++ b/java/openjdk18/Makefile
@@ -171,6 +171,11 @@ CONFIGURE_ARGS+= --disable-dtrace
.if ${ARCH} == powerpc64 && ${OSREL:C/\.[0-9]//} == 12
EXTRA_PATCHES= ${PATCHDIR}/extra-patch-src_hotspot_cpu_ppc_vm__version__ppc.hpp
.endif
+.if ${ARCH} == aarch64
+CONFIGURE_ARGS+= --with-boot-jdk-jvmargs=-XX:-UseCompressedClassPointers
+MAKE_ENV+= JAVA_TOOL_OPTIONS="-XX:-UseCompressedClassPointers"
+EXTRA_PATCHES= ${PATCHDIR}/extra-patch-src_hotspot_share_runtime_arguments.cpp
+.endif
.if empty(ICONV_LIB)
ICONV_CFLAGS= -DLIBICONV_PLUG
diff --git a/java/openjdk18/files/extra-patch-src_hotspot_share_runtime_arguments.cpp b/java/openjdk18/files/extra-patch-src_hotspot_share_runtime_arguments.cpp
new file mode 100644
index 000000000000..80ef25c560f6
--- /dev/null
+++ b/java/openjdk18/files/extra-patch-src_hotspot_share_runtime_arguments.cpp
@@ -0,0 +1,21 @@
+--- src/hotspot/share/runtime/arguments.cpp.orig 2023-01-15 10:13:55.469227000 -0800
++++ src/hotspot/share/runtime/arguments.cpp 2023-01-15 10:20:49.218102000 -0800
+@@ -1557,6 +1557,10 @@
+ // set_use_compressed_oops().
+ void Arguments::set_use_compressed_klass_ptrs() {
+ #ifdef _LP64
++# if defined(__FreeBSD__) && defined(AARCH64)
++ FLAG_SET_DEFAULT(UseCompressedClassPointers, false);
++ FLAG_SET_ERGO(UseCompressedClassPointers, false);
++# else
+ // On some architectures, the use of UseCompressedClassPointers implies the use of
+ // UseCompressedOops. The reason is that the rheap_base register of said platforms
+ // is reused to perform some optimized spilling, in order to use rheap_base as a
+@@ -1582,6 +1586,7 @@
+ }
+ }
+ }
++# endif // __FreeBSD__ && AARCH64
+ #endif // _LP64
+ }
+
diff --git a/java/openjdk18/files/patch-src_hotspot_os__cpu_bsd__aarch64_atomic__bsd__aarch64.S b/java/openjdk18/files/patch-src_hotspot_os__cpu_bsd__aarch64_atomic__bsd__aarch64.S
deleted file mode 100644
index 35c926fd1a0a..000000000000
--- a/java/openjdk18/files/patch-src_hotspot_os__cpu_bsd__aarch64_atomic__bsd__aarch64.S
+++ /dev/null
@@ -1,31 +0,0 @@
---- src/hotspot/os_cpu/bsd_aarch64/atomic_bsd_aarch64.S
-+++ src/hotspot/os_cpu/bsd_aarch64/atomic_bsd_aarch64.S
-@@ -47,6 +47,28 @@ aarch64_atomic_fetch_add_4_default_impl:
- mov w0, w2
- ret
-
-+ .global aarch64_atomic_fetch_add_8_relaxed_default_impl
-+ .align 5
-+aarch64_atomic_fetch_add_8_relaxed_default_impl:
-+ prfm pstl1strm, [x0]
-+0: ldxr x2, [x0]
-+ add x8, x2, x1
-+ stxr w9, x8, [x0]
-+ cbnz w9, 0b
-+ mov x0, x2
-+ ret
-+
-+ .global aarch64_atomic_fetch_add_4_relaxed_default_impl
-+ .align 5
-+aarch64_atomic_fetch_add_4_relaxed_default_impl:
-+ prfm pstl1strm, [x0]
-+0: ldxr w2, [x0]
-+ add w8, w2, w1
-+ stxr w9, w8, [x0]
-+ cbnz w9, 0b
-+ mov w0, w2
-+ ret
-+
- .globl aarch64_atomic_xchg_4_default_impl
- .align 5
- aarch64_atomic_xchg_4_default_impl: