/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