lb1sf68.S (Laddsf$nf): Fix sign bit handling in path to Lf$finfty.
authorKalamatee <kalamatee@gmail.com>
Wed, 23 May 2018 22:29:01 +0000 (22:29 +0000)
committerJeff Law <law@gcc.gnu.org>
Wed, 23 May 2018 22:29:01 +0000 (16:29 -0600)
2018-05-23  Kalamatee  <kalamatee@gmail.com>

* config/m68k/lb1sf68.S (Laddsf$nf): Fix sign bit handling in
path to Lf$finfty.

From-SVN: r260626

libgcc/ChangeLog
libgcc/config/m68k/lb1sf68.S

index e8886cfda7735096e4d49feadb4041a84f5541b5..1b24190cf303ecd9af9f133ff16635ff78783a0d 100644 (file)
@@ -1,3 +1,8 @@
+2018-05-23  Kalamatee  <kalamatee@gmail.com>
+
+       * config/m68k/lb1sf68.S (Laddsf$nf): Fix sign bit handling in
+       path to Lf$finfty.
+
 2018-05-18  Kito Cheng <kito.cheng@gmail.com>
            Monk Chiang  <sh.chiang04@gmail.com>
            Jim Wilson <jimw@sifive.com>
index 1d9392a4ef7e239a8d3fac10aebe881900a6b7ae..325a7c17d9ba2b40ae2369c06bffa58c0501b3b0 100644 (file)
@@ -3111,6 +3111,8 @@ Laddsf$nf:
        movel   a6@(12),d1      | did some processing already)
        movel   IMM (INFINITY),d4 | useful constant (INFINITY)
        movel   d0,d2           | save sign bits
+       movel   d0,d7           | into d7 as well as we may need the sign
+                               | bit before jumping to LfSinfty
        movel   d1,d3
        bclr    IMM (31),d0     | clear sign bits
        bclr    IMM (31),d1
@@ -3125,7 +3127,6 @@ Laddsf$nf:
 | are adding or subtracting them.
        eorl    d3,d2           | to check sign bits
        bmi     1f
-       movel   d0,d7
        andl    IMM (0x80000000),d7     | get (common) sign bit
        bra     Lf$infty
 1:
@@ -3135,7 +3136,6 @@ Laddsf$nf:
        cmpl    d1,d0           | are both infinite?
        beq     Lf$inop         | if so return NaN
 
-       movel   d0,d7
        andl    IMM (0x80000000),d7 | get a's sign bit '
        cmpl    d4,d0           | test now for infinity
        beq     Lf$infty        | if a is INFINITY return with this sign