Revision: 4208
Author: [email protected]
Date: Mon Mar 22 07:31:28 2010
Log: Use bit fields to calculate compare stub minor key
Review URL: http://codereview.chromium.org/1081010
http://code.google.com/p/v8/source/detail?r=4208

Modified:
 /branches/bleeding_edge/src/arm/codegen-arm.cc
 /branches/bleeding_edge/src/codegen.h
 /branches/bleeding_edge/src/ia32/codegen-ia32.cc
 /branches/bleeding_edge/src/x64/codegen-x64.cc

=======================================
--- /branches/bleeding_edge/src/arm/codegen-arm.cc      Mon Mar 22 05:16:11 2010
+++ /branches/bleeding_edge/src/arm/codegen-arm.cc      Mon Mar 22 07:31:28 2010
@@ -7159,11 +7159,13 @@


 int CompareStub::MinorKey() {
-  // Encode the three parameters in a unique 16 bit value.
-  ASSERT((static_cast<unsigned>(cc_) >> 26) < (1 << 16));
-  int nnn_value = (never_nan_nan_ ? 2 : 0);
-  if (cc_ != eq) nnn_value = 0;  // Avoid duplicate stubs.
- return (static_cast<unsigned>(cc_) >> 26) | nnn_value | (strict_ ? 1 : 0); + // Encode the three parameters in a unique 16 bit value. To avoid duplicate
+  // stubs the never NaN NaN condition is only taken into account if the
+  // condition is equals.
+  ASSERT((static_cast<unsigned>(cc_) >> 28) < (1 << 14));
+  return ConditionField::encode(static_cast<unsigned>(cc_) >> 28)
+         | StrictField::encode(strict_)
+         | NeverNanNanField::encode(cc_ == eq ? never_nan_nan_ : false);
 }


=======================================
--- /branches/bleeding_edge/src/codegen.h       Thu Mar 11 01:27:12 2010
+++ /branches/bleeding_edge/src/codegen.h       Mon Mar 22 07:31:28 2010
@@ -361,6 +361,11 @@
   // stubs.
   bool never_nan_nan_;

+  // Encoding of the minor key CCCCCCCCCCCCCCNS.
+  class StrictField: public BitField<bool, 0, 1> {};
+  class NeverNanNanField: public BitField<bool, 1, 1> {};
+  class ConditionField: public BitField<int, 2, 14> {};
+
   Major MajorKey() { return Compare; }

   int MinorKey();
=======================================
--- /branches/bleeding_edge/src/ia32/codegen-ia32.cc Mon Mar 22 04:55:12 2010 +++ /branches/bleeding_edge/src/ia32/codegen-ia32.cc Mon Mar 22 07:31:28 2010
@@ -11534,11 +11534,13 @@


 int CompareStub::MinorKey() {
-  // Encode the three parameters in a unique 16 bit value.
+ // Encode the three parameters in a unique 16 bit value. To avoid duplicate
+  // stubs the never NaN NaN condition is only taken into account if the
+  // condition is equals.
   ASSERT(static_cast<unsigned>(cc_) < (1 << 14));
-  int nnn_value = (never_nan_nan_ ? 2 : 0);
-  if (cc_ != equal) nnn_value = 0;  // Avoid duplicate stubs.
-  return (static_cast<unsigned>(cc_) << 2) | nnn_value | (strict_ ? 1 : 0);
+  return ConditionField::encode(static_cast<unsigned>(cc_))
+         | StrictField::encode(strict_)
+         | NeverNanNanField::encode(cc_ == equal ? never_nan_nan_ : false);
 }


=======================================
--- /branches/bleeding_edge/src/x64/codegen-x64.cc      Fri Mar 19 05:01:17 2010
+++ /branches/bleeding_edge/src/x64/codegen-x64.cc      Mon Mar 22 07:31:28 2010
@@ -9105,11 +9105,13 @@


 int CompareStub::MinorKey() {
-  // Encode the three parameters in a unique 16 bit value.
+ // Encode the three parameters in a unique 16 bit value. To avoid duplicate
+  // stubs the never NaN NaN condition is only taken into account if the
+  // condition is equals.
   ASSERT(static_cast<unsigned>(cc_) < (1 << 14));
-  int nnn_value = (never_nan_nan_ ? 2 : 0);
-  if (cc_ != equal) nnn_value = 0;  // Avoid duplicate stubs.
-  return (static_cast<unsigned>(cc_) << 2) | nnn_value | (strict_ ? 1 : 0);
+  return ConditionField::encode(static_cast<unsigned>(cc_))
+         | StrictField::encode(strict_)
+         | NeverNanNanField::encode(cc_ == equal ? never_nan_nan_ : false);
 }


--
v8-dev mailing list
[email protected]
http://groups.google.com/group/v8-dev

To unsubscribe from this group, send email to v8-dev+unsubscribegooglegroups.com or reply 
to this email with the words "REMOVE ME" as the subject.

Reply via email to