From 54a5ecb6b046485a8b1f476cf957f6320a42c59c Mon Sep 17 00:00:00 2001
From: gary <gary@138bc75d-0d04-0410-961f-82ee72b054a4>
Date: Wed, 9 Aug 2006 14:59:16 +0000
Subject: [PATCH] 2006-08-09  Gary Benson  <gbenson@redhat.com>

	* stacktrace.cc (accesscontrol_trace_fn): Skip non-Java frames.



git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@116038 138bc75d-0d04-0410-961f-82ee72b054a4
---
 libjava/ChangeLog     | 4 ++++
 libjava/stacktrace.cc | 4 +++-
 2 files changed, 7 insertions(+), 1 deletion(-)

diff --git a/libjava/ChangeLog b/libjava/ChangeLog
index 9be7e4ac6cc3..f8c4f5d6f6ee 100644
--- a/libjava/ChangeLog
+++ b/libjava/ChangeLog
@@ -1,3 +1,7 @@
+2006-08-09  Gary Benson  <gbenson@redhat.com>
+
+	* stacktrace.cc (accesscontrol_trace_fn): Skip non-Java frames.
+
 2006-08-09  Gary Benson  <gbenson@redhat.com>
 
 	* java/lang/System.java (setSecurityManager): Javadoc fix.
diff --git a/libjava/stacktrace.cc b/libjava/stacktrace.cc
index e81294ddf690..bd011d005ceb 100644
--- a/libjava/stacktrace.cc
+++ b/libjava/stacktrace.cc
@@ -542,12 +542,14 @@ _Jv_StackTrace::accesscontrol_trace_fn (_Jv_UnwindState *state)
   _Jv_StackFrame *frame = &state->frames[state->pos];
   FillInFrameInfo (frame);
 
+  if (!(frame->klass && frame->meth))
+    return _URC_NO_REASON;
+
   bool *stopping = (bool *) state->trace_data;
   if (*stopping)
     return _URC_NORMAL_STOP;
   
   if (frame->klass == &::java::security::AccessController::class$
-      && frame->meth
       && strcmp (frame->meth->name->chars(), "doPrivileged") == 0)
     *stopping = true;
 
-- 
GitLab