Merge
authordholmes
Wed, 08 May 2013 21:06:46 -0400
changeset 17367 64c84d620e5c
parent 17364 cf8b9767e64c (current diff)
parent 17366 05beb289a844 (diff)
child 17368 b7cb1739172e
child 17370 59a0620561fa
Merge
--- a/hotspot/src/share/vm/runtime/arguments.cpp	Wed May 08 14:18:03 2013 -0700
+++ b/hotspot/src/share/vm/runtime/arguments.cpp	Wed May 08 21:06:46 2013 -0400
@@ -2088,6 +2088,26 @@
 #endif
   }
 
+  // Need to limit the extent of the padding to reasonable size.
+  // 8K is well beyond the reasonable HW cache line size, even with the
+  // aggressive prefetching, while still leaving the room for segregating
+  // among the distinct pages.
+  if (ContendedPaddingWidth < 0 || ContendedPaddingWidth > 8192) {
+    jio_fprintf(defaultStream::error_stream(),
+                "ContendedPaddingWidth=" INTX_FORMAT " must be the between %d and %d\n",
+                ContendedPaddingWidth, 0, 8192);
+    status = false;
+  }
+
+  // Need to enforce the padding not to break the existing field alignments.
+  // It is sufficient to check against the largest type size.
+  if ((ContendedPaddingWidth % BytesPerLong) != 0) {
+    jio_fprintf(defaultStream::error_stream(),
+                "ContendedPaddingWidth=" INTX_FORMAT " must be the multiple of %d\n",
+                ContendedPaddingWidth, BytesPerLong);
+    status = false;
+  }
+
   return status;
 }