< prev index next >

## src/share/vm/opto/mulnode.cpp

 ``` `````` 69 // Otherwise, sort inputs (commutativity) to help value numbering. 70 (in(1)->_idx > in(2)->_idx) ) { 71 swap_edges(1, 2); 72 const Type *t = t1; 73 t1 = t2; 74 t2 = t; 75 progress = this; // Made progress 76 } 77 } 78 79 // If the right input is a constant, and the left input is a product of a 80 // constant, flatten the expression tree. 81 uint op = Opcode(); 82 if( t2->singleton() && // Right input is a constant? 83 op != Op_MulF && // Float & double cannot reassociate 84 op != Op_MulD ) { 85 if( t2 == Type::TOP ) return NULL; 86 Node *mul1 = in(1); 87 #ifdef ASSERT 88 // Check for dead loop 89 int op1 = mul1->Opcode(); 90 if( phase->eqv( mul1, this ) || phase->eqv( in(2), this ) || 91 ( op1 == mul_opcode() || op1 == add_opcode() ) && 92 ( phase->eqv( mul1->in(1), this ) || phase->eqv( mul1->in(2), this ) || 93 phase->eqv( mul1->in(1), mul1 ) || phase->eqv( mul1->in(2), mul1 ) ) ) 94 assert(false, "dead loop in MulNode::Ideal"); 95 #endif 96 97 if( mul1->Opcode() == mul_opcode() ) { // Left input is a multiply? 98 // Mul of a constant? 99 const Type *t12 = phase->type( mul1->in(2) ); 100 if( t12->singleton() && t12 != Type::TOP) { // Left input is an add of a constant? 101 // Compute new constant; check for overflow 102 const Type *tcon01 = ((MulNode*)mul1)->mul_ring(t2,t12); 103 if( tcon01->singleton() ) { 104 // The Mul of the flattened expression 105 set_req(1, mul1->in(1)); 106 set_req(2, phase->makecon( tcon01 )); 107 t2 = tcon01; 108 progress = this; // Made progress 109 } ``` ``` `````` 69 // Otherwise, sort inputs (commutativity) to help value numbering. 70 (in(1)->_idx > in(2)->_idx) ) { 71 swap_edges(1, 2); 72 const Type *t = t1; 73 t1 = t2; 74 t2 = t; 75 progress = this; // Made progress 76 } 77 } 78 79 // If the right input is a constant, and the left input is a product of a 80 // constant, flatten the expression tree. 81 uint op = Opcode(); 82 if( t2->singleton() && // Right input is a constant? 83 op != Op_MulF && // Float & double cannot reassociate 84 op != Op_MulD ) { 85 if( t2 == Type::TOP ) return NULL; 86 Node *mul1 = in(1); 87 #ifdef ASSERT 88 // Check for dead loop 89 uint op1 = mul1->Opcode(); 90 if( phase->eqv( mul1, this ) || phase->eqv( in(2), this ) || 91 ( op1 == mul_opcode() || op1 == add_opcode() ) && 92 ( phase->eqv( mul1->in(1), this ) || phase->eqv( mul1->in(2), this ) || 93 phase->eqv( mul1->in(1), mul1 ) || phase->eqv( mul1->in(2), mul1 ) ) ) 94 assert(false, "dead loop in MulNode::Ideal"); 95 #endif 96 97 if( mul1->Opcode() == mul_opcode() ) { // Left input is a multiply? 98 // Mul of a constant? 99 const Type *t12 = phase->type( mul1->in(2) ); 100 if( t12->singleton() && t12 != Type::TOP) { // Left input is an add of a constant? 101 // Compute new constant; check for overflow 102 const Type *tcon01 = ((MulNode*)mul1)->mul_ring(t2,t12); 103 if( tcon01->singleton() ) { 104 // The Mul of the flattened expression 105 set_req(1, mul1->in(1)); 106 set_req(2, phase->makecon( tcon01 )); 107 t2 = tcon01; 108 progress = this; // Made progress 109 } ```