diff --git a/libjava/ChangeLog b/libjava/ChangeLog
index b1853f4400600f531aeec31538718e749ad5aa30..e6933f30829d2f539d7b0198e36ce4fee9729ee8 100644
--- a/libjava/ChangeLog
+++ b/libjava/ChangeLog
@@ -1,3 +1,10 @@
+2006-10-10  Keith Seitz  <keiths@redhat.com>
+
+	* include/java-interp.h (_Jv_InterpMethod::get_insn): Declare.
+	(_Jv_InterpMethod::set_insn): Declare.
+	* interpret.cc (_Jv_InterpMethod::get_insn): New method.
+	(_Jv_InterpMethod::get_insn): New method.
+
 2006-10-10  Tom Tromey  <tromey@redhat.com>
 
 	* prims.cc (_Jv_PrependVersionedLibdir): Use
diff --git a/libjava/include/java-interp.h b/libjava/include/java-interp.h
index 133fd19f9fe9b4a2df71123bd71aa7d441011113..276a887be34527b627aeb87b26aba76f5049a851 100644
--- a/libjava/include/java-interp.h
+++ b/libjava/include/java-interp.h
@@ -206,6 +206,13 @@ class _Jv_InterpMethod : public _Jv_MethodBase
   void get_line_table (jlong& start, jlong& end, jintArray& line_numbers,
 		       jlongArray& code_indices);
 
+  // Gets the instruction at the given index
+  pc_t get_insn (jlong index);
+
+  /* Writes the given instruction at the given code index. Returns
+     the insn or NULL if index is invalid. */
+  pc_t set_insn (jlong index, pc_t insn);
+
 #ifdef DIRECT_THREADED
   friend void _Jv_CompileMethod (_Jv_InterpMethod*);
 #endif
diff --git a/libjava/interpret.cc b/libjava/interpret.cc
index 1c4e21e6b76e5a03411722ecde2e89d86ea018df..b5c83871b5fa4c86124d966089f44989fae3b987 100644
--- a/libjava/interpret.cc
+++ b/libjava/interpret.cc
@@ -1384,6 +1384,46 @@ _Jv_InterpMethod::get_line_table (jlong& start, jlong& end,
 #endif // !DIRECT_THREADED
 }
 
+pc_t
+_Jv_InterpMethod::get_insn (jlong index)
+{
+  pc_t code;
+
+#ifdef DIRECT_THREADED
+  if (index >= number_insn_slots || index < 0)
+    return NULL;
+
+  code = prepared;
+#else // !DIRECT_THREADED
+  if (index >= code_length || index < 0)
+    return NULL;
+
+  code = reinterpret_cast<pc_t> (bytecode ());
+#endif // !DIRECT_THREADED
+
+  return &code[index];
+}
+
+pc_t
+_Jv_InterpMethod::set_insn (jlong index, pc_t insn)
+{
+#ifdef DIRECT_THREADED
+  if (index >= number_insn_slots || index < 0)
+    return NULL;
+
+  pc_t code = prepared;
+  code[index].insn = insn->insn;
+#else // !DIRECT_THREADED
+  if (index >= code_length || index < 0)
+    return NULL;
+
+  pc_t code = reinterpret_cast<pc_t> (bytecode ());
+  code[index] = *insn;
+#endif // !DIRECT_THREADED
+
+  return &code[index];
+}
+
 void *
 _Jv_JNIMethod::ncode ()
 {