Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 15 Mar 2021 14:58:02 +0000 (UTC)
From:      Piotr Kubaj <pkubaj@FreeBSD.org>
To:        ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org
Subject:   svn commit: r568464 - in head/java/openjdk12: . files
Message-ID:  <202103151458.12FEw28f039894@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: pkubaj
Date: Mon Mar 15 14:58:01 2021
New Revision: 568464
URL: https://svnweb.freebsd.org/changeset/ports/568464

Log:
  java/openjdk12: fix build on powerpc64le
  
  This ports r556940 to java/openjdk11.
  
  Approved by:	tier 2 blanket

Added:
  head/java/openjdk12/files/patch-src_hotspot_os__cpu_bsd__ppc_bytes__bsd__ppc.inline.hpp   (contents, props changed)
  head/java/openjdk12/files/patch-src_jdk.hotspot.agent_bsd_native_libsaproc_BsdDebuggerLocal.c   (contents, props changed)
Modified:
  head/java/openjdk12/Makefile
  head/java/openjdk12/files/patch-make_autoconf_flags-cflags.m4

Modified: head/java/openjdk12/Makefile
==============================================================================
--- head/java/openjdk12/Makefile	Mon Mar 15 14:49:45 2021	(r568463)
+++ head/java/openjdk12/Makefile	Mon Mar 15 14:58:01 2021	(r568464)
@@ -12,7 +12,7 @@ COMMENT=	Java Development Kit ${JDK_MAJOR_VERSION}
 
 LICENSE=	GPLv2
 
-ONLY_FOR_ARCHS=	amd64 i386 powerpc64
+ONLY_FOR_ARCHS=	amd64 i386 powerpc64 powerpc64le
 
 BUILD_DEPENDS=	zip:archivers/zip \
 		autoconf>0:devel/autoconf \
@@ -138,11 +138,13 @@ CONFIGURE_ARGS+=	--with-extra-ldflags="-Wl,-rpath=${LO
 MAKE_ENV+=	USE_CLANG=true
 .endif
 
+.if ${ARCH} == aarch64 || ${ARCH:Mpowerpc64*}
+CONFIGURE_ARGS+=	--disable-warnings-as-errors
+.endif
 .if ${ARCH} == aarch64 || ${ARCH} == powerpc64
-CONFIGURE_ARGS+=	--disable-warnings-as-errors \
-			--disable-dtrace
+CONFIGURE_ARGS+=	--disable-dtrace
 .endif
-.if defined(PPC_ABI) && ${PPC_ABI} == ELFv2
+.if defined(PPC_ABI) && ${PPC_ABI} == ELFv2 || ${ARCH} == powerpc64le
 CONFIGURE_ARGS+=	--disable-precompiled-headers
 .endif
 .if ${ARCH} != amd64

Modified: head/java/openjdk12/files/patch-make_autoconf_flags-cflags.m4
==============================================================================
--- head/java/openjdk12/files/patch-make_autoconf_flags-cflags.m4	Mon Mar 15 14:49:45 2021	(r568463)
+++ head/java/openjdk12/files/patch-make_autoconf_flags-cflags.m4	Mon Mar 15 14:58:01 2021	(r568464)
@@ -1,12 +1,16 @@
 --- make/autoconf/flags-cflags.m4.orig	2020-01-08 09:12:31 UTC
 +++ make/autoconf/flags-cflags.m4
