Merge
authoriveresov
Mon, 04 Apr 2011 18:48:49 -0700
changeset 9106 fc511f136aea
parent 9105 afc81a03564f (current diff)
parent 9104 85edf8ec98b2 (diff)
child 9108 4b84c6a49f71
child 9109 ec7b2f3b386c
Merge
--- a/hotspot/src/share/vm/opto/loopTransform.cpp	Mon Apr 04 16:00:34 2011 -0700
+++ b/hotspot/src/share/vm/opto/loopTransform.cpp	Mon Apr 04 18:48:49 2011 -0700
@@ -2112,9 +2112,12 @@
       if (value != head->phi()) {
         msg = "unhandled shift in address";
       } else {
-        found_index = true;
-        shift = n;
-        assert(type2aelembytes(store->as_Mem()->memory_type(), true) == 1 << shift->in(2)->get_int(), "scale should match");
+        if (type2aelembytes(store->as_Mem()->memory_type(), true) != (1 << n->in(2)->get_int())) {
+          msg = "scale doesn't match";
+        } else {
+          found_index = true;
+          shift = n;
+        }
       }
     } else if (n->Opcode() == Op_ConvI2L && conv == NULL) {
       if (n->in(1) == head->phi()) {