aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/mips/mips64
diff options
context:
space:
mode:
authorSteve Ellcey <sellcey@mips.com>2014-12-19 14:39:18 -0800
committerSteve Ellcey <sellcey@mips.com>2014-12-19 14:39:18 -0800
commit8b2800c0fb18f83d1ee8083d0a7ac15e0b011e73 (patch)
tree883f5ead649507e76a7ecfab18bf7fa5f08d4cc6 /sysdeps/mips/mips64
parent04d55561978eb59e36ced8fc1e8d87a72ef70072 (diff)
downloadglibc-8b2800c0fb18f83d1ee8083d0a7ac15e0b011e73.tar
glibc-8b2800c0fb18f83d1ee8083d0a7ac15e0b011e73.tar.gz
glibc-8b2800c0fb18f83d1ee8083d0a7ac15e0b011e73.tar.bz2
glibc-8b2800c0fb18f83d1ee8083d0a7ac15e0b011e73.zip
2014-12-19 Steve Ellcey <sellcey@imgtec.com>
* sysdeps/mips/addmul_1.S (__mpn_addmul_1): Use mulu/muhu instead of multu on MIPSr6. * sysdeps/mips/mul_1.S (__mpn_mul_1): Ditto. * sysdeps/mips/submul_1.S (__mpn_submul_1): Ditto. * sysdeps/mips/mips64/addmul_1.S (__mpn_addmul_1): Ditto. * sysdeps/mips/mips64/mul_1.S (__mpn_mul_1): Ditto. * sysdeps/mips/mips64/submul_1.S (__mpn_submul_1): Ditto.
Diffstat (limited to 'sysdeps/mips/mips64')
-rw-r--r--sysdeps/mips/mips64/addmul_1.S30
-rw-r--r--sysdeps/mips/mips64/mul_1.S30
-rw-r--r--sysdeps/mips/mips64/submul_1.S30
3 files changed, 90 insertions, 0 deletions
diff --git a/sysdeps/mips/mips64/addmul_1.S b/sysdeps/mips/mips64/addmul_1.S
index 57edd4aa76..4f035f9851 100644
--- a/sysdeps/mips/mips64/addmul_1.S
+++ b/sysdeps/mips/mips64/addmul_1.S
@@ -44,7 +44,12 @@ ENTRY (__mpn_addmul_1)
# warm up phase 1
daddiu $5,$5,8
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
daddiu $6,$6,-1
beq $6,$0,L(LC0)
@@ -55,11 +60,21 @@ ENTRY (__mpn_addmul_1)
ld $8,0($5) # load new s1 limb as early as possible
L(Loop): ld $10,0($4)
+#if __mips_isa_rev < 6
mflo $3
mfhi $9
+#else
+ move $3,$11
+ move $9,$12
+#endif
daddiu $5,$5,8
daddu $3,$3,$2 # add old carry limb to low product limb
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
ld $8,0($5) # load new s1 limb as early as possible
daddiu $6,$6,-1 # decrement loop counter
sltu $2,$3,$2 # carry from previous addition -> $2
@@ -73,11 +88,21 @@ L(Loop): ld $10,0($4)
# cool down phase 1
L(LC1): ld $10,0($4)
+#if __mips_isa_rev < 6
mflo $3
mfhi $9
+#else
+ move $3,$11
+ move $9,$12
+#endif
daddu $3,$3,$2
sltu $2,$3,$2
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
daddu $3,$10,$3
sltu $10,$3,$10
daddu $2,$2,$10
@@ -87,8 +112,13 @@ L(LC1): ld $10,0($4)
# cool down phase 0
L(LC0): ld $10,0($4)
+#if __mips_isa_rev < 6
mflo $3
mfhi $9
+#else
+ move $3,$11
+ move $9,$12
+#endif
daddu $3,$3,$2
sltu $2,$3,$2
daddu $3,$10,$3
diff --git a/sysdeps/mips/mips64/mul_1.S b/sysdeps/mips/mips64/mul_1.S
index a8d8078114..0e5b734653 100644
--- a/sysdeps/mips/mips64/mul_1.S
+++ b/sysdeps/mips/mips64/mul_1.S
@@ -45,7 +45,12 @@ ENTRY (__mpn_mul_1)
# warm up phase 1
daddiu $5,$5,8
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
daddiu $6,$6,-1
beq $6,$0,L(LC0)
@@ -55,11 +60,21 @@ ENTRY (__mpn_mul_1)
beq $6,$0,L(LC1)
ld $8,0($5) # load new s1 limb as early as possible
+#if __mips_isa_rev < 6
L(Loop): mflo $10
mfhi $9
+#else
+L(Loop): move $10,$11
+ move $9,$12
+#endif
daddiu $5,$5,8
daddu $10,$10,$2 # add old carry limb to low product limb
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
ld $8,0($5) # load new s1 limb as early as possible
daddiu $6,$6,-1 # decrement loop counter
sltu $2,$10,$2 # carry from previous addition -> $2
@@ -69,18 +84,33 @@ L(Loop): mflo $10
daddu $2,$9,$2 # add high product limb and carry from addition
# cool down phase 1
+#if __mips_isa_rev < 6
L(LC1): mflo $10
mfhi $9
+#else
+L(LC1): move $10,$11
+ move $9,$12
+#endif
daddu $10,$10,$2
sltu $2,$10,$2
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
sd $10,0($4)
daddiu $4,$4,8
daddu $2,$9,$2 # add high product limb and carry from addition
# cool down phase 0
+#if __mips_isa_rev < 6
L(LC0): mflo $10
mfhi $9
+#else
+L(LC0): move $10,$11
+ move $9,$12
+#endif
daddu $10,$10,$2
sltu $2,$10,$2
sd $10,0($4)
diff --git a/sysdeps/mips/mips64/submul_1.S b/sysdeps/mips/mips64/submul_1.S
index bf24123bde..84e9a91d00 100644
--- a/sysdeps/mips/mips64/submul_1.S
+++ b/sysdeps/mips/mips64/submul_1.S
@@ -45,7 +45,12 @@ ENTRY (__mpn_submul_1)
# warm up phase 1
daddiu $5,$5,8
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
daddiu $6,$6,-1
beq $6,$0,L(LC0)
@@ -56,11 +61,21 @@ ENTRY (__mpn_submul_1)
ld $8,0($5) # load new s1 limb as early as possible
L(Loop): ld $10,0($4)
+#if __mips_isa_rev < 6
mflo $3
mfhi $9
+#else
+ move $3,$11
+ move $9,$12
+#endif
daddiu $5,$5,8
daddu $3,$3,$2 # add old carry limb to low product limb
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
ld $8,0($5) # load new s1 limb as early as possible
daddiu $6,$6,-1 # decrement loop counter
sltu $2,$3,$2 # carry from previous addition -> $2
@@ -74,11 +89,21 @@ L(Loop): ld $10,0($4)
# cool down phase 1
L(LC1): ld $10,0($4)
+#if __mips_isa_rev < 6
mflo $3
mfhi $9
+#else
+ move $3,$11
+ move $9,$12
+#endif
daddu $3,$3,$2
sltu $2,$3,$2
+#if __mips_isa_rev < 6
dmultu $8,$7
+#else
+ dmulu $11,$8,$7
+ dmuhu $12,$8,$7
+#endif
dsubu $3,$10,$3
sgtu $10,$3,$10
daddu $2,$2,$10
@@ -88,8 +113,13 @@ L(LC1): ld $10,0($4)
# cool down phase 0
L(LC0): ld $10,0($4)
+#if __mips_isa_rev < 6
mflo $3
mfhi $9
+#else
+ move $3,$11
+ move $9,$12
+#endif
daddu $3,$3,$2
sltu $2,$3,$2
dsubu $3,$10,$3