summaryrefslogtreecommitdiffstats
path: root/libjava/gnu
diff options
context:
space:
mode:
authoraph <aph@138bc75d-0d04-0410-961f-82ee72b054a4>2007-01-24 17:13:50 +0000
committeraph <aph@138bc75d-0d04-0410-961f-82ee72b054a4>2007-01-24 17:13:50 +0000
commit3ccf108d8b40a62d19b1c9e4bfa860f49888951e (patch)
tree921c73a3acbebbe5bffac1e41ad9a7332e15199f /libjava/gnu
parent751d3443fb1775f0997a0852acd6f65f9eeb6688 (diff)
downloadppe42-gcc-3ccf108d8b40a62d19b1c9e4bfa860f49888951e.tar.gz
ppe42-gcc-3ccf108d8b40a62d19b1c9e4bfa860f49888951e.zip
2007-01-24 Andrew Haley <aph@redhat.com>
* gnu/classpath/natVMStackWalker.cc: Call InitClass everywhere. (getClassContext) Add a barrier to prevent GetStackWalkerStack() from being sibcalled. 2007-01-24 Andrew Haley <aph@redhat.com> * scripts/makemake.tcl (emit_bc_rule): Set the source filename. * sources.am: Rebuild. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@121119 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/gnu')
-rw-r--r--libjava/gnu/classpath/natVMStackWalker.cc13
1 files changed, 12 insertions, 1 deletions
diff --git a/libjava/gnu/classpath/natVMStackWalker.cc b/libjava/gnu/classpath/natVMStackWalker.cc
index 07ec48c030a..621a95b4cc5 100644
--- a/libjava/gnu/classpath/natVMStackWalker.cc
+++ b/libjava/gnu/classpath/natVMStackWalker.cc
@@ -17,22 +17,29 @@ details. */
#include <gnu/classpath/VMStackWalker.h>
#include <gnu/gcj/RawData.h>
#include <java/lang/ClassLoader.h>
+#include <java/lang/Class.h>
JArray<jclass> *
gnu::classpath::VMStackWalker::getClassContext(void)
{
- return _Jv_StackTrace::GetStackWalkerStack ();
+ _Jv_InitClass (&::gnu::classpath::VMStackWalker::class$);
+ JArray<jclass> *result = _Jv_StackTrace::GetStackWalkerStack ();
+ // Prevent GetStackWalkerStack() from being sibcalled.
+ __asm__ __volatile__ ("" : : "g" (result));
+ return result;
}
jclass
gnu::classpath::VMStackWalker::getCallingClass(void)
{
+ _Jv_InitClass (&::gnu::classpath::VMStackWalker::class$);
return _Jv_StackTrace::GetStackWalkerCallingClass ();
}
jclass
gnu::classpath::VMStackWalker::getCallingClass(::gnu::gcj::RawData *pc)
{
+ _Jv_InitClass (&::gnu::classpath::VMStackWalker::class$);
void *f = _Unwind_FindEnclosingFunction (pc);
// FIXME: it might well be a good idea to cache pc values here in
@@ -57,12 +64,14 @@ gnu::classpath::VMStackWalker::getCallingClass(::gnu::gcj::RawData *pc)
::java::lang::ClassLoader *
gnu::classpath::VMStackWalker::getClassLoader(::java::lang::Class *c)
{
+ _Jv_InitClass (&::gnu::classpath::VMStackWalker::class$);
return c->getClassLoaderInternal ();
}
::java::lang::ClassLoader *
gnu::classpath::VMStackWalker::getCallingClassLoader(void)
{
+ _Jv_InitClass (&::gnu::classpath::VMStackWalker::class$);
return
_Jv_StackTrace::GetStackWalkerCallingClass ()->getClassLoaderInternal ();
}
@@ -70,11 +79,13 @@ gnu::classpath::VMStackWalker::getCallingClassLoader(void)
::java::lang::ClassLoader *
gnu::classpath::VMStackWalker::getCallingClassLoader(::gnu::gcj::RawData *pc)
{
+ _Jv_InitClass (&::gnu::classpath::VMStackWalker::class$);
return getCallingClass (pc)->getClassLoaderInternal ();
}
::java::lang::ClassLoader *
gnu::classpath::VMStackWalker::firstNonNullClassLoader(void)
{
+ _Jv_InitClass (&::gnu::classpath::VMStackWalker::class$);
return _Jv_StackTrace::GetStackWalkerFirstNonNullLoader ();
}
OpenPOWER on IntegriCloud