PowerPC: Optimized mpn functions for PowerPC64/POWER7
authorAdhemerval Zanella <azanella@linux.vnet.ibm.com>
Fri, 22 Nov 2013 12:38:45 +0000 (06:38 -0600)
committerAdhemerval Zanella <azanella@linux.vnet.ibm.com>
Fri, 6 Dec 2013 17:52:31 +0000 (11:52 -0600)
This patch add optimized __mpn_add_n/__mpn_sub_n for PowerPC64/POWER7.
They are originally from GMP with adjustments for GLIBC.

ChangeLog
sysdeps/powerpc/powerpc64/power7/add_n.S [new file with mode: 0644]
sysdeps/powerpc/powerpc64/power7/sub_n.S [new file with mode: 0644]

index 38fdcd8..ba25853 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
 2013-12-06  Adhemerval Zanella  <azanella@linux.vnet.ibm.com>
 
+       * sysdeps/powerpc/powerpc64/power7/add_n.S: New file: optimized
+       __mpn_add_n for PowerPC64/POWER7.
+       * sysdeps/powerpc/powerpc64/power7/sub_n.S: New file: optimized
+       __mpn_sub_n for PowerPC64/POWER7.
+
+2013-12-06  Adhemerval Zanella  <azanella@linux.vnet.ibm.com>
+
        * sysdeps/powerpc/powerpc64/addmul_1.S: New file: optimized
        __mpn_addmul_1 for PowerPC64.
        * sysdeps/powerpc/powerpc64/submul_1.S: New file: optimized
diff --git a/sysdeps/powerpc/powerpc64/power7/add_n.S b/sysdeps/powerpc/powerpc64/power7/add_n.S
new file mode 100644 (file)
index 0000000..d90e4fc
--- /dev/null
@@ -0,0 +1,98 @@
+/* PowerPC64 mpn_lshift --  mpn_add_n/mpn_sub_n -- mpn addition and
+   subtraction.
+   Copyright (C) 2003-2013 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+
+/*             cycles/limb
+ * POWER7             2.18
+ */
+
+#ifdef USE_AS_SUB
+# define FUNC      __mpn_sub_n
+# define ADDSUBC   subfe
+#else
+# define FUNC      __mpn_add_n
+# define ADDSUBC   adde
+#endif
+
+#define RP  r3
+#define UP  r4
+#define VP  r5
+#define N   r6
+
+EALIGN(FUNC, 5, 0)
+#ifdef USE_AS_SUB
+       addic   r0, r0, 0
+#else
+       addic   r0, r1, -1
+#endif
+       andi.   r7, N, 1
+       beq     L(bx0)
+
+       ld      r7, 0(UP)
+       ld      r9, r0(VP)
+       ADDSUBC r11, r9, r7
+       std     r11, r0(RP)
+       cmpldi  N, N, 1
+       beq     N, L(end)
+       addi    UP, UP, 8
+       addi    VP, VP, 8
+       addi    RP, RP, 8
+
+L(bx0):        addi    r0, N, 2
+       srdi    r0, r0, 2
+       mtctr   r0
+
+       andi.   r7, N, 2
+       bne     L(mid)
+
+       addi    UP, UP, 16
+       addi    VP, VP, 16
+       addi    RP, RP, 16
+
+       .align  5
+L(top):        ld      r6, -16(UP)
+       ld      r7, -8(UP)
+       ld      r8, -16(VP)
+       ld      r9, -8(VP)
+       ADDSUBC r10, r8, N
+       ADDSUBC r11, r9, r7
+       std     r10, -16(RP)
+       std     r11, -8(RP)
+L(mid):        ld      r6, 0(UP)
+       ld      r7, 8(UP)
+       ld      r8, 0(VP)
+       ld      r9, 8(VP)
+       ADDSUBC r10, r8, N
+       ADDSUBC r11, r9, r7
+       std     r10, 0(RP)
+       std     r11, 8(RP)
+       addi    UP, UP, 32
+       addi    VP, VP, 32
+       addi    RP, RP, 32
+       bdnz    L(top)
+
+L(end):        subfe   r3, r0, r0
+#ifdef USE_AS_SUB
+       neg     r3, r3
+#else
+       addi    r3, r3, 1
+#endif
+       blr
+END(FUNC)
diff --git a/sysdeps/powerpc/powerpc64/power7/sub_n.S b/sysdeps/powerpc/powerpc64/power7/sub_n.S
new file mode 100644 (file)
index 0000000..6afb81c
--- /dev/null
@@ -0,0 +1,23 @@
+/* PowerPC64 mpn_lshift --  mpn_add_n/mpn_sub_n -- mpn addition and
+   subtraction.
+   Copyright (C) 2013 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <sysdep.h>
+
+#define USE_AS_SUB
+#include "add_n.S"