From 716c78f080c3ae123c14be409dc3a82fa8732003 Mon Sep 17 00:00:00 2001 From: Changpeng Fang Date: Tue, 5 May 2009 11:02:10 -0700 Subject: [PATCH] 6833879: Assigning positive zero is ignored when old value is negative zero Don't perform CMOVE identity optimization for floating point types Reviewed-by: kvn, never --- hotspot/src/share/vm/opto/connode.cpp | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/hotspot/src/share/vm/opto/connode.cpp b/hotspot/src/share/vm/opto/connode.cpp index 46f13c652b6..9e82a8e4441 100644 --- a/hotspot/src/share/vm/opto/connode.cpp +++ b/hotspot/src/share/vm/opto/connode.cpp @@ -128,6 +128,10 @@ Node *CMoveNode::is_cmove_id( PhaseTransform *phase, Node *cmp, Node *t, Node *f // Swapped Cmp is OK (phase->eqv(cmp->in(2),f) && phase->eqv(cmp->in(1),t)) ) { + // Give up this identity check for floating points because it may choose incorrect + // value around 0.0 and -0.0 + if ( cmp->Opcode()==Op_CmpF || cmp->Opcode()==Op_CmpD ) + return NULL; // Check for "(t==f)?t:f;" and replace with "f" if( b->_test._test == BoolTest::eq ) return f;