Home | History | Annotate | Download | only in x86_64
      1 %default {"suff":"d","nanval":"pos"}
      2 /*
      3  * Compare two floating-point values.  Puts 0, 1, or -1 into the
      4  * destination register based on the results of the comparison.
      5  *
      6  * int compare(x, y) {
      7  *     if (x == y) {
      8  *         return 0;
      9  *     } else if (x < y) {
     10  *         return -1;
     11  *     } else if (x > y) {
     12  *         return 1;
     13  *     } else {
     14  *         return nanval ? 1 : -1;
     15  *     }
     16  * }
     17  */
     18     /* op vAA, vBB, vCC */
     19     movzbq  3(rPC), %rcx                    # ecx<- CC
     20     movzbq  2(rPC), %rax                    # eax<- BB
     21     movs${suff} VREG_ADDRESS(%rax), %xmm0
     22     xor     %eax, %eax
     23     ucomis${suff} VREG_ADDRESS(%rcx), %xmm0
     24     jp      .L${opcode}_nan_is_${nanval}
     25     je      .L${opcode}_finish
     26     jb      .L${opcode}_less
     27 .L${opcode}_nan_is_pos:
     28     addb    $$1, %al
     29     jmp     .L${opcode}_finish
     30 .L${opcode}_nan_is_neg:
     31 .L${opcode}_less:
     32     movl    $$-1, %eax
     33 .L${opcode}_finish:
     34     SET_VREG %eax, rINSTq
     35     ADVANCE_PC_FETCH_AND_GOTO_NEXT 2
     36