fix GC safety issues in classpath-openjdk.cpp

This commit is contained in:
Joel Dice 2013-02-03 15:19:35 -07:00
parent 80c8940b7f
commit 3db9e73aa1

View File

@ -2376,6 +2376,8 @@ makeJmethod(Thread* t, object vmMethod, int index)
if (addendum) { if (addendum) {
signature = addendumSignature(t, addendum); signature = addendumSignature(t, addendum);
if (signature) { if (signature) {
PROTECT(t, addendum);
signature = t->m->classpath->makeString signature = t->m->classpath->makeString
(t, signature, 0, byteArrayLength(t, signature) - 1); (t, signature, 0, byteArrayLength(t, signature) - 1);
} }
@ -2443,6 +2445,8 @@ makeJconstructor(Thread* t, object vmMethod, int index)
if (addendum) { if (addendum) {
signature = addendumSignature(t, addendum); signature = addendumSignature(t, addendum);
if (signature) { if (signature) {
PROTECT(t, addendum);
signature = t->m->classpath->makeString signature = t->m->classpath->makeString
(t, signature, 0, byteArrayLength(t, signature) - 1); (t, signature, 0, byteArrayLength(t, signature) - 1);
} }
@ -2508,6 +2512,8 @@ makeJfield(Thread* t, object vmField, int index)
if (addendum) { if (addendum) {
signature = addendumSignature(t, addendum); signature = addendumSignature(t, addendum);
if (signature) { if (signature) {
PROTECT(t, addendum);
signature = t->m->classpath->makeString signature = t->m->classpath->makeString
(t, signature, 0, byteArrayLength(t, signature) - 1); (t, signature, 0, byteArrayLength(t, signature) - 1);
} }