RFR(L): 8031321 Support Intel bit manipulation instructions

Igor Veresov igor.veresov at oracle.com
Mon Feb 17 01:55:00 PST 2014


Got it. For some CPUs the documentation says the destination is undefined in that case. So, I’d rather play it safe, really. But thanks pointing this out about AMD’s CPUs.

igor

On Feb 17, 2014, at 1:26 AM, Florian Weimer <fweimer at redhat.com> wrote:

> On 02/14/2014 09:27 PM, Igor Veresov wrote:
>> But you have to return 64 in case when all bits are 0:
>> 
>> instruct countTrailingZerosL_bsf(rRegI dst, rRegL src, rFlagsReg cr) %{
>>   predicate(!UseCountTrailingZerosInstruction);
>>   match(Set dst (CountTrailingZerosL src));
>>   effect(KILL cr);
>> 
>>   format %{ "bsfq    $dst, $src\t# count trailing zeros (long)\n\t"
>>             "jnz     done\n\t"
>>             "movl    $dst, 64\n"
>>       "done:" %}
>>   ins_encode %{
>>     Register Rdst = $dst$$Register;
>>     Label done;
>>     __ bsfq(Rdst, $src$$Register);
>>     __ jccb(Assembler::notZero, done);
>>     __ movl(Rdst, BitsPerLong);
>>     __ bind(done);
>>   %}
>>   ins_pipe(ialu_reg);
>> %}
> 
> I meant something like this:
> 
> instruct countTrailingZerosL_bsf(rRegI dst, rRegL src, rFlagsReg cr) %{
>  predicate(!UseCountTrailingZerosInstruction);
>  match(Set dst (CountTrailingZerosL src));
>  effect(KILL cr);
> 
>  format %{ "movl    $dst, 64\n"
>            "bsfq    $dst, $src\t# count trailing zeros (long)\n\t" %}
>  ins_encode %{
>    Register Rdst = $dst$$Register;
>    __ movl(Rdst, BitsPerLong);
>    __ bsfq(Rdst, $src$$Register);
>  %}
>  ins_pipe(ialu_reg);
> %}
> 
> And you also need some constraint that src and dst isn't the same.  (Not sure how to express that.)
> 
> This is based on the following statement in "AMD64 Architecture
> Programmer's Manual, Volume 3: General-Purpose and System Instructions", as part of the BSF instruction description:
> 
> "If the second operand contains 0, the instruction sets ZF to 1 and does not change the contents of the destination register."
> 
> -- 
> Florian Weimer / Red Hat Product Security Team



More information about the hotspot-compiler-dev mailing list