hjl / source-git / glibc

Forked from source-git/glibc 3 years ago
Clone

Blame sysdeps/arm/submul_1.S

Packit 6c4009
/* mpn_submul_1 -- multiply and subtract bignums.
Packit 6c4009
   Copyright (C) 2013-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library.  If not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#include <sysdep.h>
Packit 6c4009
Packit 6c4009
	.syntax unified
Packit 6c4009
	.text
Packit 6c4009
Packit 6c4009
@		cycles/limb
Packit 6c4009
@ StrongArm	   ?
Packit 6c4009
@ Cortex-A8	   ?
Packit 6c4009
@ Cortex-A9	   ?
Packit 6c4009
@ Cortex-A15	   4
Packit 6c4009
Packit 6c4009
/* mp_limb_t mpn_submul_1(res_ptr, src1_ptr, size, s2_limb) */
Packit 6c4009
Packit 6c4009
ENTRY (__mpn_submul_1)
Packit 6c4009
	push	{ r4, r5, r6, r7 }
Packit 6c4009
	cfi_adjust_cfa_offset (16)
Packit 6c4009
	cfi_rel_offset (r4, 0)
Packit 6c4009
	cfi_rel_offset (r5, 4)
Packit 6c4009
	cfi_rel_offset (r6, 8)
Packit 6c4009
	cfi_rel_offset (r7, 12)
Packit 6c4009
Packit 6c4009
	ldr	r6, [r1], #4
Packit 6c4009
	ldr	r7, [r0]
Packit 6c4009
	mov	r4, #0			/* init carry in */
Packit 6c4009
	b	1f
Packit 6c4009
0:
Packit 6c4009
	ldr	r6, [r1], #4		/* load next ul */
Packit 6c4009
	adds	r5, r5, r4		/* (lpl, c) = lpl + cl */
Packit 6c4009
	adc	r4, ip, #0		/* cl = hpl + c */
Packit 6c4009
	subs	r5, r7, r5		/* (lpl, !c) = rl - lpl */
Packit 6c4009
	ldr	r7, [r0, #4]		/* load next rl */
Packit 6c4009
	it	cc
Packit 6c4009
	addcc	r4, r4, #1		/* cl += !c */
Packit 6c4009
	str	r5, [r0], #4
Packit 6c4009
1:
Packit 6c4009
	umull	r5, ip, r6, r3		/* (hpl, lpl) = ul * vl */
Packit 6c4009
	subs	r2, r2, #1
Packit 6c4009
	bne	0b
Packit 6c4009
Packit 6c4009
	adds	r5, r5, r4		/* (lpl, c) = lpl + cl */
Packit 6c4009
	adc	r4, ip, #0		/* cl = hpl + c */
Packit 6c4009
	subs	r5, r7, r5		/* (lpl, !c) = rl - lpl */
Packit 6c4009
	str	r5, [r0], #4
Packit 6c4009
	it	cc
Packit 6c4009
	addcc	r4, r4, #1		/* cl += !c */
Packit 6c4009
	mov	r0, r4			/* return carry */
Packit 6c4009
Packit 6c4009
	pop	{ r4, r5, r6, r7 }
Packit 6c4009
	DO_RET	(lr)
Packit 6c4009
END (__mpn_submul_1)