-@@ -770,6 +770,10 @@ AC_DEFUN([FLAGS_SETUP_CFLAGS_CPU_DEP],
+@@ -770,6 +770,14 @@ AC_DEFUN([FLAGS_SETUP_CFLAGS_CPU_DEP],
          # for all archs except arm and ppc, prevent gcc to omit frame pointer
          $1_CFLAGS_CPU_JDK="${$1_CFLAGS_CPU_JDK} -fno-omit-frame-pointer"
        fi
 +    elif test "x$OPENJDK_TARGET_OS_ENV" = xbsd.freebsd; then
 +        if test "x$FLAGS_CPU" = xppc64; then
 +            $1_CFLAGS_CPU_JVM="${$1_CFLAGS_CPU_JVM} -DABI_ELFv2 -mcpu=powerpc64 -mtune=power5"
++	 elif test "x$FLAGS_CPU" = xppc64le; then
++	     # Little endian machine uses ELFv2 ABI.
++	     # Use Power8, this is the first CPU to support PPC64 LE with ELFv2 ABI.
++	     $1_CFLAGS_CPU_JVM="${$1_CFLAGS_CPU_JVM} -DABI_ELFv2 -mcpu=power8 -mtune=power8"
 +        fi
      fi
  

Added: head/java/openjdk12/files/patch-src_hotspot_os__cpu_bsd__ppc_bytes__bsd__ppc.inline.hpp
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/java/openjdk12/files/patch-src_hotspot_os__cpu_bsd__ppc_bytes__bsd__ppc.inline.hpp	Mon Mar 15 14:58:01 2021	(r568464)
@@ -0,0 +1,20 @@
+--- src/hotspot/os_cpu/bsd_ppc/bytes_bsd_ppc.inline.hpp.orig	2021-03-15 12:55:40 UTC
++++ src/hotspot/os_cpu/bsd_ppc/bytes_bsd_ppc.inline.hpp
+@@ -27,13 +27,13 @@
+ #define OS_CPU_BSD_PPC_VM_BYTES_BSD_PPC_INLINE_HPP
+ 
+ #if defined(VM_LITTLE_ENDIAN)
+-#include <byteswap.h>
++#include <sys/endian.h>
+ 
+ // Efficient swapping of data bytes from Java byte
+ // ordering to native byte ordering and vice versa.
+-inline u2 Bytes::swap_u2(u2 x) { return bswap_16(x); }
+-inline u4 Bytes::swap_u4(u4 x) { return bswap_32(x); }
+-inline u8 Bytes::swap_u8(u8 x) { return bswap_64(x); }
++inline u2 Bytes::swap_u2(u2 x) { return bswap16(x); }
++inline u4 Bytes::swap_u4(u4 x) { return bswap32(x); }
++inline u8 Bytes::swap_u8(u8 x) { return bswap64(x); }
+ #endif // VM_LITTLE_ENDIAN
+ 
+ #endif // OS_CPU_BSD_PPC_VM_BYTES_BSD_PPC_INLINE_HPP

Added: head/java/openjdk12/files/patch-src_jdk.hotspot.agent_bsd_native_libsaproc_BsdDebuggerLocal.c
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/java/openjdk12/files/patch-src_jdk.hotspot.agent_bsd_native_libsaproc_BsdDebuggerLocal.c	Mon Mar 15 14:58:01 2021	(r568464)
@@ -0,0 +1,20 @@
+--- src/jdk.hotspot.agent/bsd/native/libsaproc/BsdDebuggerLocal.c.orig	2021-03-15 13:24:28 UTC
++++ src/jdk.hotspot.agent/bsd/native/libsaproc/BsdDebuggerLocal.c
+@@ -42,7 +42,7 @@
+ #include "sun_jvm_hotspot_debugger_sparc_SPARCThreadContext.h"
+ #endif
+ 
+-#ifdef ppc64
++#if defined(ppc64) || defined(ppc64le)
+ #include "sun_jvm_hotspot_debugger_ppc64_PPC64ThreadContext.h"
+ #endif
+ 
+@@ -326,7 +326,7 @@ JNIEXPORT jlongArray JNICALL Java_sun_jvm_hotspot_debu
+ #if defined(sparc) || defined(sparcv9)
+ #define NPRGREG sun_jvm_hotspot_debugger_sparc_SPARCThreadContext_NPRGREG
+ #endif
+-#ifdef ppc64
++#if defined(ppc64) || defined(ppc64le)
+ #define NPRGREG sun_jvm_hotspot_debugger_ppc64_PPC64ThreadContext_NPRGREG
+ #endif
+ #ifdef aarch64



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202103151458.12FEw28f039894>