Linux PARISC architecture development
 help / color / mirror / Atom feed
* [parisc-linux] PIC assembly
@ 2002-01-06 17:26 Randolph Chung
  2002-01-06 21:32 ` John David Anglin
  0 siblings, 1 reply; 5+ messages in thread
From: Randolph Chung @ 2002-01-06 17:26 UTC (permalink / raw)
  To: parisc-linux

[-- Attachment #1: Type: text/plain, Size: 532 bytes --]

There is bug in the libgcrypt package in Debian where one of the
assembly routines was not written for PIC linking. The bug is:

http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=127863&repeatmerged=yes

I'ved filed a possible patch for this in the bug report, but I'm not
100% convinced I understand this correctly. Can someone please take a
look and let me know? 

the original .S file and the patch are also attached

randolph
-- 
   @..@                                         http://www.TauSq.org/
  (----)
 ( >__< )
 ^^ ~~ ^^

[-- Attachment #2: udiv-qrnnd.S --]
[-- Type: text/plain, Size: 2400 bytes --]

/* HP-PA  __udiv_qrnnd division support, used from longlong.h.
 *	  This version runs fast on PA 7000 and later.
 *
 *      Copyright (C) 1993, 1994, 1998, 
 *                    2001 Free Software Foundation, Inc.
 *
 * This file is part of GnuPG.
 *
 * GnuPG is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * GnuPG 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 General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
 *
 * Note: This code is heavily based on the GNU MP Library.
 *	 Actually it's the same code with only minor changes in the
 *	 way the data is stored; this is to support the abstraction
 *	 of an optional secure memory allocation which may be used
 *	 to avoid revealing of sensitive data due to paging etc.
 *	 The GNU MP Library itself is published under the LGPL;
 *	 however I decided to publish this code under the plain GPL.
 */



/* INPUT PARAMETERS
 *   rem_ptr	   gr26
 *   n1 	   gr25
 *   n0 	   gr24
 *   d		   gr23
 */

	.code
	.label L$0000
	.word		0x43f00000
	.word		0x0
	.export 	__udiv_qrnnd
	.label		__udiv_qrnnd
	.proc
	.callinfo	frame=64,no_calls
	.entry
	ldo		64(%r30),%r30

	stws		%r25,-16(0,%r30)	; n_hi
	stws		%r24,-12(0,%r30)	; n_lo
	ldil		L'L$0000,%r19           ; '
	ldo		R'L$0000(%r19),%r19     ; '
	fldds		-16(0,%r30),%fr5
	stws		%r23,-12(0,%r30)
	comib,<=	0,%r25,L$1
	fcnvxf,dbl,dbl	%fr5,%fr5
	fldds		0(0,%r19),%fr4
	fadd,dbl	%fr4,%fr5,%fr5
	.label	L$1
	fcpy,sgl	%fr0,%fr6L
	fldws		-12(0,%r30),%fr6R
	fcnvxf,dbl,dbl	%fr6,%fr4

	fdiv,dbl	%fr5,%fr4,%fr5

	fcnvfx,dbl,dbl	%fr5,%fr4
	fstws		%fr4R,-16(%r30)
	xmpyu		%fr4R,%fr6R,%fr6
	ldws		-16(%r30),%r28
	fstds		%fr6,-16(0,%r30)
	ldws		-12(0,%r30),%r21
	ldws		-16(0,%r30),%r20
	sub		%r24,%r21,%r22
	subb		%r25,%r20,%r19
	comib,= 	0,%r19,L$2
	ldo		-64(%r30),%r30

	add		%r22,%r23,%r22
	ldo		-1(%r28),%r28
	.label	L$2
	bv		0(%r2)
	stws		%r22,0(0,%r26)

	.exit
	.procend



[-- Attachment #3: udiv-qrnnd.diff --]
[-- Type: text/plain, Size: 423 bytes --]

--- udiv-qrnnd.S.orig	Thu May 31 03:14:12 2001
+++ udiv-qrnnd.S	Sat Jan  5 23:27:02 2002
@@ -51,8 +51,11 @@
 
 	stws		%r25,-16(0,%r30)	; n_hi
 	stws		%r24,-12(0,%r30)	; n_lo
-	ldil		L'L$0000,%r19           ; '
-	ldo		R'L$0000(%r19),%r19     ; '
+
+	stw             %r19,-32(%r30)
+	addil		LT%L$0000,%r19
+	ldw		RT%L$0000(%r1),%r1
+	ldw		0(%r1), %r19
 	fldds		-16(0,%r30),%fr5
 	stws		%r23,-12(0,%r30)
 	comib,<=	0,%r25,L$1

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [parisc-linux] PIC assembly
  2002-01-06 17:26 [parisc-linux] PIC assembly Randolph Chung
@ 2002-01-06 21:32 ` John David Anglin
  0 siblings, 0 replies; 5+ messages in thread
