/hg/icedtea6: Removal of the ARM assembler port, unbreaks Zero a...

xranby at icedtea.classpath.org xranby at icedtea.classpath.org
Mon Jul 11 05:27:49 PDT 2011


changeset aae82c1ccf7d in /hg/icedtea6
details: http://icedtea.classpath.org/hg/icedtea6?cmd=changeset;node=aae82c1ccf7d
author: Xerxes R?nby <xerxes at zafena.se>
date: Mon Jul 11 14:19:14 2011 +0200

	Removal of the ARM assembler port, unbreaks Zero and Shark builds.

	2011-07-11 Xerxes R?nby <xerxes at zafena.se>

	 Removal of the ARM assembler port, unbreaks Zero and Shark
	builds.
	        * Makefile.am: (ICEDTEA_PATCHES): Remove patches/arm.patch
	(clean-ports): Removed. (stamps/ports.stamp): Likewise.
	(hotspot-ports): Likewise.
	        * arm_port/hotspot/src/cpu/zero/vm/asm_helper.cpp: Removed.
	        * arm_port/hotspot/src/cpu/zero/vm/bytecodes_arm.def: Likewise.
	        * arm_port/hotspot/src/cpu/zero/vm/cppInterpreter_arm.S: Likewise.
	        * arm_port/hotspot/src/cpu/zero/vm/thumb2.cpp: Likewise.
	        * arm_port/hotspot/tools/mkbc.c: Likewise.
	        * patches/arm.patch: Likewise.


diffstat:

 ChangeLog                                             |    15 +
 Makefile.am                                           |    29 +-
 arm_port/hotspot/src/cpu/zero/vm/asm_helper.cpp       |   583 -
 arm_port/hotspot/src/cpu/zero/vm/bytecodes_arm.def    |  7695 -----------------
 arm_port/hotspot/src/cpu/zero/vm/cppInterpreter_arm.S |  6336 -------------
 arm_port/hotspot/src/cpu/zero/vm/thumb2.cpp           |  7456 ----------------
 arm_port/hotspot/tools/mkbc.c                         |   607 -
 patches/arm.patch                                     |   218 -
 8 files changed, 18 insertions(+), 22921 deletions(-)

diffs (truncated from 23013 to 500 lines):

diff -r 4ca76ee4a7a1 -r aae82c1ccf7d ChangeLog
--- a/ChangeLog	Mon Jul 11 10:59:47 2011 +0200
+++ b/ChangeLog	Mon Jul 11 14:19:14 2011 +0200
@@ -1,3 +1,18 @@
+2011-07-11  Xerxes RÃ¥nby  <xerxes at zafena.se>
+
+	Removal of the ARM assembler port, unbreaks Zero and Shark builds.
+	* Makefile.am:
+	(ICEDTEA_PATCHES): Remove patches/arm.patch.
+	(clean-ports): Removed.
+	(stamps/ports.stamp): Likewise.
+	(hotspot-ports): Likewise.
+	* arm_port/hotspot/src/cpu/zero/vm/asm_helper.cpp: Removed.
+	* arm_port/hotspot/src/cpu/zero/vm/bytecodes_arm.def: Likewise.
+	* arm_port/hotspot/src/cpu/zero/vm/cppInterpreter_arm.S: Likewise.
+	* arm_port/hotspot/src/cpu/zero/vm/thumb2.cpp: Likewise.
+	* arm_port/hotspot/tools/mkbc.c: Likewise.
+	* patches/arm.patch: Likewise.
+
 2011-07-11  Pavel Tisnovsky  <ptisnovs at redhat.com>
 
 	* Makefile.am: added new patch
diff -r 4ca76ee4a7a1 -r aae82c1ccf7d Makefile.am
--- a/Makefile.am	Mon Jul 11 10:59:47 2011 +0200
+++ b/Makefile.am	Mon Jul 11 14:19:14 2011 +0200
@@ -262,7 +262,6 @@
 	patches/openjdk/6959123-libpng_14.patch \
 	patches/applet_hole.patch \
 	patches/jtreg-httpTest.patch \
-	patches/arm.patch \
 	patches/debug-dir.patch \
 	patches/override-redirect-metacity.patch \
 	patches/openjdk/6967533-pre_epoch.patch \
@@ -603,7 +602,7 @@
 check-local: jtregcheck
 
 clean-local: clean-jtreg clean-jtreg-reports $(PULSE_JAVA_CLEAN_TARGET) \
- clean-icedtea clean-icedtea-debug clean-icedtea-ecj clean-extract clean-ports \
+ clean-icedtea clean-icedtea-debug clean-icedtea-ecj clean-extract \
  clean-overlay clean-native-ecj clean-icedtea-against-icedtea clean-icedtea-debug-against-icedtea \
  clean-icedtea-against-ecj clean-extract-ecj clean-generated clean-replace-hotspot \
  clean-rewriter clean-rewrite-rhino clean-rt clean-bootstrap-directory \
@@ -640,7 +639,7 @@
 	clean-icedtea-against-ecj \
 	clean-jamvm clean-add-jamvm clean-add-jamvm-debug \
 	clean-cacao clean-add-cacao clean-add-cacao-debug \
-	clean-ports clean-overlay clean-extract-ecj clean-extract clean-extract-openjdk \
+	clean-overlay clean-extract-ecj clean-extract clean-extract-openjdk \
 	clean-replace-hotspot clean-generated clean-download clean-hgforest clean-download-openjdk \
 	clean-rewriter clean-rewrite-rhino clean-add-systemtap clean-add-systemtap-debug \
 	clean-add-pulseaudio clean-add-pulseaudio-debug clean-add-nss clean-add-nss-debug \
@@ -996,27 +995,7 @@
 clean-replace-hotspot:
 	rm -f stamps/replace-hotspot.stamp
 
