# HG changeset patch # User never # Date 1331607281 25200 # Node ID 2537ebc321d48a750464f61c1c6be2895f6e74e1 # Parent ee138854b3a6a1f5abc78c7d93a2693a4c45f178# Parent 61b82be3b1ffc87df65a9c93b9b184889e070f6a Merge diff -r ee138854b3a6 -r 2537ebc321d4 src/cpu/sparc/vm/sparc.ad --- a/src/cpu/sparc/vm/sparc.ad Mon Mar 12 10:46:47 2012 -0700 +++ b/src/cpu/sparc/vm/sparc.ad Mon Mar 12 19:54:41 2012 -0700 @@ -1832,6 +1832,8 @@ case Op_CountLeadingZerosL: case Op_CountTrailingZerosI: case Op_CountTrailingZerosL: + case Op_PopCountI: + case Op_PopCountL: if (!UsePopCountInstruction) return false; break; diff -r ee138854b3a6 -r 2537ebc321d4 src/cpu/x86/vm/x86_32.ad --- a/src/cpu/x86/vm/x86_32.ad Mon Mar 12 10:46:47 2012 -0700 +++ b/src/cpu/x86/vm/x86_32.ad Mon Mar 12 19:54:41 2012 -0700 @@ -1293,6 +1293,14 @@ 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 -r ee138854b3a6 -r 2537ebc321d4 src/cpu/x86/vm/x86_64.ad --- a/src/cpu/x86/vm/x86_64.ad Mon Mar 12 10:46:47 2012 -0700 +++ b/src/cpu/x86/vm/x86_64.ad Mon Mar 12 19:54:41 2012 -0700 @@ -1714,6 +1714,14 @@ 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 -r ee138854b3a6 -r 2537ebc321d4 src/share/vm/opto/library_call.cpp --- a/src/share/vm/opto/library_call.cpp Mon Mar 12 10:46:47 2012 -0700 +++ b/src/share/vm/opto/library_call.cpp Mon Mar 12 19:54:41 2012 -0700 @@ -338,11 +338,11 @@ 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: