提交 1f95c505 编写于 作者: A acorn

Merge

...@@ -1129,8 +1129,8 @@ void LIR_Assembler::stack2stack(LIR_Opr src, LIR_Opr dest, BasicType type) { ...@@ -1129,8 +1129,8 @@ void LIR_Assembler::stack2stack(LIR_Opr src, LIR_Opr dest, BasicType type) {
#else #else
__ pushl(frame_map()->address_for_slot(src ->double_stack_ix(), 0)); __ pushl(frame_map()->address_for_slot(src ->double_stack_ix(), 0));
// push and pop the part at src + wordSize, adding wordSize for the previous push // push and pop the part at src + wordSize, adding wordSize for the previous push
__ pushl(frame_map()->address_for_slot(src ->double_stack_ix(), wordSize)); __ pushl(frame_map()->address_for_slot(src ->double_stack_ix(), 2 * wordSize));
__ popl (frame_map()->address_for_slot(dest->double_stack_ix(), wordSize)); __ popl (frame_map()->address_for_slot(dest->double_stack_ix(), 2 * wordSize));
__ popl (frame_map()->address_for_slot(dest->double_stack_ix(), 0)); __ popl (frame_map()->address_for_slot(dest->double_stack_ix(), 0));
#endif // _LP64 #endif // _LP64
......
...@@ -157,6 +157,7 @@ Node *AddNode::Ideal(PhaseGVN *phase, bool can_reshape) { ...@@ -157,6 +157,7 @@ Node *AddNode::Ideal(PhaseGVN *phase, bool can_reshape) {
Node *a12 = add1->in(2); Node *a12 = add1->in(2);
const Type *t12 = phase->type( a12 ); const Type *t12 = phase->type( a12 );
if( t12->singleton() && t12 != Type::TOP && (add1 != add1->in(1)) ) { if( t12->singleton() && t12 != Type::TOP && (add1 != add1->in(1)) ) {
assert(add1->in(1) != this, "dead loop in AddNode::Ideal");
add2 = add1->clone(); add2 = add1->clone();
add2->set_req(2, in(2)); add2->set_req(2, in(2));
add2 = phase->transform(add2); add2 = phase->transform(add2);
...@@ -173,6 +174,7 @@ Node *AddNode::Ideal(PhaseGVN *phase, bool can_reshape) { ...@@ -173,6 +174,7 @@ Node *AddNode::Ideal(PhaseGVN *phase, bool can_reshape) {
Node *a22 = add2->in(2); Node *a22 = add2->in(2);
const Type *t22 = phase->type( a22 ); const Type *t22 = phase->type( a22 );
if( t22->singleton() && t22 != Type::TOP && (add2 != add2->in(1)) ) { if( t22->singleton() && t22 != Type::TOP && (add2 != add2->in(1)) ) {
assert(add2->in(1) != this, "dead loop in AddNode::Ideal");
Node *addx = add2->clone(); Node *addx = add2->clone();
addx->set_req(1, in(1)); addx->set_req(1, in(1));
addx->set_req(2, add2->in(1)); addx->set_req(2, add2->in(1));
......
...@@ -932,7 +932,7 @@ void PhaseIdealLoop::split_if_with_blocks_post( Node *n ) { ...@@ -932,7 +932,7 @@ void PhaseIdealLoop::split_if_with_blocks_post( Node *n ) {
// to fold a StoreP and an AddP together (as part of an // to fold a StoreP and an AddP together (as part of an
// address expression) and the AddP and StoreP have // address expression) and the AddP and StoreP have
// different controls. // different controls.
if( !x->is_Load() ) _igvn._worklist.yank(x); if( !x->is_Load() && !x->is_DecodeN() ) _igvn._worklist.yank(x);
} }
_igvn.remove_dead_node(n); _igvn.remove_dead_node(n);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册