aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/java/ChangeLog5
-rw-r--r--gcc/java/verify-impl.c10
-rw-r--r--libjava/ChangeLog5
-rw-r--r--libjava/verify.cc5
4 files changed, 19 insertions, 6 deletions
diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog
index 4c96759..bfc0df1 100644
--- a/gcc/java/ChangeLog
+++ b/gcc/java/ChangeLog
@@ -1,3 +1,8 @@
+2005-06-24 Tom Tromey <tromey@redhat.com>
+
+ * verify-impl.c (verify_instructions_0): Correctly handle
+ situation where PC falls off end.
+
2005-06-23 Bryce McKinlay <mckinlay@redhat.com>
PR java/20697
diff --git a/gcc/java/verify-impl.c b/gcc/java/verify-impl.c
index db6078e..f787638 100644
--- a/gcc/java/verify-impl.c
+++ b/gcc/java/verify-impl.c
@@ -2251,10 +2251,12 @@ verify_instructions_0 (void)
else
{
/* We only have to do this checking in the situation where
- control flow falls through from the previous
- instruction. Otherwise merging is done at the time we
- push the branch. */
- if (vfr->states[vfr->PC] != NULL)
+ control flow falls through from the previous instruction.
+ Otherwise merging is done at the time we push the branch.
+ Note that we'll catch the off-the-end problem just
+ below. */
+ if (vfr->PC < vfr->current_method->code_length
+ && vfr->states[vfr->PC] != NULL)
{
/* We've already visited this instruction. So merge
the states together. It is simplest, but not most
diff --git a/libjava/ChangeLog b/libjava/ChangeLog
index af57bb6..bcc1eab 100644
--- a/libjava/ChangeLog
+++ b/libjava/ChangeLog
@@ -1,5 +1,10 @@
2005-06-24 Tom Tromey <tromey@redhat.com>
+ * verify.cc (verify_instructions_0): Correctly handle situation
+ where PC falls off end.
+
+2005-06-24 Tom Tromey <tromey@redhat.com>
+
* interpret.cc (compile): Handle case where table entry is
outside of PC range.
diff --git a/libjava/verify.cc b/libjava/verify.cc
index a47571b..167d74c 100644
--- a/libjava/verify.cc
+++ b/libjava/verify.cc
@@ -2198,8 +2198,9 @@ private:
// We only have to do this checking in the situation where
// control flow falls through from the previous
// instruction. Otherwise merging is done at the time we
- // push the branch.
- if (states[PC] != NULL)
+ // push the branch. Note that we'll catch the
+ // off-the-end problem just below.
+ if (PC < current_method->code_length && states[PC] != NULL)
{
// We've already visited this instruction. So merge
// the states together. It is simplest, but not most