Mercurial > hg > graal-compiler
changeset 5949:2537ebc321d4
Merge
author | never |
---|---|
date | Mon, 12 Mar 2012 19:54:41 -0700 |
parents | ee138854b3a6 (current diff) 61b82be3b1ff (diff) |
children | 0f4014d7731b |
files | |
diffstat | 4 files changed, 20 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- 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;
--- 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. }
--- 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. }
--- 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: