diff options
| author | tromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-01-09 19:58:05 +0000 |
|---|---|---|
| committer | tromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-01-09 19:58:05 +0000 |
| commit | 65bf3316cf384588453604be6b4f0ed3751a8b0f (patch) | |
| tree | 996a5f57d4a68c53473382e45cb22f574cb3e4db /libjava/gnu/classpath/natVMStackWalker.cc | |
| parent | 8fc56618a84446beccd45b80381cdfe0e94050df (diff) | |
| download | ppe42-gcc-65bf3316cf384588453604be6b4f0ed3751a8b0f.tar.gz ppe42-gcc-65bf3316cf384588453604be6b4f0ed3751a8b0f.zip | |
Merged gcj-eclipse branch to trunk.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@120621 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/gnu/classpath/natVMStackWalker.cc')
| -rw-r--r-- | libjava/gnu/classpath/natVMStackWalker.cc | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/libjava/gnu/classpath/natVMStackWalker.cc b/libjava/gnu/classpath/natVMStackWalker.cc new file mode 100644 index 00000000000..07ec48c030a --- /dev/null +++ b/libjava/gnu/classpath/natVMStackWalker.cc @@ -0,0 +1,80 @@ +// natVMStackWalker.cc + +/* Copyright (C) 2006 Free Software Foundation + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +#include <config.h> +#include <platform.h> + +#include <gcj/cni.h> +#include <jvm.h> +#include <java-stack.h> +#include <gnu/classpath/VMStackWalker.h> +#include <gnu/gcj/RawData.h> +#include <java/lang/ClassLoader.h> + +JArray<jclass> * +gnu::classpath::VMStackWalker::getClassContext(void) +{ + return _Jv_StackTrace::GetStackWalkerStack (); +} + +jclass +gnu::classpath::VMStackWalker::getCallingClass(void) +{ + return _Jv_StackTrace::GetStackWalkerCallingClass (); +} + +jclass +gnu::classpath::VMStackWalker::getCallingClass(::gnu::gcj::RawData *pc) +{ + void *f = _Unwind_FindEnclosingFunction (pc); + + // FIXME: it might well be a good idea to cache pc values here in + // order to avoid repeated invocations of + // _Unwind_FindEnclosingFunction, which is quite expensive. On the + // other hand, which not simply write a caching version of + // _Unwind_FindEnclosingFunction itself? That would probably be + // worthwhile. + + _Jv_StackTrace::UpdateNCodeMap (); + jclass klass = (jclass) _Jv_StackTrace::ncodeMap->get ((jobject) f); + + // If the caller is a compiled frame and the caller of the caller + // is an interpreted frame then klass will be null and we need to + // unwind the stack. + if (klass == NULL) + klass = _Jv_StackTrace::GetStackWalkerCallingClass (); + + return klass; +} + +::java::lang::ClassLoader * +gnu::classpath::VMStackWalker::getClassLoader(::java::lang::Class *c) +{ + return c->getClassLoaderInternal (); +} + +::java::lang::ClassLoader * +gnu::classpath::VMStackWalker::getCallingClassLoader(void) +{ + return + _Jv_StackTrace::GetStackWalkerCallingClass ()->getClassLoaderInternal (); +} + +::java::lang::ClassLoader * +gnu::classpath::VMStackWalker::getCallingClassLoader(::gnu::gcj::RawData *pc) +{ + return getCallingClass (pc)->getClassLoaderInternal (); +} + +::java::lang::ClassLoader * +gnu::classpath::VMStackWalker::firstNonNullClassLoader(void) +{ + return _Jv_StackTrace::GetStackWalkerFirstNonNullLoader (); +} |

