diff options
author | Danila Kiver | 2020-05-30 20:18:25 +0300 |
---|---|---|
committer | Danila Kiver | 2020-05-30 20:18:25 +0300 |
commit | 95874bdd30b58ab7a51b3164fd135a2099e26627 (patch) | |
tree | e1cd567987ff077923df3472d316d79c7f4f7d3f | |
download | aur-95874bdd30b58ab7a51b3164fd135a2099e26627.tar.gz |
Initial commit.
-rw-r--r-- | .SRCINFO | 17 | ||||
-rw-r--r-- | .gitignore | 6 | ||||
-rw-r--r-- | PKGBUILD | 79 | ||||
-rw-r--r-- | binutils-compat.patch | 12 |
4 files changed, 114 insertions, 0 deletions
diff --git a/.SRCINFO b/.SRCINFO new file mode 100644 index 000000000000..ac5e1a4baf38 --- /dev/null +++ b/.SRCINFO @@ -0,0 +1,17 @@ +pkgbase = java14-openjdk-hsdis + pkgdesc = Disassembler for HotSpot + pkgver = 14.0.1 + pkgrel = 1 + url = http://openjdk.java.net/ + arch = i686 + arch = x86_64 + license = GPL2 + source = openjdk-jdk-14.0.1+7.tar.gz::http://hg.openjdk.java.net/jdk-updates/jdk14u/archive/jdk-14.0.1+7.tar.gz + source = http://ftp.gnu.org/gnu/binutils/binutils-2.34.tar.bz2 + source = binutils-compat.patch + sha256sums = 301203cbda9c40a5fc496b3299806995ac4833b39c6d2e8470fd85a35461afd4 + sha256sums = 89f010078b6cf69c23c27897d686055ab89b198dddf819efb0a4f2c38a0b36e6 + sha256sums = 3b1bd383cdfef4a6cfd9ed0dafeeee956670ad7fb797323f72e56bb7bc0cebaa + +pkgname = java14-openjdk-hsdis + diff --git a/.gitignore b/.gitignore new file mode 100644 index 000000000000..135c48a4ff2f --- /dev/null +++ b/.gitignore @@ -0,0 +1,6 @@ +/*.tar.bz2 +/*.tar.gz +/*.tar.xz +/binutils-gdb/ +/pkg/ +/src/ diff --git a/PKGBUILD b/PKGBUILD new file mode 100644 index 000000000000..f611836c8d6d --- /dev/null +++ b/PKGBUILD @@ -0,0 +1,79 @@ +# Maintainer: Danila Kiver <danila.kiver@mail.ru> +# Contributor: Tavian Barnes <tavianator@tavianator.com> + +pkgname=java14-openjdk-hsdis +_java_major=14 +_java_minor=0 +_java_patch=1 +_java_build=7 +_binutils_ver=2.34 +pkgver=${_java_major}.${_java_minor}.${_java_patch} +_repo_ver=jdk-${_java_major}.${_java_minor}.${_java_patch}+${_java_build} +pkgrel=1 +pkgdesc="Disassembler for HotSpot" +arch=('i686' 'x86_64') +url='http://openjdk.java.net/' +license=('GPL2') +_url_src=http://hg.openjdk.java.net/jdk-updates/jdk14u +source=(openjdk-${_repo_ver}.tar.gz::${_url_src}/archive/${_repo_ver}.tar.gz + http://ftp.gnu.org/gnu/binutils/binutils-${_binutils_ver}.tar.bz2 + binutils-compat.patch) +sha256sums=('301203cbda9c40a5fc496b3299806995ac4833b39c6d2e8470fd85a35461afd4' + '89f010078b6cf69c23c27897d686055ab89b198dddf819efb0a4f2c38a0b36e6' + '3b1bd383cdfef4a6cfd9ed0dafeeee956670ad7fb797323f72e56bb7bc0cebaa') + +prepare() { + cd "${srcdir}/binutils-${_binutils_ver}" + + # hack! - libiberty configure tests for header files using "$CPP $CPPFLAGS" + sed -i "/ac_cpp=/s/\$CPPFLAGS/\$CPPFLAGS -O2/" libiberty/configure + + cd "${srcdir}/jdk14u-${_repo_ver}/src/utils/hsdis" + mkdir -p build + ln -sf "${srcdir}/binutils-${_binutils_ver}" build/binutils + + # The upstream is currently stuck with binutils 2.31. This patch provides the + # compatibility with least recent binutils versions. Remove it once the upstream + # updates the binutils version in use. + cd "${srcdir}/jdk14u-${_repo_ver}" + patch -N -p 1 -i "${srcdir}/binutils-compat.patch" +} + +build() { + cd "${srcdir}/jdk14u-${_repo_ver}/src/utils/hsdis" + + if [ "$CARCH" = "x86_64" ]; then + mkdir -p build/linux-amd64 + cd build/linux-amd64 + else + mkdir -p build/linux-i586 + cd build/linux-i586 + fi + + ../binutils/configure --prefix=/usr \ + --with-lib-path=/usr/lib:/usr/local/lib \ + --with-bugurl=https://bugs.archlinux.org/ \ + --enable-threads --enable-shared --with-pic \ + --enable-ld=default --enable-gold --enable-plugins \ + --disable-werror --disable-gdb --disable-nls \ + CFLAGS="$CFLAGS -fPIC" + make all-opcodes + + cd ../.. + + if [ "$CARCH" = "x86_64" ]; then + make all LP64=1 + else + make all + fi +} + +package() { + cd "${srcdir}/jdk14u-${_repo_ver}/src/utils/hsdis" + + if [ "$CARCH" = "x86_64" ]; then + install -D -m755 build/linux-amd64/hsdis-amd64.so "${pkgdir}/usr/lib/jvm/java-14-openjdk/lib/hsdis-amd64.so" + else + install -D -m755 build/linux-i586/hsdis-i586.so "${pkgdir}/usr/lib/jvm/java-14-openjdk/lib/hsdis-i586.so" + fi +} diff --git a/binutils-compat.patch b/binutils-compat.patch new file mode 100644 index 000000000000..edb846f2a690 --- /dev/null +++ b/binutils-compat.patch @@ -0,0 +1,12 @@ +diff --unified --color --unified --recursive --text jdk14u-jdk-14.0.1+7/src/utils/hsdis/hsdis.c jdk14u-jdk-14.0.1+7-new/src/utils/hsdis/hsdis.c +--- jdk14u-jdk-14.0.1+7/src/utils/hsdis/hsdis.c 2019-11-28 23:32:27.000000000 +0300 ++++ jdk14u-jdk-14.0.1+7-new/src/utils/hsdis/hsdis.c 2020-05-30 03:14:15.355394159 +0300 +@@ -568,7 +568,7 @@ + dinfo->arch = bfd_get_arch(abfd); + dinfo->mach = bfd_get_mach(abfd); + dinfo->disassembler_options = disassembler_options; +- dinfo->octets_per_byte = bfd_octets_per_byte (abfd); ++ dinfo->octets_per_byte = bfd_octets_per_byte (abfd, NULL); + dinfo->skip_zeroes = sizeof(void*) * 2; + dinfo->skip_zeroes_at_end = sizeof(void*)-1; + dinfo->disassembler_needs_relocs = FALSE; |