-# Copy ports sources into tree
-stamps/ports.stamp: stamps/replace-hotspot.stamp
-if !WITH_ALT_HSBUILD
-	for target in $(abs_top_srcdir)/arm_port/hotspot/tools \
-		      $(abs_top_srcdir)/arm_port/hotspot/src/*cpu/* ; do \
-	  link=$$(dirname $$target | sed 's/^.*arm_port/openjdk/'); \
-	  cp -rv $$target $$link; \
-	done
-endif
-	mkdir -p stamps
-	touch stamps/ports.stamp
-
-clean-ports:
-	for target in $(abs_top_srcdir)/arm_port/hotspot/tools \
-		      $(abs_top_srcdir)/arm_port/hotspot/src/*cpu/* ; do \
-	  link=$$(dirname $$target | sed 's/^.*arm_port/openjdk/'); \
-	  rm -rf $$link; \
-	done
-	rm -f stamps/ports.stamp
-
-stamps/generated.stamp: stamps/ports.stamp
+stamps/generated.stamp: stamps/replace-hotspot.stamp
 	set -e ; \
 	if [ ! -e $(abs_top_builddir)/generated ]; then \
 	  cp -a $(abs_top_srcdir)/generated $(abs_top_builddir); \
@@ -2266,8 +2245,6 @@
 
 extract-ecj: stamps/extract-ecj.stamp
 
-hotspot-ports: stamps/ports.stamp
-
 icedtea: stamps/icedtea.stamp
 
 icedtea-against-icedtea: stamps/icedtea-against-icedtea.stamp
diff -r 4ca76ee4a7a1 -r aae82c1ccf7d arm_port/hotspot/src/cpu/zero/vm/asm_helper.cpp
--- a/arm_port/hotspot/src/cpu/zero/vm/asm_helper.cpp	Mon Jul 11 10:59:47 2011 +0200
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,583 +0,0 @@
-/*
- * Copyright 2009, 2010 Edward Nevill
- *
- * This code is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License version 2 only, as
- * published by the Free Software Foundation.
- *
- * This code is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
- * version 2 for more details (a copy is included in the LICENSE file that
- * accompanied this code).
- *
- * You should have received a copy of the GNU General Public License version
- * 2 along with this work; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
- */
-
-#define	ARCH_THUMBEE	(1<<16)
-#define ARCH_VFP	(1<<17)
-#define ARCH_CLZ	(1<<18)
-
-#ifndef STATIC_OFFSETS
-
-#include "incls/_bytecodeInterpreter.cpp.incl"
-
-#include <linux/auxvec.h>
-#include <asm/hwcap.h>
-
-#define VECBUFF_SIZE 64
-
-extern "C" unsigned hwcap(void)
-{
-  int fd;
-  unsigned vecs[VECBUFF_SIZE];
-  unsigned *p;
-  int i, n;
-  unsigned rc = 0;
-  unsigned arch = 4;
- 
-  fd = open("/proc/self/auxv", O_RDONLY);
-  if (fd < 0) return 0;
-  do {
-    n = read(fd, vecs, VECBUFF_SIZE * sizeof(unsigned));
-    p = vecs;
-    i = n/8;
-    while (--i >= 0) {
-      unsigned tag = *p++;
-      unsigned value = *p++;
-      if (tag == 0) goto fini;
-      if (tag == AT_HWCAP) {
-	if (value & HWCAP_THUMBEE) rc |= ARCH_THUMBEE;
-	if (value & HWCAP_VFP) rc |= ARCH_VFP;
-      } else if (tag == AT_PLATFORM) {
-	const char *s = (const char *)value;
-	int c;
-
-	if (*s++ == 'v') {
-	  arch = 0;
-	  while ((isdigit)(c = *s++)) arch = arch * 10 + c - '0';
-	}
-      }
-    }
-  } while (n == VECBUFF_SIZE * sizeof(unsigned));
-fini:
-  close(fd);
-//  printf("arch = %d, rc = 0x%08x\n", arch, rc);
-  if (arch >= 5) rc |= ARCH_CLZ;
-  if (arch >= 7) rc |= ARCH_THUMBEE;
-  return rc | (1<<arch);
-}
-
-/* Thease functions allow the ASM interpreter to call CPP virtual functions.
- * Otherwise the ASM interpreter has to grup around in the VTABLE which is
- * not very portable.
- */
-extern "C" bool JavaThread_is_lock_owned(JavaThread *r0, address r1)
-{
-	return r0->is_lock_owned(r1);
-}
-
-extern "C" HeapWord **CollectedHeap_top_addr(CollectedHeap *r0)
-{
-	return r0->top_addr();
-}
-
-extern "C" HeapWord **CollectedHeap_end_addr(CollectedHeap *r0)
-{
-	return r0->end_addr();
-}
-
-extern "C" char *SharedRuntime_generate_class_cast_message(const char *name, const char *klass)
-{
-	return SharedRuntime::generate_class_cast_message(name, klass);
-}
-
-#define HELPER_THROW(thread, name, msg) Exceptions::_throw_msg(thread, __FILE__, __LINE__, name, msg)
-
-class VMStructs {
-public:
-	static inline klassOop klass_at_addr(constantPoolOop constants, u2 index) {
-	  return (klassOop) *constants->obj_at_addr(index);
-	}
-};
-
-extern "C" oop Helper_new(interpreterState istate, unsigned index)
-{
-    JavaThread *thread = istate->thread();
-
-    constantPoolOop constants = istate->method()->constants();
-    oop result = NULL;
-    if (!constants->tag_at(index).is_unresolved_klass()) {
-      // Make sure klass is initialized and doesn't have a finalizer
-      oop entry = VMStructs::klass_at_addr(constants, index);
-      klassOop k_entry = (klassOop) entry;
-      instanceKlass* ik = (instanceKlass*) k_entry->klass_part();
-      if ( ik->is_initialized() && ik->can_be_fastpath_allocated() ) {
-	size_t obj_size = ik->size_helper();
-	// If the TLAB isn't pre-zeroed then we'll have to do it
-	bool need_zero = !ZeroTLAB;
-	if (UseTLAB) {
-	  result = (oop) thread->tlab().allocate(obj_size);
-	}
-	if (result == NULL) {
-	  need_zero = true;
-	  // Try allocate in shared eden
-    retry:
-	  HeapWord* compare_to = *Universe::heap()->top_addr();
-	  HeapWord* new_top = compare_to + obj_size;
-	  if (new_top <= *Universe::heap()->end_addr()) {
-	    if (Atomic::cmpxchg_ptr(new_top, Universe::heap()->top_addr(), compare_to) != compare_to) {
-	      goto retry;
-	    }
-	    result = (oop) compare_to;
-	  }
-	}
-	if (result != NULL) {
-	  // Initialize object (if nonzero size and need) and then the header
-	  if (need_zero ) {
-	    HeapWord* to_zero = (HeapWord*) result + sizeof(oopDesc) / oopSize;
-	    obj_size -= sizeof(oopDesc) / oopSize;
-	    if (obj_size > 0 ) {
-	      memset(to_zero, 0, obj_size * HeapWordSize);
-	    }
-	  }
-	  if (UseBiasedLocking) {
-	    result->set_mark(ik->prototype_header());
-	  } else {
-	    result->set_mark(markOopDesc::prototype());
-	  }
-	  result->set_klass_gap(0);
-	  result->set_klass(k_entry);
-	  return result;
-	}
-      }
-    }
-    // Slow case allocation
-    InterpreterRuntime::_new(thread, istate->method()->constants(), index);
-    result = thread->vm_result();
-    thread->set_vm_result(NULL);
-    return result;
-}
-
-extern "C" int Helper_instanceof(interpreterState istate, unsigned index, oop tos)
-{
-    if (tos == NULL) return 0;
-
-    // Constant pool may have actual klass or unresolved klass. If it is
-    // unresolved we must resolve it
-    if (istate->method()->constants()->tag_at(index).is_unresolved_klass()) {
-      InterpreterRuntime::quicken_io_cc(istate->thread());
-      if (istate->thread()->has_pending_exception()) return 0;
-    }
-    klassOop klassOf = VMStructs::klass_at_addr(istate->method()->constants(), index);
-    klassOop objKlassOop = tos->klass();
-    //
-    // Check for compatibilty. This check must not GC!!
-    // Seems way more expensive now that we must dispatch
-    //
-    return objKlassOop == klassOf || objKlassOop->klass_part()->is_subtype_of(klassOf);
-}
-
-extern "C" oop Helper_checkcast(interpreterState istate, unsigned index, oop tos)
-{
-    if (tos == NULL) return NULL;
-
-    // Constant pool may have actual klass or unresolved klass. If it is
-    // unresolved we must resolve it
-    if (istate->method()->constants()->tag_at(index).is_unresolved_klass()) {
-      oop except_oop;
-      InterpreterRuntime::quicken_io_cc(istate->thread());
-      if (except_oop = istate->thread()->pending_exception()) return except_oop;
-    }
-    klassOop klassOf = VMStructs::klass_at_addr(istate->method()->constants(), index);
-    klassOop objKlassOop = tos->klass(); //ebx
-    //
-    // Check for compatibilty. This check must not GC!!
-    // Seems way more expensive now that we must dispatch
-    //
-    if (objKlassOop != klassOf && !objKlassOop->klass_part()->is_subtype_of(klassOf)) {
-      ResourceMark rm(istate->thread());
-      const char* objName = Klass::cast(objKlassOop)->external_name();
-      const char* klassName = Klass::cast(klassOf)->external_name();
-      char* message = SharedRuntime::generate_class_cast_message(objName, klassName);
-      ThreadInVMfromJava trans(istate->thread());
-      HELPER_THROW(istate->thread(), vmSymbols::java_lang_ClassCastException(), message);
-    }
-    return istate->thread()->pending_exception();
-}
-
-extern "C" oop Helper_aastore(interpreterState istate, oop value, int index, arrayOop arrayref)
-{
-    if (arrayref == NULL) {
-      ThreadInVMfromJava trans(istate->thread());
-      HELPER_THROW(istate->thread(), vmSymbols::java_lang_NullPointerException(), "");
-    } else if ((uint32_t)index >= (uint32_t)arrayref->length()) {
-      char message[jintAsStringSize];
-      sprintf(message, "%d", index);
-      HELPER_THROW(istate->thread(), vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), message);
-    } else {
-      if (value != NULL) {
-	/* Check assignability of value into arrayref */
-	klassOop rhsKlassOop = value->klass(); // EBX (subclass)
-	klassOop elemKlassOop = ((objArrayKlass*) arrayref->klass()->klass_part())->element_klass();
-	//
-	// Check for compatibilty. This check must not GC!!
-	// Seems way more expensive now that we must dispatch
-	//
-	if (rhsKlassOop != elemKlassOop && !rhsKlassOop->klass_part()->is_subtype_of(elemKlassOop)) {
-	  HELPER_THROW(istate->thread(), vmSymbols::java_lang_ArrayStoreException(), "");
-	  goto handle_exception;
-	}
-      }
-      oop* elem_loc = (oop*)(((address) arrayref->base(T_OBJECT)) + index * sizeof(oop));
-      // *(oop*)(((address) arrayref->base(T_OBJECT)) + index * sizeof(oop)) = value;
-      *elem_loc = value;
-      // Mark the card
-      BarrierSet* bs = Universe::heap()->barrier_set();
-      static volatile jbyte* _byte_map_base = (volatile jbyte*)(((CardTableModRefBS*)bs)->byte_map_base);
-      OrderAccess::release_store(&_byte_map_base[(uintptr_t)elem_loc >> CardTableModRefBS::card_shift], 0);
-    }
-handle_exception:
-    return istate->thread()->pending_exception();
-}
-
-extern "C" void Helper_aputfield(oop obj)
-{
-      BarrierSet* bs = Universe::heap()->barrier_set();
-      static volatile jbyte* _byte_map_base = (volatile jbyte*)(((CardTableModRefBS*)bs)->byte_map_base);
-      OrderAccess::release_store(&_byte_map_base[(uintptr_t)obj >> CardTableModRefBS::card_shift], 0);
-}
-
-extern "C" oop Helper_synchronized_enter(JavaThread *thread, BasicObjectLock *mon)
-{
-    BasicLock *lock = mon->lock();
-    markOop displaced = lock->displaced_header();
-
-    if (thread->is_lock_owned((address)displaced->clear_lock_bits()))
-      lock->set_displaced_header(NULL);
-    else
-      InterpreterRuntime::monitorenter(thread, mon);
-    return thread->pending_exception();
-}
-
-extern "C" oop Helper_synchronized_exit(JavaThread *thread, BasicObjectLock *mon)
-{
-    {
-      HandleMark __hm(thread);
-      if (mon->obj() == NULL)
-	InterpreterRuntime::throw_illegal_monitor_state_exception(thread);
-      else
-        InterpreterRuntime::monitorexit(thread, mon);
-    }
-    return thread->pending_exception();
-}
-
-extern "C" oop Helper_SafePoint(JavaThread *thread)
-{
-    {
-      HandleMarkCleaner __hmc(thread);
-    }
-    SafepointSynchronize::block(thread);
-    return thread->pending_exception();
-}
-
-extern "C" void Helper_RaiseArrayBoundException(JavaThread *thread, int index)
-{
-  char message[jintAsStringSize];
-  sprintf(message, "%d", index);
-  {
-       ThreadInVMfromJava trans(thread);
-       Exceptions::_throw_msg(thread, "[Bytecoce Interpreter]", 99,
-			vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), message);
-  }
-}
-
-extern "C" void Helper_Raise(JavaThread *thread, symbolOopDesc *name, char const *msg)
-{
-   ThreadInVMfromJava trans(thread);
-   Exceptions::_throw_msg(thread, "[Bytecoce Interpreter]", 99, name, msg);
-}
-
-extern "C" void Helper_RaiseIllegalMonitorException(JavaThread *thread)
-{
-    HandleMark __hm(thread);
-    thread->clear_pending_exception();
-    InterpreterRuntime::throw_illegal_monitor_state_exception(thread);
-}
-
-extern "C" address Helper_HandleException(interpreterState istate, JavaThread *thread)
-{
-    HandleMarkCleaner __hmc(thread);
-    Handle except_oop(thread, thread->pending_exception());
-    HandleMark __hm(thread);
-    intptr_t continuation_bci;
-    intptr_t *topOfStack;
-    address pc;
-
-    thread->clear_pending_exception();
-    continuation_bci = (intptr_t)InterpreterRuntime::exception_handler_for_exception(thread, except_oop());
-    except_oop = (oop) thread->vm_result();
-    thread->set_vm_result(NULL);
-    if (continuation_bci >= 0) {
-      topOfStack = (intptr_t *)istate->stack();
-      *topOfStack-- = (intptr_t)except_oop();
-      istate->set_stack(topOfStack);
-      pc = istate->method()->code_base() + continuation_bci;
-#if 0
-        tty->print_cr("Exception <%s> (" INTPTR_FORMAT ")", Klass::cast(except_oop->klass())->external_name(), except_oop());
-        tty->print_cr(" thrown in interpreter method <%s>", istate->method()->name_and_sig_as_C_string());
-        tty->print_cr(" at bci %d, continuing at %d for thread " INTPTR_FORMAT,
-                      pc - (intptr_t)istate->method()->code_base(),
-                      continuation_bci, thread);
-#endif
-      return pc;
-    }
-#if 0
-      tty->print_cr("Exception <%s> (" INTPTR_FORMAT ")", Klass::cast(except_oop->klass())->external_name(), except_oop());
-      tty->print_cr(" thrown in interpreter method <%s>", istate->method()->name_and_sig_as_C_string());
-      tty->print_cr(" at bci %d, unwinding for thread " INTPTR_FORMAT,
-                    pc  - (intptr_t) istate->method()->code_base(),
-                    thread);
-#endif
-    thread->set_pending_exception(except_oop(), NULL, 0);
-    return 0;
-}
-
-#endif // STATIC_OFFSETS
-
-#ifdef STATIC_OFFSETS
-
-#include "incls/_precompiled.incl"
-
-class VMStructs {
-public:
-	static void print_vm_offsets(void);
-};
-
-#define outfile	stdout
-
-void print_def(const char *s, int v)
-{
-	fprintf(outfile, "#undef %-40s\n", s);
-	fprintf(outfile, "#define %-40s 0x%02x\n", s, v);
-}
-
-void nl(void)
-{
-	fputc('\n', outfile);
-}
-
-// ZeroFrame is not friends with VMStructs, but it is with ZeroStackPrinter
-class ZeroStackPrinter {
-public:
-  static void print_vm_offsets(void);
-};
-
-void ZeroStackPrinter::print_vm_offsets(void)
-{
-    print_def("INTERPRETER_FRAME", ZeroFrame::INTERPRETER_FRAME);
-}
-
-void VMStructs::print_vm_offsets(void)
-{
-  print_def("ISTATE_THREAD",    offset_of(BytecodeInterpreter, _thread));
-  print_def("ISTATE_BCP",       offset_of(BytecodeInterpreter, _bcp));
-  print_def("ISTATE_LOCALS",    offset_of(BytecodeInterpreter, _locals));
-  print_def("ISTATE_CONSTANTS", offset_of(BytecodeInterpreter, _constants));
-  print_def("ISTATE_METHOD",    offset_of(BytecodeInterpreter, _method));
-  print_def("ISTATE_STACK",     offset_of(BytecodeInterpreter, _stack));
-  print_def("ISTATE_MSG",       offset_of(BytecodeInterpreter, _msg));
-  print_def("ISTATE_OOP_TEMP",	offset_of(BytecodeInterpreter, _oop_temp));
-  print_def("ISTATE_STACK_BASE",offset_of(BytecodeInterpreter, _stack_base));
-  print_def("ISTATE_STACK_LIMIT",offset_of(BytecodeInterpreter, _stack_limit));
-  print_def("ISTATE_MONITOR_BASE",offset_of(BytecodeInterpreter, _monitor_base));
-  print_def("ISTATE_SELF_LINK",	offset_of(BytecodeInterpreter, _self_link));
-  print_def("ISTATE_FRAME_TYPE", sizeof(BytecodeInterpreter) + 0);
-  print_def("ISTATE_NEXT_FRAME", sizeof(BytecodeInterpreter) + 4);
-  print_def("FRAME_SIZE", sizeof(BytecodeInterpreter) + 8);
-  nl();
-  ZeroStackPrinter::print_vm_offsets();
-  nl();
-  print_def("THREAD_PENDING_EXC", offset_of(JavaThread, _pending_exception));
-  print_def("THREAD_SUSPEND_FLAGS", offset_of(JavaThread, _suspend_flags));
-  print_def("THREAD_ACTIVE_HANDLES", offset_of(JavaThread, _active_handles));
-  print_def("THREAD_LAST_HANDLE_MARK", offset_of(JavaThread, _last_handle_mark));
-  print_def("THREAD_TLAB_TOP", offset_of(JavaThread, _tlab) + offset_of(ThreadLocalAllocBuffer, _top));



More information about the distro-pkg-dev mailing list