| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286 | ;! HP-PA  __udiv_qrnnd division support, used from longlong.h.;! This version runs fast on pre-PA7000 CPUs.;! Copyright (C) 1993, 1994 Free Software Foundation, Inc.;! This file is part of the GNU MP Library.;! The GNU MP 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 MP 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 MP Library; see the file COPYING.LIB.  If not, write to;! the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,;! MA 02111-1307, USA.;! INPUT PARAMETERS;! rem_ptr	gr26;! n1		gr25;! n0		gr24;! d		gr23;! The code size is a bit excessive.  We could merge the last two ds;addc;! sequences by simply moving the "bb,< Odd" instruction down.  The only;! trouble is the FFFFFFFF code that would need some hacking.	.text	.export		__udiv_qrnnd__udiv_qrnnd:	.proc	.callinfo	frame=0,no_calls	.entry	comb,<		%r23,%r0,L$largedivisor	 sub		%r0,%r23,%r1		;! clear cy as side-effect	ds		%r0,%r1,%r0	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r24	ds		%r25,%r23,%r25	addc		%r24,%r24,%r28	ds		%r25,%r23,%r25	comclr,>=	%r25,%r0,%r0	addl		%r25,%r23,%r25	stws		%r25,0(%r26)	bv		0(%r2)	 addc		%r28,%r28,%r28L$largedivisor:	extru		%r24,31,1,%r20		;! r20 = n0 & 1	bb,<		%r23,31,L$odd	 extru		%r23,30,31,%r22		;! r22 = d >> 1	shd		%r25,%r24,1,%r24	;! r24 = new n0	extru		%r25,30,31,%r25		;! r25 = new n1	sub		%r0,%r22,%r21	ds		%r0,%r21,%r0	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	comclr,>=	%r25,%r0,%r0	addl		%r25,%r22,%r25	sh1addl		%r25,%r20,%r25	stws		%r25,0(%r26)	bv		0(%r2)	 addc		%r24,%r24,%r28L$odd:	addib,sv,n	1,%r22,L$FF..		;! r22 = (d / 2 + 1)	shd		%r25,%r24,1,%r24	;! r24 = new n0	extru		%r25,30,31,%r25		;! r25 = new n1	sub		%r0,%r22,%r21	ds		%r0,%r21,%r0	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r24	ds		%r25,%r22,%r25	addc		%r24,%r24,%r28	comclr,>=	%r25,%r0,%r0	addl		%r25,%r22,%r25	sh1addl		%r25,%r20,%r25;! We have computed (n1,,n0) / (d + 1), q' = r28, r' = r25	add,nuv		%r28,%r25,%r25	addl		%r25,%r1,%r25	addc		%r0,%r28,%r28	sub,<<		%r25,%r23,%r0	addl		%r25,%r1,%r25	stws		%r25,0(%r26)	bv		0(%r2)	 addc		%r0,%r28,%r28;! This is just a special case of the code above.;! We come here when d == 0xFFFFFFFFL$FF..:	add,uv		%r25,%r24,%r24	sub,<<		%r24,%r23,%r0	ldo		1(%r24),%r24	stws		%r24,0(%r26)	bv		0(%r2)	 addc		%r0,%r25,%r28	.exit	.procend
 |