From: John David Anglin @ 2002-01-06 21:32 UTC (permalink / raw)
  To: randolph; +Cc: parisc-linux

> I'ved filed a possible patch for this in the bug report, but I'm not
> 100% convinced I understand this correctly. Can someone please take a
> look and let me know? 

The patch needs to be revised.  You can't use r19 as a scratch register
in PIC mode.  There are several places where it is used in the routine.
Maybe you use can use r1 in its place.

> --- udiv-qrnnd.S.orig	Thu May 31 03:14:12 2001
> +++ udiv-qrnnd.S	Sat Jan  5 23:27:02 2002
> @@ -51,8 +51,11 @@
>  
>  	stws		%r25,-16(0,%r30)	; n_hi
>  	stws		%r24,-12(0,%r30)	; n_lo
> -	ldil		L'L$0000,%r19           ; '
> -	ldo		R'L$0000(%r19),%r19     ; '
> +
> +	stw             %r19,-32(%r30)
> +	addil		LT%L$0000,%r19
> +	ldw		RT%L$0000(%r1),%r1

Change following fldds insn to use r1, or change destination register in
the above to some other caller saved register and the fldds insn to match.

> +	ldw		0(%r1), %r19

Wrong.  This would load 0x43f00000 into r19.

Finally, you should put the data in the data section.  There might be a
problem accessing data in the code section with LT% (RT%) because LT%
is "LR% value offset of data linkage slots from linkage table pointer (r19)".

Dave
-- 
J. David Anglin                                  dave.anglin@nrc.ca
National Research Council of Canada              (613) 990-0752 (FAX: 952-6605)

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [parisc-linux] PIC assembly
       [not found] <no.id>
@ 2002-01-07 18:39 ` John David Anglin
  2002-01-09  1:05   ` Grant Grundler
  0 siblings, 1 reply; 5+ messages in thread
From: John David Anglin @ 2002-01-07 18:39 UTC (permalink / raw)
  To: John David Anglin; +Cc: randolph, parisc-linux

> This page contains links to various useful documents including the 32-bit
> runtime:
> 
> <http://h21007.www2.hp.com/dspp/tech/tech_TechTypeListingPage_IDX/1,1704,10403,00.html>.
> 
> The document itself is here:
> 
> <http://devresource.hp.com/STK/partner/rad_10_20.pdf>.

Maybe copies of these documents could be made accessible from the PA-RISC
LINUX Tech Documentation page as some of these are hard to find.

Dave
-- 
J. David Anglin                                  dave.anglin@nrc.ca
National Research Council of Canada              (613) 990-0752 (FAX: 952-6605)

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [parisc-linux] PIC assembly
  2002-01-07 18:39 ` John David Anglin
@ 2002-01-09  1:05   ` Grant Grundler
  2002-01-11 20:45     ` Grant Grundler
  0 siblings, 1 reply; 5+ messages in thread
From: Grant Grundler @ 2002-01-09  1:05 UTC (permalink / raw)
  To: John David Anglin; +Cc: randolph, parisc-linux

"John David Anglin" wrote:
> > This page contains links to various useful documents including the 32-bit
> > runtime:
> > 
> > <http://h21007.www2.hp.com/dspp/tech/tech_TechTypeListingPage_IDX/1,1704,10
>   403,00.html>.
> > 
> > The document itself is here:
> > 
> > <http://devresource.hp.com/STK/partner/rad_10_20.pdf>.
> 
> Maybe copies of these documents could be made accessible from the PA-RISC
> LINUX Tech Documentation page as some of these are hard to find.

I've been given the OK to link into h21007.www2.hp.com website and promised
the URLs for specific documents wouldn't change (too) suddenly.
I'll add those links in the next couple of days to p-l.org
"Tech Documentation" to those.

grant

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [parisc-linux] PIC assembly
  2002-01-09  1:05   ` Grant Grundler
@ 2002-01-11 20:45     ` Grant Grundler
  0 siblings, 0 replies; 5+ messages in thread
From: Grant Grundler @ 2002-01-11 20:45 UTC (permalink / raw)
  To: parisc-linux

Grant Grundler wrote:
> I've been given the OK to link into h21007.www2.hp.com website and promised
> the URLs for specific documents wouldn't change (too) suddenly.
> I'll add those links in the next couple of days to p-l.org
> "Tech Documentation" to those.

I've added links for PA 1.1 and PA 2.0 Instruction Sets among other things.
Please reload:
	http://www.parisc-linux.org/documentation/index.html

Please continue to post requests for links to docs here.
(I'm not promising any new docs at this point).

thanks,
grant

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2002-01-11 20:45 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2002-01-06 17:26 [parisc-linux] PIC assembly Randolph Chung
2002-01-06 21:32 ` John David Anglin
     [not found] <no.id>
2002-01-07 18:39 ` John David Anglin
2002-01-09  1:05   ` Grant Grundler
2002-01-11 20:45     ` Grant Grundler

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox