Blame mpn/ia64/mul_1.asm

Packit 5c3484
dnl  IA-64 mpn_mul_1, mpn_mul_1c -- Multiply a limb vector with a limb and
Packit 5c3484
dnl  store the result in a second limb vector.
Packit 5c3484
Packit 5c3484
dnl  Contributed to the GNU project by Torbjorn Granlund.
Packit 5c3484
Packit 5c3484
dnl  Copyright 2000-2004, 2006, 2007 Free Software Foundation, Inc.
Packit 5c3484
Packit 5c3484
dnl  This file is part of the GNU MP Library.
Packit 5c3484
dnl
Packit 5c3484
dnl  The GNU MP Library is free software; you can redistribute it and/or modify
Packit 5c3484
dnl  it under the terms of either:
Packit 5c3484
dnl
Packit 5c3484
dnl    * the GNU Lesser General Public License as published by the Free
Packit 5c3484
dnl      Software Foundation; either version 3 of the License, or (at your
Packit 5c3484
dnl      option) any later version.
Packit 5c3484
dnl
Packit 5c3484
dnl  or
Packit 5c3484
dnl
Packit 5c3484
dnl    * the GNU General Public License as published by the Free Software
Packit 5c3484
dnl      Foundation; either version 2 of the License, or (at your option) any
Packit 5c3484
dnl      later version.
Packit 5c3484
dnl
Packit 5c3484
dnl  or both in parallel, as here.
Packit 5c3484
dnl
Packit 5c3484
dnl  The GNU MP Library is distributed in the hope that it will be useful, but
Packit 5c3484
dnl  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
Packit 5c3484
dnl  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit 5c3484
dnl  for more details.
Packit 5c3484
dnl
Packit 5c3484
dnl  You should have received copies of the GNU General Public License and the
Packit 5c3484
dnl  GNU Lesser General Public License along with the GNU MP Library.  If not,
Packit 5c3484
dnl  see https://www.gnu.org/licenses/.
Packit 5c3484
Packit 5c3484
include(`../config.m4')
Packit 5c3484
Packit 5c3484
C         cycles/limb
Packit 5c3484
C Itanium:    4.0
Packit 5c3484
C Itanium 2:  2.0
Packit 5c3484
Packit 5c3484
C TODO
Packit 5c3484
C  * Further optimize feed-in and wind-down code, both for speed and code size.
Packit 5c3484
C  * Handle low limb input and results specially, using a common stf8 in the
Packit 5c3484
C    epilogue.
Packit 5c3484
C  * Use 1 c/l carry propagation scheme in wind-down code.
Packit 5c3484
C  * Use extra pointer register for `up' to speed up feed-in loads.
Packit 5c3484
C  * Work out final differences with addmul_1.asm.
Packit 5c3484
Packit 5c3484
C INPUT PARAMETERS
Packit 5c3484
define(`rp', `r32')
Packit 5c3484
define(`up', `r33')
Packit 5c3484
define(`n', `r34')
Packit 5c3484
define(`vl', `r35')
Packit 5c3484
define(`cy', `r36')	C for mpn_mul_1c
Packit 5c3484
Packit 5c3484
ASM_START()
Packit 5c3484
PROLOGUE(mpn_mul_1)
Packit 5c3484
	.prologue
Packit 5c3484
	.save	ar.lc, r2
Packit 5c3484
	.body
Packit 5c3484
Packit 5c3484
ifdef(`HAVE_ABI_32',
Packit 5c3484
`	addp4		rp = 0, rp		C M I
Packit 5c3484
	addp4		up = 0, up		C M I
Packit 5c3484
	zxt4		n = n			C I
Packit 5c3484
	;;
Packit 5c3484
')
Packit 5c3484
{.mfi
Packit 5c3484
	adds		r15 = -1, n		C M I
Packit 5c3484
	mov		f9 = f0			C F
Packit 5c3484
	mov.i		r2 = ar.lc		C I0
Packit 5c3484
}
Packit 5c3484
{.mmi
Packit 5c3484
	ldf8		f7 = [up], 8		C M
Packit 5c3484
	nop.m		0			C M
Packit 5c3484
	and		r14 = 3, n		C M I
Packit 5c3484
	;;
Packit 5c3484
}
Packit 5c3484
.Lcommon:
Packit 5c3484
{.mii
Packit 5c3484
	setf.sig	f6 = vl			C M2 M3
Packit 5c3484
	shr.u		r31 = r15, 2		C I0
Packit 5c3484
	cmp.eq		p10, p0 = 0, r14	C M I
Packit 5c3484
}
Packit 5c3484
{.mii
Packit 5c3484
	cmp.eq		p11, p0 = 2, r14	C M I
Packit 5c3484
	cmp.eq		p12, p0 = 3, r14	C M I
Packit 5c3484
	nop.i		0			C I
Packit 5c3484
	;;
Packit 5c3484
}
Packit 5c3484
{.mii
Packit 5c3484
	cmp.ne		p6, p7 = r0, r0		C M I
Packit 5c3484
	mov.i		ar.lc = r31		C I0
Packit 5c3484
	cmp.ne		p8, p9 = r0, r0		C M I
Packit 5c3484
}
Packit 5c3484
{.bbb
Packit 5c3484
  (p10)	br.dptk		.Lb00			C B
Packit 5c3484
  (p11)	br.dptk		.Lb10			C B
Packit 5c3484
  (p12)	br.dptk		.Lb11			C B
Packit 5c3484
	;;
Packit 5c3484
}
Packit 5c3484
Packit 5c3484
.Lb01:	mov		r20 = 0
Packit 5c3484
	br.cloop.dptk	.grt1			C B
Packit 5c3484
Packit 5c3484
	xma.l		f39 = f7, f6, f9	C F
Packit 5c3484
	xma.hu		f43 = f7, f6, f9	C F
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r8 = f43		C M2
Packit 5c3484
	stf8		[rp] = f39		C M2 M3
Packit 5c3484
	mov.i		ar.lc = r2		C I0
Packit 5c3484
	br.ret.sptk.many b0			C B
Packit 5c3484
Packit 5c3484
.grt1:
Packit 5c3484
	ldf8		f32 = [up], 8
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f33 = [up], 8
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f34 = [up], 8
Packit 5c3484
	xma.l		f39 = f7, f6, f9
Packit 5c3484
	xma.hu		f43 = f7, f6, f9
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f35 = [up], 8
Packit 5c3484
	br.cloop.dptk	.grt5
Packit 5c3484
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	stf8		[rp] = f39, 8
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r21 = f43
Packit 5c3484
	getf.sig	r18 = f36
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r22 = f40
Packit 5c3484
	getf.sig	r19 = f37
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r23 = f41
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	br		.Lcj5
Packit 5c3484
Packit 5c3484
.grt5:
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	ldf8		f32 = [up], 8
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r21 = f43
Packit 5c3484
	ldf8		f33 = [up], 8
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r18 = f36
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r22 = f40
Packit 5c3484
	ldf8		f34 = [up], 8
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r19 = f37
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
	br		.LL01
Packit 5c3484
Packit 5c3484
Packit 5c3484
.Lb10:	ldf8		f35 = [up], 8
Packit 5c3484
	mov		r23 = 0
Packit 5c3484
	br.cloop.dptk	.grt2
Packit 5c3484
Packit 5c3484
	xma.l		f38 = f7, f6, f9
Packit 5c3484
	xma.hu		f42 = f7, f6, f9
Packit 5c3484
	;;
Packit 5c3484
	stf8		[rp] = f38, 8
Packit 5c3484
	xma.l		f39 = f35, f6, f42
Packit 5c3484
	xma.hu		f43 = f35, f6, f42
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r8 = f43
Packit 5c3484
	stf8		[rp] = f39
Packit 5c3484
	mov.i		ar.lc = r2
Packit 5c3484
	br.ret.sptk.many b0
Packit 5c3484
Packit 5c3484
Packit 5c3484
.grt2:
Packit 5c3484
	ldf8		f32 = [up], 8
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f33 = [up], 8
Packit 5c3484
	xma.l		f38 = f7, f6, f9
Packit 5c3484
	xma.hu		f42 = f7, f6, f9
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f34 = [up], 8
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f35 = [up], 8
Packit 5c3484
	br.cloop.dptk	.grt6
Packit 5c3484
Packit 5c3484
	stf8		[rp] = f38, 8
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r21 = f43
Packit 5c3484
	getf.sig	r18 = f36
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r22 = f40
Packit 5c3484
	getf.sig	r19 = f37
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
	br		.Lcj6
Packit 5c3484
Packit 5c3484
.grt6:
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
	ldf8		f32 = [up], 8
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r21 = f43
Packit 5c3484
	ldf8		f33 = [up], 8
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r18 = f36
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	br		.LL10
Packit 5c3484
Packit 5c3484
Packit 5c3484
.Lb11:	ldf8		f34 = [up], 8
Packit 5c3484
	mov		r22 = 0
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f35 = [up], 8
Packit 5c3484
	br.cloop.dptk	.grt3
Packit 5c3484
	;;
Packit 5c3484
Packit 5c3484
	xma.l		f37 = f7, f6, f9
Packit 5c3484
	xma.hu		f41 = f7, f6, f9
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r23 = f41
Packit 5c3484
	stf8		[rp] = f37, 8
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	getf.sig	r8 = f43
Packit 5c3484
	br		.Lcj3
Packit 5c3484
Packit 5c3484
.grt3:
Packit 5c3484
	ldf8		f32 = [up], 8
Packit 5c3484
	xma.l		f37 = f7, f6, f9
Packit 5c3484
	xma.hu		f41 = f7, f6, f9
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f33 = [up], 8
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r19 = f37
Packit 5c3484
	ldf8		f34 = [up], 8
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r23 = f41
Packit 5c3484
	ldf8		f35 = [up], 8
Packit 5c3484
	br.cloop.dptk	.grt7
Packit 5c3484
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	getf.sig	r21 = f43
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r18 = f36
Packit 5c3484
	st8		[rp] = r19, 8
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	br		.Lcj7
Packit 5c3484
Packit 5c3484
.grt7:
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
	ldf8		f32 = [up], 8
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	br		.LL11
Packit 5c3484
Packit 5c3484
Packit 5c3484
.Lb00:	ldf8		f33 = [up], 8
Packit 5c3484
	mov		r21 = 0
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f34 = [up], 8
Packit 5c3484
	;;
Packit 5c3484
	ldf8		f35 = [up], 8
Packit 5c3484
	xma.l		f36 = f7, f6, f9
Packit 5c3484
	xma.hu		f40 = f7, f6, f9
Packit 5c3484
	br.cloop.dptk	.grt4
Packit 5c3484
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r22 = f40
Packit 5c3484
	stf8		[rp] = f36, 8
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
	getf.sig	r19 = f37
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r23 = f41
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	br		.Lcj4
Packit 5c3484
Packit 5c3484
.grt4:
Packit 5c3484
	ldf8		f32 = [up], 8
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r18 = f36
Packit 5c3484
	ldf8		f33 = [up], 8
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r22 = f40
Packit 5c3484
	ldf8		f34 = [up], 8
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r19 = f37
Packit 5c3484
	getf.sig	r23 = f41
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
	ldf8		f35 = [up], 8
Packit 5c3484
	br.cloop.dptk	.grt8
Packit 5c3484
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
	;;
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	st8		[rp] = r18, 8
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
	br		.Lcj8
Packit 5c3484
Packit 5c3484
.grt8:
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
	br		.LL00
Packit 5c3484
Packit 5c3484
Packit 5c3484
C *** MAIN LOOP START ***
Packit 5c3484
	ALIGN(32)
Packit 5c3484
.Loop:
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
   (p6)	cmp.leu		p8, p9 = r24, r17
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
   (p7)	cmp.ltu		p8, p9 = r24, r17
Packit 5c3484
	;;
Packit 5c3484
.LL00:
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
   (p8)	add		r24 = r18, r21, 1
Packit 5c3484
	nop.b		0
Packit 5c3484
	ldf8		f32 = [up], 8
Packit 5c3484
   (p9)	add		r24 = r18, r21
Packit 5c3484
	nop.b		0
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
   (p8)	cmp.leu		p6, p7 = r24, r18
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
   (p9)	cmp.ltu		p6, p7 = r24, r18
Packit 5c3484
	;;
Packit 5c3484
.LL11:
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r21 = f43
Packit 5c3484
   (p6)	add		r24 = r19, r22, 1
Packit 5c3484
	nop.b		0
Packit 5c3484
	ldf8		f33 = [up], 8
Packit 5c3484
   (p7)	add		r24 = r19, r22
Packit 5c3484
	nop.b		0
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r18 = f36
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
   (p6)	cmp.leu		p8, p9 = r24, r19
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
   (p7)	cmp.ltu		p8, p9 = r24, r19
Packit 5c3484
	;;
Packit 5c3484
.LL10:
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r22 = f40
Packit 5c3484
   (p8)	add		r24 = r16, r23, 1
Packit 5c3484
	nop.b		0
Packit 5c3484
	ldf8		f34 = [up], 8
Packit 5c3484
   (p9)	add		r24 = r16, r23
Packit 5c3484
	nop.b		0
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r19 = f37
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
   (p8)	cmp.leu		p6, p7 = r24, r16
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
   (p9)	cmp.ltu		p6, p7 = r24, r16
Packit 5c3484
	;;
Packit 5c3484
.LL01:
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r23 = f41
Packit 5c3484
   (p6)	add		r24 = r17, r20, 1
Packit 5c3484
	nop.b		0
Packit 5c3484
	ldf8		f35 = [up], 8
Packit 5c3484
   (p7)	add		r24 = r17, r20
Packit 5c3484
	br.cloop.dptk	.Loop
Packit 5c3484
C *** MAIN LOOP END ***
Packit 5c3484
	;;
Packit 5c3484
Packit 5c3484
.Lcj9:
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	xma.l		f36 = f32, f6, f0
Packit 5c3484
   (p6)	cmp.leu		p8, p9 = r24, r17
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	xma.hu		f40 = f32, f6, f0
Packit 5c3484
   (p7)	cmp.ltu		p8, p9 = r24, r17
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
   (p8)	add		r24 = r18, r21, 1
Packit 5c3484
   (p9)	add		r24 = r18, r21
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	xma.l		f37 = f33, f6, f0
Packit 5c3484
   (p8)	cmp.leu		p6, p7 = r24, r18
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	xma.hu		f41 = f33, f6, f0
Packit 5c3484
   (p9)	cmp.ltu		p6, p7 = r24, r18
Packit 5c3484
	;;
Packit 5c3484
.Lcj8:
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r21 = f43
Packit 5c3484
   (p6)	add		r24 = r19, r22, 1
Packit 5c3484
   (p7)	add		r24 = r19, r22
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r18 = f36
Packit 5c3484
	xma.l		f38 = f34, f6, f0
Packit 5c3484
   (p6)	cmp.leu		p8, p9 = r24, r19
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	xma.hu		f42 = f34, f6, f0
Packit 5c3484
   (p7)	cmp.ltu		p8, p9 = r24, r19
Packit 5c3484
	;;
Packit 5c3484
.Lcj7:
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r22 = f40
Packit 5c3484
   (p8)	add		r24 = r16, r23, 1
Packit 5c3484
   (p9)	add		r24 = r16, r23
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r19 = f37
Packit 5c3484
	xma.l		f39 = f35, f6, f0
Packit 5c3484
   (p8)	cmp.leu		p6, p7 = r24, r16
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	xma.hu		f43 = f35, f6, f0
Packit 5c3484
   (p9)	cmp.ltu		p6, p7 = r24, r16
Packit 5c3484
	;;
Packit 5c3484
.Lcj6:
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r23 = f41
Packit 5c3484
   (p6)	add		r24 = r17, r20, 1
Packit 5c3484
   (p7)	add		r24 = r17, r20
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
   (p6)	cmp.leu		p8, p9 = r24, r17
Packit 5c3484
   (p7)	cmp.ltu		p8, p9 = r24, r17
Packit 5c3484
	getf.sig	r16 = f38
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	;;
Packit 5c3484
.Lcj5:
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	getf.sig	r20 = f42
Packit 5c3484
   (p8)	add		r24 = r18, r21, 1
Packit 5c3484
   (p9)	add		r24 = r18, r21
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
   (p8)	cmp.leu		p6, p7 = r24, r18
Packit 5c3484
   (p9)	cmp.ltu		p6, p7 = r24, r18
Packit 5c3484
	getf.sig	r17 = f39
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
	;;
Packit 5c3484
.Lcj4:
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	getf.sig	r8 = f43
Packit 5c3484
   (p6)	add		r24 = r19, r22, 1
Packit 5c3484
   (p7)	add		r24 = r19, r22
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
   (p6)	cmp.leu		p8, p9 = r24, r19
Packit 5c3484
   (p7)	cmp.ltu		p8, p9 = r24, r19
Packit 5c3484
	;;
Packit 5c3484
.Lcj3:
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
   (p8)	add		r24 = r16, r23, 1
Packit 5c3484
   (p9)	add		r24 = r16, r23
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p8,p9
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
   (p8)	cmp.leu		p6, p7 = r24, r16
Packit 5c3484
   (p9)	cmp.ltu		p6, p7 = r24, r16
Packit 5c3484
	;;
Packit 5c3484
.Lcj2:
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
   (p6)	add		r24 = r17, r20, 1
Packit 5c3484
   (p7)	add		r24 = r17, r20
Packit 5c3484
	;;
Packit 5c3484
	.pred.rel "mutex",p6,p7
Packit 5c3484
	st8		[rp] = r24, 8
Packit 5c3484
   (p6)	cmp.leu		p8, p9 = r24, r17
Packit 5c3484
   (p7)	cmp.ltu		p8, p9 = r24, r17
Packit 5c3484
	;;
Packit 5c3484
   (p8)	add		r8 = 1, r8
Packit 5c3484
	mov.i		ar.lc = r2
Packit 5c3484
	br.ret.sptk.many b0
Packit 5c3484
EPILOGUE()
Packit 5c3484
Packit 5c3484
PROLOGUE(mpn_mul_1c)
Packit 5c3484
	.prologue
Packit 5c3484
	.save	ar.lc, r2
Packit 5c3484
	.body
Packit 5c3484
Packit 5c3484
ifdef(`HAVE_ABI_32',
Packit 5c3484
`	addp4		rp = 0, rp		C M I
Packit 5c3484
	addp4		up = 0, up		C M I
Packit 5c3484
	zxt4		n = n			C I
Packit 5c3484
	;;
Packit 5c3484
')
Packit 5c3484
{.mmi
Packit 5c3484
	adds		r15 = -1, n		C M I
Packit 5c3484
	setf.sig	f9 = cy			C M2 M3
Packit 5c3484
	mov.i		r2 = ar.lc		C I0
Packit 5c3484
}
Packit 5c3484
{.mmb
Packit 5c3484
	ldf8		f7 = [up], 8		C M
Packit 5c3484
	and		r14 = 3, n		C M I
Packit 5c3484
	br.sptk		.Lcommon
Packit 5c3484
	;;
Packit 5c3484
}
Packit 5c3484
EPILOGUE()
Packit 5c3484
ASM_END()