From 8cda32ad5652b9af45466973f1d0c0c8fec2f1de Mon Sep 17 00:00:00 2001 From: Andrew Haley Date: Wed, 24 Jan 2007 17:13:50 +0000 Subject: natVMStackWalker.cc: Call InitClass everywhere. 2007-01-24 Andrew Haley * gnu/classpath/natVMStackWalker.cc: Call InitClass everywhere. (getClassContext) Add a barrier to prevent GetStackWalkerStack() from being sibcalled. 2007-01-24 Andrew Haley * scripts/makemake.tcl (emit_bc_rule): Set the source filename. * sources.am: Rebuild. From-SVN: r121119 --- libjava/gnu/classpath/natVMStackWalker.cc | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'libjava/gnu/classpath') diff --git a/libjava/gnu/classpath/natVMStackWalker.cc b/libjava/gnu/classpath/natVMStackWalker.cc index 07ec48c..621a95b 100644 --- a/libjava/gnu/classpath/natVMStackWalker.cc +++ b/libjava/gnu/classpath/natVMStackWalker.cc @@ -17,22 +17,29 @@ details. */ #include #include #include +#include JArray * gnu::classpath::VMStackWalker::getClassContext(void) { - return _Jv_StackTrace::GetStackWalkerStack (); + _Jv_InitClass (&::gnu::classpath::VMStackWalker::class$); + JArray *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 (); } -- cgit v1.1