提交 9491724a 编写于 作者: N never

6986028: assert(_base == Int) failed: Not an Int in CmpINode::sub

Reviewed-by: kvn, twisti
上级 cfb3122a
...@@ -75,8 +75,7 @@ class StringConcat : public ResourceObj { ...@@ -75,8 +75,7 @@ class StringConcat : public ResourceObj {
for (SimpleDUIterator i(endprojs.resproj); i.has_next(); i.next()) { for (SimpleDUIterator i(endprojs.resproj); i.has_next(); i.next()) {
CallStaticJavaNode *use = i.get()->isa_CallStaticJava(); CallStaticJavaNode *use = i.get()->isa_CallStaticJava();
if (use != NULL && use->method() != NULL && if (use != NULL && use->method() != NULL &&
use->method()->holder() == C->env()->String_klass() && use->method()->intrinsic_id() == vmIntrinsics::_String_String &&
use->method()->name() == ciSymbol::object_initializer_name() &&
use->in(TypeFunc::Parms + 1) == endprojs.resproj) { use->in(TypeFunc::Parms + 1) == endprojs.resproj) {
// Found useless new String(sb.toString()) so reuse the newly allocated String // Found useless new String(sb.toString()) so reuse the newly allocated String
// when creating the result instead of allocating a new one. // when creating the result instead of allocating a new one.
...@@ -394,7 +393,9 @@ StringConcat* PhaseStringOpts::build_candidate(CallStaticJavaNode* call) { ...@@ -394,7 +393,9 @@ StringConcat* PhaseStringOpts::build_candidate(CallStaticJavaNode* call) {
Node* constructor = NULL; Node* constructor = NULL;
for (SimpleDUIterator i(result); i.has_next(); i.next()) { for (SimpleDUIterator i(result); i.has_next(); i.next()) {
CallStaticJavaNode *use = i.get()->isa_CallStaticJava(); CallStaticJavaNode *use = i.get()->isa_CallStaticJava();
if (use != NULL && use->method() != NULL && if (use != NULL &&
use->method() != NULL &&
!use->method()->is_static() &&
use->method()->name() == ciSymbol::object_initializer_name() && use->method()->name() == ciSymbol::object_initializer_name() &&
use->method()->holder() == m->holder()) { use->method()->holder() == m->holder()) {
// Matched the constructor. // Matched the constructor.
...@@ -444,7 +445,8 @@ StringConcat* PhaseStringOpts::build_candidate(CallStaticJavaNode* call) { ...@@ -444,7 +445,8 @@ StringConcat* PhaseStringOpts::build_candidate(CallStaticJavaNode* call) {
} }
} else if (cnode->method() == NULL) { } else if (cnode->method() == NULL) {
break; break;
} else if (cnode->method()->holder() == m->holder() && } else if (!cnode->method()->is_static() &&
cnode->method()->holder() == m->holder() &&
cnode->method()->name() == ciSymbol::append_name() && cnode->method()->name() == ciSymbol::append_name() &&
(cnode->method()->signature()->as_symbol() == string_sig || (cnode->method()->signature()->as_symbol() == string_sig ||
cnode->method()->signature()->as_symbol() == char_sig || cnode->method()->signature()->as_symbol() == char_sig ||
...@@ -459,8 +461,7 @@ StringConcat* PhaseStringOpts::build_candidate(CallStaticJavaNode* call) { ...@@ -459,8 +461,7 @@ StringConcat* PhaseStringOpts::build_candidate(CallStaticJavaNode* call) {
if (arg->is_Proj() && arg->in(0)->is_CallStaticJava()) { if (arg->is_Proj() && arg->in(0)->is_CallStaticJava()) {
CallStaticJavaNode* csj = arg->in(0)->as_CallStaticJava(); CallStaticJavaNode* csj = arg->in(0)->as_CallStaticJava();
if (csj->method() != NULL && if (csj->method() != NULL &&
csj->method()->holder() == C->env()->Integer_klass() && csj->method()->intrinsic_id() == vmIntrinsics::_Integer_toString) {
csj->method()->name() == ciSymbol::toString_name()) {
sc->add_control(csj); sc->add_control(csj);
sc->push_int(csj->in(TypeFunc::Parms)); sc->push_int(csj->in(TypeFunc::Parms));
continue; continue;
...@@ -537,9 +538,8 @@ PhaseStringOpts::PhaseStringOpts(PhaseGVN* gvn, Unique_Node_List*): ...@@ -537,9 +538,8 @@ PhaseStringOpts::PhaseStringOpts(PhaseGVN* gvn, Unique_Node_List*):
if (arg->is_Proj() && arg->in(0)->is_CallStaticJava()) { if (arg->is_Proj() && arg->in(0)->is_CallStaticJava()) {
CallStaticJavaNode* csj = arg->in(0)->as_CallStaticJava(); CallStaticJavaNode* csj = arg->in(0)->as_CallStaticJava();
if (csj->method() != NULL && if (csj->method() != NULL &&
(csj->method()->holder() == C->env()->StringBuffer_klass() || (csj->method()->intrinsic_id() == vmIntrinsics::_StringBuilder_toString ||
csj->method()->holder() == C->env()->StringBuilder_klass()) && csj->method()->intrinsic_id() == vmIntrinsics::_StringBuffer_toString)) {
csj->method()->name() == ciSymbol::toString_name()) {
for (int o = 0; o < concats.length(); o++) { for (int o = 0; o < concats.length(); o++) {
if (c == o) continue; if (c == o) continue;
StringConcat* other = concats.at(o); StringConcat* other = concats.at(o);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册