From 7b7d3507db19e2cb9c840c41bb65d6d6ea08ef6e Mon Sep 17 00:00:00 2001 From: Nils Eliasson Date: Mon, 12 Mar 2012 15:28:07 -0700 Subject: [PATCH] 7152957: VM crashes with assert(false) failed: bad AD file Reviewed-by: kvn, never --- hotspot/src/cpu/sparc/vm/sparc.ad | 2 ++ hotspot/src/cpu/x86/vm/x86_32.ad | 8 ++++++++ hotspot/src/cpu/x86/vm/x86_64.ad | 8 ++++++++ hotspot/src/share/vm/opto/library_call.cpp | 4 ++-- 4 files changed, 20 insertions(+), 2 deletions(-) diff --git a/hotspot/src/cpu/sparc/vm/sparc.ad b/hotspot/src/cpu/sparc/vm/sparc.ad index 3063b2d9714..e4f868baf0c 100644 --- a/hotspot/src/cpu/sparc/vm/sparc.ad +++ b/hotspot/src/cpu/sparc/vm/sparc.ad @@ -1832,6 +1832,8 @@ const bool Matcher::match_rule_supported(int opcode) { case Op_CountLeadingZerosL: case Op_CountTrailingZerosI: case Op_CountTrailingZerosL: + case Op_PopCountI: + case Op_PopCountL: if (!UsePopCountInstruction) return false; break; diff --git a/hotspot/src/cpu/x86/vm/x86_32.ad b/hotspot/src/cpu/x86/vm/x86_32.ad index ee98469e80a..1c5248fecbe 100644 --- a/hotspot/src/cpu/x86/vm/x86_32.ad +++ b/hotspot/src/cpu/x86/vm/x86_32.ad @@ -1293,6 +1293,14 @@ const bool Matcher::match_rule_supported(int opcode) { if (!has_match_rule(opcode)) return false; + switch (opcode) { + case Op_PopCountI: + case Op_PopCountL: + if (!UsePopCountInstruction) + return false; + break; + } + return true; // Per default match rules are supported. } diff --git a/hotspot/src/cpu/x86/vm/x86_64.ad b/hotspot/src/cpu/x86/vm/x86_64.ad index cce1c3468d2..b86d288f5c5 100644 --- a/hotspot/src/cpu/x86/vm/x86_64.ad +++ b/hotspot/src/cpu/x86/vm/x86_64.ad @@ -1714,6 +1714,14 @@ const bool Matcher::match_rule_supported(int opcode) { if (!has_match_rule(opcode)) return false; + switch (opcode) { + case Op_PopCountI: + case Op_PopCountL: + if (!UsePopCountInstruction) + return false; + break; + } + return true; // Per default match rules are supported. } diff --git a/hotspot/src/share/vm/opto/library_call.cpp b/hotspot/src/share/vm/opto/library_call.cpp index 90465d5ff8c..1a38fb6131b 100644 --- a/hotspot/src/share/vm/opto/library_call.cpp +++ b/hotspot/src/share/vm/opto/library_call.cpp @@ -338,11 +338,11 @@ CallGenerator* Compile::make_vm_intrinsic(ciMethod* m, bool is_virtual) { break; case vmIntrinsics::_bitCount_i: - if (!Matcher::has_match_rule(Op_PopCountI)) return NULL; + if (!Matcher::match_rule_supported(Op_PopCountI)) return NULL; break; case vmIntrinsics::_bitCount_l: - if (!Matcher::has_match_rule(Op_PopCountL)) return NULL; + if (!Matcher::match_rule_supported(Op_PopCountL)) return NULL; break; case vmIntrinsics::_numberOfLeadingZeros_i: