head	1.2;
access;
symbols
	perseant-exfatfs-base-20250801:1.2
	perseant-exfatfs-base-20240630:1.2
	perseant-exfatfs:1.2.0.8
	perseant-exfatfs-base:1.2
	netbsd-8-3-RELEASE:1.1.1.1
	cjep_sun2x:1.2.0.6
	cjep_sun2x-base:1.2
	cjep_staticlib_x-base1:1.2
	cjep_staticlib_x:1.2.0.4
	cjep_staticlib_x-base:1.2
	phil-wifi-20200421:1.2
	phil-wifi-20200411:1.2
	phil-wifi-20200406:1.2
	netbsd-8-2-RELEASE:1.1.1.1
	netbsd-8-1-RELEASE:1.1.1.1
	netbsd-8-1-RC1:1.1.1.1
	pgoyette-compat-merge-20190127:1.2
	pgoyette-compat-20190127:1.2
	pgoyette-compat-20190118:1.2
	pgoyette-compat-1226:1.2
	pgoyette-compat-1126:1.2
	pgoyette-compat-1020:1.2
	pgoyette-compat-0930:1.2
	pgoyette-compat-0906:1.2
	netbsd-7-2-RELEASE:1.1.1.1
	pgoyette-compat-0728:1.2
	netbsd-8-0-RELEASE:1.1.1.1
	pgoyette-compat-0625:1.2
	netbsd-8-0-RC2:1.1.1.1
	pgoyette-compat-0521:1.2
	pgoyette-compat-0502:1.2
	pgoyette-compat-0422:1.2
	netbsd-8-0-RC1:1.1.1.1
	pgoyette-compat-0415:1.2
	pgoyette-compat-0407:1.2
	pgoyette-compat-0330:1.2
	pgoyette-compat-0322:1.2
	pgoyette-compat-0315:1.2
	netbsd-7-1-2-RELEASE:1.1.1.1
	pgoyette-compat:1.2.0.2
	pgoyette-compat-base:1.2
	netbsd-7-1-1-RELEASE:1.1.1.1
	matt-nb8-mediatek:1.1.1.1.0.26
	matt-nb8-mediatek-base:1.1.1.1
	perseant-stdc-iso10646:1.1.1.1.0.24
	perseant-stdc-iso10646-base:1.1.1.1
	netbsd-8:1.1.1.1.0.22
	netbsd-8-base:1.1.1.1
	prg-localcount2-base3:1.1.1.1
	prg-localcount2-base2:1.1.1.1
	prg-localcount2-base1:1.1.1.1
	prg-localcount2:1.1.1.1.0.20
	prg-localcount2-base:1.1.1.1
	pgoyette-localcount-20170426:1.1.1.1
	bouyer-socketcan-base1:1.1.1.1
	pgoyette-localcount-20170320:1.1.1.1
	netbsd-7-1:1.1.1.1.0.18
	netbsd-7-1-RELEASE:1.1.1.1
	netbsd-7-1-RC2:1.1.1.1
	netbsd-7-nhusb-base-20170116:1.1.1.1
	bouyer-socketcan:1.1.1.1.0.16
	bouyer-socketcan-base:1.1.1.1
	pgoyette-localcount-20170107:1.1.1.1
	netbsd-7-1-RC1:1.1.1.1
	pgoyette-localcount-20161104:1.1.1.1
	netbsd-7-0-2-RELEASE:1.1.1.1
	localcount-20160914:1.1.1.1
	netbsd-7-nhusb:1.1.1.1.0.14
	netbsd-7-nhusb-base:1.1.1.1
	pgoyette-localcount-20160806:1.1.1.1
	pgoyette-localcount-20160726:1.1.1.1
	pgoyette-localcount:1.1.1.1.0.12
	pgoyette-localcount-base:1.1.1.1
	netbsd-7-0-1-RELEASE:1.1.1.1
	netbsd-7-0:1.1.1.1.0.10
	netbsd-7-0-RELEASE:1.1.1.1
	netbsd-7-0-RC3:1.1.1.1
	netbsd-7-0-RC2:1.1.1.1
	netbsd-7-0-RC1:1.1.1.1
	tls-maxphys-base:1.1.1.1
	tls-maxphys:1.1.1.1.0.8
	netbsd-7:1.1.1.1.0.6
	netbsd-7-base:1.1.1.1
	yamt-pagecache:1.1.1.1.0.4
	yamt-pagecache-base9:1.1.1.1
	tls-earlyentropy:1.1.1.1.0.2
	tls-earlyentropy-base:1.1.1.1
	riastradh-xf86-video-intel-2-7-1-pre-2-21-15:1.1.1.1
	riastradh-drm2-base3:1.1.1.1
	gmp-5-1-3:1.1.1.1
	gmp:1.1.1;
locks; strict;
comment	@;; @;


1.2
date	2017.08.22.09.55.46;	author mrg;	state dead;
branches;
next	1.1;
commitid	DVNRZh45aSIRZb4A;

1.1
date	2013.11.29.07.49.48;	author mrg;	state Exp;
branches
	1.1.1.1;
next	;
commitid	L2Av4PuGmdoL39fx;

1.1.1.1
date	2013.11.29.07.49.48;	author mrg;	state Exp;
branches
	1.1.1.1.4.1
	1.1.1.1.8.1;
next	;
commitid	L2Av4PuGmdoL39fx;

1.1.1.1.4.1
date	2013.11.29.07.49.48;	author yamt;	state dead;
branches;
next	1.1.1.1.4.2;
commitid	nx2BSsHy0NPeAxBx;

1.1.1.1.4.2
date	2014.05.22.14.09.02;	author yamt;	state Exp;
branches;
next	;
commitid	nx2BSsHy0NPeAxBx;

1.1.1.1.8.1
date	2013.11.29.07.49.48;	author tls;	state dead;
branches;
next	1.1.1.1.8.2;
commitid	jTnpym9Qu0o4R1Nx;

1.1.1.1.8.2
date	2014.08.19.23.59.51;	author tls;	state Exp;
branches;
next	;
commitid	jTnpym9Qu0o4R1Nx;


desc
@@


1.2
log
@merge GMP 6.1.2.
@
text
@dnl  PowerPC-64 mpn_addcnd_n/mpn_subcnd_n.

dnl  Copyright 1999, 2000, 2001, 2003, 2004, 2005, 2007, 2011, 2012 Free
dnl  Software Foundation, Inc.

dnl  This file is part of the GNU MP Library.

dnl  The GNU MP Library is free software; you can redistribute it and/or modify
dnl  it under the terms of the GNU Lesser General Public License as published
dnl  by the Free Software Foundation; either version 3 of the License, or (at
dnl  your option) any later version.

dnl  The GNU MP Library is distributed in the hope that it will be useful, but
dnl  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
dnl  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
dnl  License for more details.

dnl  You should have received a copy of the GNU Lesser General Public License
dnl  along with the GNU MP Library.  If not, see http://www.gnu.org/licenses/.

include(`../config.m4')

C                   cycles/limb
C POWER3/PPC630          ?
C POWER4/PPC970          2.25
C POWER5                 ?
C POWER6                 3
C POWER7                 ?

C INPUT PARAMETERS
define(`rp',   `r3')
define(`up',   `r4')
define(`vp',   `r5')
define(`n',    `r6')
define(`cnd',  `r7')

ifdef(`OPERATION_addcnd_n',`
  define(ADDSUBC,	adde)
  define(ADDSUB,	addc)
  define(func,		mpn_addcnd_n)
  define(GENRVAL,	`addi	r3, r3, 1')
  define(SETCBR,	`addic	r0, $1, -1')
  define(CLRCB,		`addic	r0, r0, 0')
')
ifdef(`OPERATION_subcnd_n',`
  define(ADDSUBC,	subfe)
  define(ADDSUB,	subfc)
  define(func,		mpn_subcnd_n)
  define(GENRVAL,	`neg	r3, r3')
  define(SETCBR,	`subfic	r0, $1, 0')
  define(CLRCB,		`addic	r0, r1, -1')
')

MULFUNC_PROLOGUE(mpn_addcnd_n mpn_subcnd_n)

ASM_START()
PROLOGUE(func)
	std	r31, -8(r1)
	std	r30, -16(r1)
	std	r29, -24(r1)
	std	r28, -32(r1)
	std	r27, -40(r1)

	subfic	cnd, cnd, 0
	subfe	cnd, cnd, cnd

	rldicl.	r0, r6, 0,62	C r0 = n & 3, set cr0
	cmpdi	cr6, r0, 2
	addi	r6, r6, 3	C compute count...
	srdi	r6, r6, 2	C ...for ctr
	mtctr	r6		C copy count into ctr
	beq	cr0, L(b00)
	blt	cr6, L(b01)
	beq	cr6, L(b10)

L(b11):	ld	r8, 0(up)	C load s1 limb
	ld	r9, 0(vp)	C load s2 limb
	ld	r10, 8(up)	C load s1 limb
	ld	r11, 8(vp)	C load s2 limb
	ld	r12, 16(up)	C load s1 limb
	addi	up, up, 24
	ld	r0, 16(vp)	C load s2 limb
	addi	vp, vp, 24
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	ADDSUB	r29, r9, r8
	ADDSUBC	r30, r11, r10
	ADDSUBC	r31, r0, r12
	std	r29, 0(rp)
	std	r30, 8(rp)
	std	r31, 16(rp)
	addi	rp, rp, 24
	bdnz	L(go)
	b	L(ret)

L(b01):	ld	r12, 0(up)	C load s1 limb
	addi	up, up, 8
	ld	r0, 0(vp)	C load s2 limb
	addi	vp, vp, 8
	and	r0, r0, cnd
	ADDSUB	r31, r0, r12	C add
	std	r31, 0(rp)
	addi	rp, rp, 8
	bdnz	L(go)
	b	L(ret)

L(b10):	ld	r10, 0(up)	C load s1 limb
	ld	r11, 0(vp)	C load s2 limb
	ld	r12, 8(up)	C load s1 limb
	addi	up, up, 16
	ld	r0, 8(vp)	C load s2 limb
	addi	vp, vp, 16
	and	r11, r11, cnd
	and	r0, r0, cnd
	ADDSUB	r30, r11, r10	C add
	ADDSUBC	r31, r0, r12	C add
	std	r30, 0(rp)
	std	r31, 8(rp)
	addi	rp, rp, 16
	bdnz	L(go)
	b	L(ret)

L(b00):	CLRCB			C clear/set cy
L(go):	ld	r6, 0(up)	C load s1 limb
	ld	r27, 0(vp)	C load s2 limb
	ld	r8, 8(up)	C load s1 limb
	ld	r9, 8(vp)	C load s2 limb
	ld	r10, 16(up)	C load s1 limb
	ld	r11, 16(vp)	C load s2 limb
	ld	r12, 24(up)	C load s1 limb
	ld	r0, 24(vp)	C load s2 limb
	and	r27, r27, cnd
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	bdz	L(end)

	addi	up, up, 32
	addi	vp, vp, 32

L(top):	ADDSUBC	r28, r27, r6
	ld	r6, 0(up)	C load s1 limb
	ld	r27, 0(vp)	C load s2 limb
	ADDSUBC	r29, r9, r8
	ld	r8, 8(up)	C load s1 limb
	ld	r9, 8(vp)	C load s2 limb
	ADDSUBC	r30, r11, r10
	ld	r10, 16(up)	C load s1 limb
	ld	r11, 16(vp)	C load s2 limb
	ADDSUBC	r31, r0, r12
	ld	r12, 24(up)	C load s1 limb
	ld	r0, 24(vp)	C load s2 limb
	std	r28, 0(rp)
	addi	up, up, 32
	std	r29, 8(rp)
	addi	vp, vp, 32
	std	r30, 16(rp)
	std	r31, 24(rp)
	addi	rp, rp, 32
	and	r27, r27, cnd
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	bdnz	L(top)		C decrement ctr and loop back

L(end):	ADDSUBC	r28, r27, r6
	ADDSUBC	r29, r9, r8
	ADDSUBC	r30, r11, r10
	ADDSUBC	r31, r0, r12
	std	r28, 0(rp)
	std	r29, 8(rp)
	std	r30, 16(rp)
	std	r31, 24(rp)

L(ret):	ld	r31, -8(r1)
	ld	r30, -16(r1)
	ld	r29, -24(r1)
	ld	r28, -32(r1)
	ld	r27, -40(r1)

	subfe	r3, r0, r0	C -cy
	GENRVAL
	blr
EPILOGUE()
@


1.1
log
@Initial revision
@
text
@@


1.1.1.1
log
@initial import GMP 5.1.3 sources.  changes include:

fixes for:
- mpn_sbpi1_div_qr_sec and mpn_sbpi1_div_r_sec
- mpz_powm_ui
- AMD family 11h
- mpz_powm_sec and mpn_powm_sec
- ASSERT() fixes
- gcd, gcdext, and invert function fixes
- some PPC division operations
@
text
@@


1.1.1.1.8.1
log
@file aorscnd_n.asm was added on branch tls-maxphys on 2014-08-19 23:59:51 +0000
@
text
@d1 185
@


1.1.1.1.8.2
log
@Rebase to HEAD as of a few days ago.
@
text
@a0 185
dnl  PowerPC-64 mpn_addcnd_n/mpn_subcnd_n.

dnl  Copyright 1999, 2000, 2001, 2003, 2004, 2005, 2007, 2011, 2012 Free
dnl  Software Foundation, Inc.

dnl  This file is part of the GNU MP Library.

dnl  The GNU MP Library is free software; you can redistribute it and/or modify
dnl  it under the terms of the GNU Lesser General Public License as published
dnl  by the Free Software Foundation; either version 3 of the License, or (at
dnl  your option) any later version.

dnl  The GNU MP Library is distributed in the hope that it will be useful, but
dnl  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
dnl  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
dnl  License for more details.

dnl  You should have received a copy of the GNU Lesser General Public License
dnl  along with the GNU MP Library.  If not, see http://www.gnu.org/licenses/.

include(`../config.m4')

C                   cycles/limb
C POWER3/PPC630          ?
C POWER4/PPC970          2.25
C POWER5                 ?
C POWER6                 3
C POWER7                 ?

C INPUT PARAMETERS
define(`rp',   `r3')
define(`up',   `r4')
define(`vp',   `r5')
define(`n',    `r6')
define(`cnd',  `r7')

ifdef(`OPERATION_addcnd_n',`
  define(ADDSUBC,	adde)
  define(ADDSUB,	addc)
  define(func,		mpn_addcnd_n)
  define(GENRVAL,	`addi	r3, r3, 1')
  define(SETCBR,	`addic	r0, $1, -1')
  define(CLRCB,		`addic	r0, r0, 0')
')
ifdef(`OPERATION_subcnd_n',`
  define(ADDSUBC,	subfe)
  define(ADDSUB,	subfc)
  define(func,		mpn_subcnd_n)
  define(GENRVAL,	`neg	r3, r3')
  define(SETCBR,	`subfic	r0, $1, 0')
  define(CLRCB,		`addic	r0, r1, -1')
')

MULFUNC_PROLOGUE(mpn_addcnd_n mpn_subcnd_n)

ASM_START()
PROLOGUE(func)
	std	r31, -8(r1)
	std	r30, -16(r1)
	std	r29, -24(r1)
	std	r28, -32(r1)
	std	r27, -40(r1)

	subfic	cnd, cnd, 0
	subfe	cnd, cnd, cnd

	rldicl.	r0, r6, 0,62	C r0 = n & 3, set cr0
	cmpdi	cr6, r0, 2
	addi	r6, r6, 3	C compute count...
	srdi	r6, r6, 2	C ...for ctr
	mtctr	r6		C copy count into ctr
	beq	cr0, L(b00)
	blt	cr6, L(b01)
	beq	cr6, L(b10)

L(b11):	ld	r8, 0(up)	C load s1 limb
	ld	r9, 0(vp)	C load s2 limb
	ld	r10, 8(up)	C load s1 limb
	ld	r11, 8(vp)	C load s2 limb
	ld	r12, 16(up)	C load s1 limb
	addi	up, up, 24
	ld	r0, 16(vp)	C load s2 limb
	addi	vp, vp, 24
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	ADDSUB	r29, r9, r8
	ADDSUBC	r30, r11, r10
	ADDSUBC	r31, r0, r12
	std	r29, 0(rp)
	std	r30, 8(rp)
	std	r31, 16(rp)
	addi	rp, rp, 24
	bdnz	L(go)
	b	L(ret)

L(b01):	ld	r12, 0(up)	C load s1 limb
	addi	up, up, 8
	ld	r0, 0(vp)	C load s2 limb
	addi	vp, vp, 8
	and	r0, r0, cnd
	ADDSUB	r31, r0, r12	C add
	std	r31, 0(rp)
	addi	rp, rp, 8
	bdnz	L(go)
	b	L(ret)

L(b10):	ld	r10, 0(up)	C load s1 limb
	ld	r11, 0(vp)	C load s2 limb
	ld	r12, 8(up)	C load s1 limb
	addi	up, up, 16
	ld	r0, 8(vp)	C load s2 limb
	addi	vp, vp, 16
	and	r11, r11, cnd
	and	r0, r0, cnd
	ADDSUB	r30, r11, r10	C add
	ADDSUBC	r31, r0, r12	C add
	std	r30, 0(rp)
	std	r31, 8(rp)
	addi	rp, rp, 16
	bdnz	L(go)
	b	L(ret)

L(b00):	CLRCB			C clear/set cy
L(go):	ld	r6, 0(up)	C load s1 limb
	ld	r27, 0(vp)	C load s2 limb
	ld	r8, 8(up)	C load s1 limb
	ld	r9, 8(vp)	C load s2 limb
	ld	r10, 16(up)	C load s1 limb
	ld	r11, 16(vp)	C load s2 limb
	ld	r12, 24(up)	C load s1 limb
	ld	r0, 24(vp)	C load s2 limb
	and	r27, r27, cnd
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	bdz	L(end)

	addi	up, up, 32
	addi	vp, vp, 32

L(top):	ADDSUBC	r28, r27, r6
	ld	r6, 0(up)	C load s1 limb
	ld	r27, 0(vp)	C load s2 limb
	ADDSUBC	r29, r9, r8
	ld	r8, 8(up)	C load s1 limb
	ld	r9, 8(vp)	C load s2 limb
	ADDSUBC	r30, r11, r10
	ld	r10, 16(up)	C load s1 limb
	ld	r11, 16(vp)	C load s2 limb
	ADDSUBC	r31, r0, r12
	ld	r12, 24(up)	C load s1 limb
	ld	r0, 24(vp)	C load s2 limb
	std	r28, 0(rp)
	addi	up, up, 32
	std	r29, 8(rp)
	addi	vp, vp, 32
	std	r30, 16(rp)
	std	r31, 24(rp)
	addi	rp, rp, 32
	and	r27, r27, cnd
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	bdnz	L(top)		C decrement ctr and loop back

L(end):	ADDSUBC	r28, r27, r6
	ADDSUBC	r29, r9, r8
	ADDSUBC	r30, r11, r10
	ADDSUBC	r31, r0, r12
	std	r28, 0(rp)
	std	r29, 8(rp)
	std	r30, 16(rp)
	std	r31, 24(rp)

L(ret):	ld	r31, -8(r1)
	ld	r30, -16(r1)
	ld	r29, -24(r1)
	ld	r28, -32(r1)
	ld	r27, -40(r1)

	subfe	r3, r0, r0	C -cy
	GENRVAL
	blr
EPILOGUE()
@


1.1.1.1.4.1
log
@file aorscnd_n.asm was added on branch yamt-pagecache on 2014-05-22 14:09:02 +0000
@
text
@d1 185
@


1.1.1.1.4.2
log
@sync with head.

for a reference, the tree before this commit was tagged
as yamt-pagecache-tag8.

this commit was splitted into small chunks to avoid
a limitation of cvs.  ("Protocol error: too many arguments")
@
text
@a0 185
dnl  PowerPC-64 mpn_addcnd_n/mpn_subcnd_n.

dnl  Copyright 1999, 2000, 2001, 2003, 2004, 2005, 2007, 2011, 2012 Free
dnl  Software Foundation, Inc.

dnl  This file is part of the GNU MP Library.

dnl  The GNU MP Library is free software; you can redistribute it and/or modify
dnl  it under the terms of the GNU Lesser General Public License as published
dnl  by the Free Software Foundation; either version 3 of the License, or (at
dnl  your option) any later version.

dnl  The GNU MP Library is distributed in the hope that it will be useful, but
dnl  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
dnl  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
dnl  License for more details.

dnl  You should have received a copy of the GNU Lesser General Public License
dnl  along with the GNU MP Library.  If not, see http://www.gnu.org/licenses/.

include(`../config.m4')

C                   cycles/limb
C POWER3/PPC630          ?
C POWER4/PPC970          2.25
C POWER5                 ?
C POWER6                 3
C POWER7                 ?

C INPUT PARAMETERS
define(`rp',   `r3')
define(`up',   `r4')
define(`vp',   `r5')
define(`n',    `r6')
define(`cnd',  `r7')

ifdef(`OPERATION_addcnd_n',`
  define(ADDSUBC,	adde)
  define(ADDSUB,	addc)
  define(func,		mpn_addcnd_n)
  define(GENRVAL,	`addi	r3, r3, 1')
  define(SETCBR,	`addic	r0, $1, -1')
  define(CLRCB,		`addic	r0, r0, 0')
')
ifdef(`OPERATION_subcnd_n',`
  define(ADDSUBC,	subfe)
  define(ADDSUB,	subfc)
  define(func,		mpn_subcnd_n)
  define(GENRVAL,	`neg	r3, r3')
  define(SETCBR,	`subfic	r0, $1, 0')
  define(CLRCB,		`addic	r0, r1, -1')
')

MULFUNC_PROLOGUE(mpn_addcnd_n mpn_subcnd_n)

ASM_START()
PROLOGUE(func)
	std	r31, -8(r1)
	std	r30, -16(r1)
	std	r29, -24(r1)
	std	r28, -32(r1)
	std	r27, -40(r1)

	subfic	cnd, cnd, 0
	subfe	cnd, cnd, cnd

	rldicl.	r0, r6, 0,62	C r0 = n & 3, set cr0
	cmpdi	cr6, r0, 2
	addi	r6, r6, 3	C compute count...
	srdi	r6, r6, 2	C ...for ctr
	mtctr	r6		C copy count into ctr
	beq	cr0, L(b00)
	blt	cr6, L(b01)
	beq	cr6, L(b10)

L(b11):	ld	r8, 0(up)	C load s1 limb
	ld	r9, 0(vp)	C load s2 limb
	ld	r10, 8(up)	C load s1 limb
	ld	r11, 8(vp)	C load s2 limb
	ld	r12, 16(up)	C load s1 limb
	addi	up, up, 24
	ld	r0, 16(vp)	C load s2 limb
	addi	vp, vp, 24
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	ADDSUB	r29, r9, r8
	ADDSUBC	r30, r11, r10
	ADDSUBC	r31, r0, r12
	std	r29, 0(rp)
	std	r30, 8(rp)
	std	r31, 16(rp)
	addi	rp, rp, 24
	bdnz	L(go)
	b	L(ret)

L(b01):	ld	r12, 0(up)	C load s1 limb
	addi	up, up, 8
	ld	r0, 0(vp)	C load s2 limb
	addi	vp, vp, 8
	and	r0, r0, cnd
	ADDSUB	r31, r0, r12	C add
	std	r31, 0(rp)
	addi	rp, rp, 8
	bdnz	L(go)
	b	L(ret)

L(b10):	ld	r10, 0(up)	C load s1 limb
	ld	r11, 0(vp)	C load s2 limb
	ld	r12, 8(up)	C load s1 limb
	addi	up, up, 16
	ld	r0, 8(vp)	C load s2 limb
	addi	vp, vp, 16
	and	r11, r11, cnd
	and	r0, r0, cnd
	ADDSUB	r30, r11, r10	C add
	ADDSUBC	r31, r0, r12	C add
	std	r30, 0(rp)
	std	r31, 8(rp)
	addi	rp, rp, 16
	bdnz	L(go)
	b	L(ret)

L(b00):	CLRCB			C clear/set cy
L(go):	ld	r6, 0(up)	C load s1 limb
	ld	r27, 0(vp)	C load s2 limb
	ld	r8, 8(up)	C load s1 limb
	ld	r9, 8(vp)	C load s2 limb
	ld	r10, 16(up)	C load s1 limb
	ld	r11, 16(vp)	C load s2 limb
	ld	r12, 24(up)	C load s1 limb
	ld	r0, 24(vp)	C load s2 limb
	and	r27, r27, cnd
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	bdz	L(end)

	addi	up, up, 32
	addi	vp, vp, 32

L(top):	ADDSUBC	r28, r27, r6
	ld	r6, 0(up)	C load s1 limb
	ld	r27, 0(vp)	C load s2 limb
	ADDSUBC	r29, r9, r8
	ld	r8, 8(up)	C load s1 limb
	ld	r9, 8(vp)	C load s2 limb
	ADDSUBC	r30, r11, r10
	ld	r10, 16(up)	C load s1 limb
	ld	r11, 16(vp)	C load s2 limb
	ADDSUBC	r31, r0, r12
	ld	r12, 24(up)	C load s1 limb
	ld	r0, 24(vp)	C load s2 limb
	std	r28, 0(rp)
	addi	up, up, 32
	std	r29, 8(rp)
	addi	vp, vp, 32
	std	r30, 16(rp)
	std	r31, 24(rp)
	addi	rp, rp, 32
	and	r27, r27, cnd
	and	r9, r9, cnd
	and	r11, r11, cnd
	and	r0, r0, cnd
	bdnz	L(top)		C decrement ctr and loop back

L(end):	ADDSUBC	r28, r27, r6
	ADDSUBC	r29, r9, r8
	ADDSUBC	r30, r11, r10
	ADDSUBC	r31, r0, r12
	std	r28, 0(rp)
	std	r29, 8(rp)
	std	r30, 16(rp)
	std	r31, 24(rp)

L(ret):	ld	r31, -8(r1)
	ld	r30, -16(r1)
	ld	r29, -24(r1)
	ld	r28, -32(r1)
	ld	r27, -40(r1)

	subfe	r3, r0, r0	C -cy
	GENRVAL
	blr
EPILOGUE()
@


