public inbox for gcc@gcc.gnu.org
 help / color / mirror / Atom feed
From: Mark Klein <mklein@dis.com>
To: law@cygnus.com
Cc: gcc@gcc.gnu.org
Subject: Re: MPE Port
Date: Thu, 30 Sep 1999 18:02:00 -0000	[thread overview]
Message-ID: <4.1.19990906102435.00c78df0@garfield.dis.com> (raw)
Message-ID: <19990930180200.yXE9QueXKcD7WsvUi6_bnVxUeCb9NXpGt7CIJmRRgwk@z> (raw)

Explanation:

This provides the interface to the quad library as specified in the
PRO spec. This is implemented on MPE and HP-UX, but I don't know
about the other PA platforms. Long Double support is enabled by
default for MPE only.

Sat Sep  4 18:00:00 PDT 1999 Mark Klein (mklein@dis.com)

        * pa/quadlib.asm: New file for long double support for the MPE port.

*** egcs/gcc/config/pa/quadlib.asm	Wed Dec 31 16:00:00 1969
--- egcs-ss/gcc/config/pa/quadlib.asm	Mon Aug 30 21:52:06 1999
***************
*** 0 ****
--- 1,359 ----
+ ;  Subroutines for long double support on the HPPA
+ ;  Copyright (C) 1999 Free Software Foundation, Inc.
+ 
+ ;  This file is part of GNU CC.
+ 
+ ;  GNU CC 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, or (at your option)
+ ;  any later version.
+ 
+ ;  GNU CC 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.
+ 
+ ; In addition to the permissions in the GNU General Public License, the
+ ; Free Software Foundation gives you unlimited permission to link the
+ ; compiled version of this file with other programs, and to distribute
+ ; those programs without any restriction coming from the use of this
+ ; file.  (The General Public License restrictions do apply in other
+ ; respects; for example, they cover modification of the file, and
+ ; distribution when not linked into another program.)
+ 
+ ;  You should have received a copy of the GNU General Public License
+ ;  along with GNU CC; see the file COPYING.  If not, write to
+ ;  the Free Software Foundation, 59 Temple Place - Suite 330,
+ ;  Boston, MA 02111-1307, USA.
+ 
+ 	.SPACE $TEXT$
+ 	.SUBSPA $CODE$,QUAD=0,ALIGN=8,ACCESS=44,CODE_ONLY
+ 	.compiler "quadlib.asm GNU_PA-RISC_Assembler 2.9.4"
+ 	.IMPORT _U_Qfcmp,CODE
+ 	.IMPORT _U_Qfsub,CODE
+ 
+ 	.align 4
+ 	.NSUBSPA $CODE$,QUAD=0,ALIGN=8,ACCESS=44,CODE_ONLY
+ 	;
+ 	; Check two long doubles for equality
+ 	;
+ 	.EXPORT _U_Qfeq,ENTRY,PRIV_LEV=3,ARGW0=GR,ARGW1=GR,RTNVAL=GR
+ _U_Qfeq
+ 	.PROC
+ 	.CALLINFO FRAME=64,CALLS,SAVE_RP
+ 	.ENTRY
+ 	;
+ 	; Build the frame
+ 	;
+ 	stw %r2,-20(0,%r30)
+ 	ldo 64(%r30),%r30
+ 
+ 	;
+ 	; Load the additional argument and call the comparison routine.
+ 	;
+ 	bl _U_Qfcmp,%r2
+ 	  ldi 4,%r24
+ 
+ 	;
+ 	; The return from _U_Qfcmp is the masked C bit from the FP
+ 	; status register. Convert that to a 0 or 1.
+ 	;
+ 	comiclr,= 0,%r28,%r28
+ 	  ldi 1,%r28
+ 
+ 	;
+ 	; Return
+ 	;
+ 	ldw -84(0,%r30),%r2
+ 	bv 0(%r2)
+ 	  ldo -64(%r30), %r30
+ 
+ 	.EXIT
+ 	.PROCEND
+ 
+ 	;
+ 	; Check two long doubles for inequality
+ 	;
+ 	.EXPORT _U_Qfne,ENTRY,PRIV_LEV=3,ARGW0=GR,ARGW1=GR,RTNVAL=GR
+ _U_Qfne
+ 	.PROC
+ 	.CALLINFO FRAME=64,CALLS,SAVE_RP
+ 	.ENTRY
+ 	;
+ 	; Build the frame
+ 	;
+ 	stw %r2,-20(0,%r30)
+ 	ldo 64(%r30),%r30
+ 
+ 	;
+ 	; Load the additional argument and call the comparison routine.
+ 	;
+ 	bl _U_Qfcmp,%r2
+ 	ldi 4,%r24
+ 	
+ 	;
+ 	; The return from _U_Qfcmp is the masked C bit from the FP
+ 	; status register. Convert that to a 0 or 1.
+ 	;
+ 	comiclr,<> 0,%r28,%r28
+ 	  ldi 1,%r28
+ 
+ 	;
+ 	; Return
+ 	;
+ 	ldw -84(0,%r30),%r2
+ 	bv 0(%r2)
+ 	  ldo -64(%r30),%r30
+ 	.EXIT
+ 	.PROCEND
+ 
+ 	;
+ 	; Check if opnd1 > opnd0                
+ 	;
+ 	.EXPORT _U_Qfgt,ENTRY,PRIV_LEV=3,ARGW0=GR,ARGW1=GR,RTNVAL=GR
+ _U_Qfgt
+ 	.PROC
+ 	.CALLINFO FRAME=64,CALLS,SAVE_RP
+ 	.ENTRY
+ 	;
+ 	; Build the frame
+ 	;
+ 	stw %r2,-20(0,%r30)
+ 	ldo 64(%r30),%r30
+ 
+ 	;
+ 	; Load the additional argument and call the comparison routine.
+ 	;
+ 	bl _U_Qfcmp,%r2
+ 	ldi 23,%r24
+ 
+ 	;
+ 	; The return from _U_Qfcmp is the masked C bit from the FP
+ 	; status register. Convert that to a 0 or 1.
+ 	;
+ 	comiclr,= 0,%r28,%r28
+ 	  ldi 1,%r28
+ 
+ 	;
+ 	; Return
+ 	;
+ 	ldw -84(0,%r30),%r2
+ 	bv 0(%r2)
+ 	  ldo -64(%r30), %r30
+ 
+ 	.EXIT
+ 	.PROCEND
+ 
+ 	;
+ 	; Check if opnd1 >= opnd0                
+ 	;
+ 	.EXPORT _U_Qfge,ENTRY,PRIV_LEV=3,ARGW0=GR,ARGW1=GR,RTNVAL=GR
+ _U_Qfge
+ 	.PROC
+ 	.CALLINFO FRAME=64,CALLS,SAVE_RP
+ 	.ENTRY
+ 	;
+ 	; Build the frame
+ 	;
+ 	stw %r2,-20(0,%r30)
+ 	ldo 64(%r30),%r30
+ 
+ 	;
+ 	; Load the additional argument and call the comparison routine.
+ 	;
+ 	bl _U_Qfcmp,%r2
+ 	ldi 23,%r24
+ 
+ 	;
+ 	; The return from _U_Qfcmp is the masked C bit from the FP
+ 	; status register. Convert that to a 0 or 1.
+ 	;
+ 	comiclr,= 0,%r28,%r28
+ 	  ldi 1,%r28
+ 
+ 	;
+ 	; Return
+ 	;
+ 	ldw -84(0,%r30),%r2
+ 	bv 0(%r2)
+ 	  ldo -64(%r30), %r30
+ 
+ 	.EXIT
+ 	.PROCEND
+ 
+ 	;
+ 	; Check if opnd1 < opnd0                
+ 	;
+ 	.EXPORT _U_Qflt,ENTRY,PRIV_LEV=3,ARGW0=GR,ARGW1=GR,RTNVAL=GR
+ _U_Qflt
+ 	.PROC
+ 	.CALLINFO FRAME=64,CALLS,SAVE_RP
+ 	.ENTRY
+ 	;
+ 	; Build the frame
+ 	;
+ 	stw %r2,-20(0,%r30)
+ 	ldo 64(%r30),%r30
+ 
+ 	;
+ 	; Load the additional argument and call the comparison routine.
+ 	;
+ 	bl _U_Qfcmp,%r2
+ 	ldi 9,%r24
+ 
+ 	;
+ 	; The return from _U_Qfcmp is the masked C bit from the FP
+ 	; status register. Convert that to a 0 or 1.
+ 	;
+ 	comiclr,= 0,%r28,%r28
+ 	  ldi 1,%r28
+ 
+ 	;
+ 	; Return
+ 	;
+ 	ldw -84(0,%r30),%r2
+ 	bv 0(%r2)
+ 	  ldo -64(%r30), %r30
+ 
+ 	.EXIT
+ 	.PROCEND
+ 
+ 	;
+ 	; Check if opnd1 <= opnd0                
+ 	;
+ 	.EXPORT _U_Qfle,ENTRY,PRIV_LEV=3,ARGW0=GR,ARGW1=GR,RTNVAL=GR
+ _U_Qfle
+ 	.PROC
+ 	.CALLINFO FRAME=64,CALLS,SAVE_RP
+ 	.ENTRY
+ 	;
+ 	; Build the frame
+ 	;
+ 	stw %r2,-20(0,%r30)
+ 	ldo 64(%r30),%r30
+ 
+ 	;
+ 	; Load the additional argument and call the comparison routine.
+ 	;
+ 	bl _U_Qfcmp,%r2
+ 	ldi 13,%r24
+ 
+ 	;
+ 	; The return from _U_Qfcmp is the masked C bit from the FP
+ 	; status register. Convert that to a 0 or 1.
+ 	;
+ 	comiclr,= 0,%r28,%r28
+ 	  ldi 1,%r28
+ 
+ 	;
+ 	; Return
+ 	;
+ 	ldw -84(0,%r30),%r2
+ 	bv 0(%r2)
+ 	  ldo -64(%r30), %r30
+ 
+ 	.EXIT
+ 	.PROCEND
+ 
+ 	;
+ 	; Negate opnd0 and store in ret0                 
+ 	;
+ 	.EXPORT _U_Qfneg,ENTRY,PRIV_LEV=3,ARGW0=GR,RTNVAL=GR
+ _U_Qfneg
+ 	.PROC
+ 	.CALLINFO FRAME=128,CALLS,SAVE_RP
+ 	.ENTRY
+ 	;
+ 	; Build the frame
+ 	;
+ 	stw %r2,-20(0,%r30)
+ 	ldo 128(%r30),%r30
+ 
+ 	;
+ 	; copy the value to be negated to the frame.
+ 	;
+ 	ldw 0(0,%r26), %r25
+ 	ldw 4(0,%r26), %r24
+ 	ldw 8(0,%r26), %r23
+ 	ldw 12(0,%r26),%r1
+ 	stw %r25, -100(0,%r30)
+ 	stw %r24,  -96(0,%r30)
+ 	stw %r23,  -92(0,%r30)
+ 	stw %r1,   -88(0,%r30)
+ 	ldo -100(%r30), %r25
+ 
+ 	;
+ 	; ret0 contains a pointer to the location for the return
+ 	; value. Initialize it to zero and pass it as arg0 to
+ 	; _U_Qfsub.
+ 	;
+ 	copy %r28,%r26
+ 	stw %r0,0(0,%r26)
+ 	stw %r0,4(0,%r26)
+ 	stw %r0,8(0,%r26)
+ 	bl _U_Qfsub,%r2
+ 	  stw %r0,12(0,%r26)
+ 
+ 	;
+ 	; Return
+ 	;
+ 	ldw -148(0,%r30),%r2
+ 	bv 0(%r2)
+ 	  ldo -128(%r30), %r30
+ 
+ 	.EXIT
+ 	.PROCEND
+ 
+ 	;
+ 	; Compare opnd0 and opnd1. If opnd0 == opnd1, return 0.
+ 	; If opnd0 is greater than opnd1, return 1.
+ 	; Otherwise, return -1.
+ 	;
+ 	.EXPORT _U_Qfcomp,ENTRY,PRIV_LEV=3,ARGW0=GR,ARGW1=GR,RTNVAL=GR
+ _U_Qfcomp
+ 	.PROC
+ 	.CALLINFO FRAME=64,CALLS,SAVE_RP
+ 	.ENTRY
+ 	;
+ 	; Build the frame
+ 	;
+ 	stw %r2,-20(0,%r30)
+ 	ldo 64(%r30),%r30
+ 
+ 	;
+ 	; Save arg0 and arg1.
+ 	;
+ 	stw %r26, -60(0,%r30)
+ 	stw %r25, -56(0,%r30)
+ 	;
+ 	; Check for equality
+ 	;
+ 	bl _U_Qfcmp,%r2
+ 	  ldi 4, %r24
+ 
+ 	comib,<> 0,%r28,done
+ 	  copy %r0, %r1
+ 
+ 	;
+ 	; Reset the parms and test for opnd0 > opnd1.
+ 	;
+ 	ldw -60(0,%r30),%r26
+ 	ldw -56(0,%r30),%r25
+ 	bl _U_Qfcmp,%r2
+ 	  ldi 22,%r24
+ 
+ 	ldi 1,%r1
+ 	comiclr,<> 0,%r28,0
+ 	  ldi -1,%r1
+ 
+ done
+ 	copy %r1,%r28
+ 	;
+ 	; Return
+ 	;
+ 	ldw -84(0,%r30),%r2
+ 	bv 0(%r2)
+ 	  ldo -64(%r30), %r30
+ 
+ 	.EXIT
+ 	.PROCEND

--
Mark Klein                                 DIS International, Ltd.
http://www.dis.com                         415-892-8400
PGP Public Key Available			

             reply	other threads:[~1999-09-30 18:02 UTC|newest]

Thread overview: 96+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
1999-09-06 10:39 Mark Klein [this message]
1999-09-30 18:02 ` Mark Klein
  -- strict thread matches above, loose matches on Subject: below --
1999-09-07  8:42 Mark Klein
1999-09-30 18:02 ` Mark Klein
1999-10-25 22:41 ` Jeffrey A Law
1999-10-26  7:03   ` Mark Klein
1999-10-26 19:12     ` Jeffrey A Law
1999-10-26 19:52       ` Mark Klein
1999-10-31 23:35         ` Mark Klein
1999-10-31 23:35       ` Jeffrey A Law
1999-10-31 23:35     ` Mark Klein
1999-10-31 23:35   ` Jeffrey A Law
1999-09-06 10:40 Mark Klein
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:40 Mark Klein
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:40 Mark Klein
1999-09-08  1:49 ` Jeffrey A Law
1999-09-08 20:31   ` Mark Klein
1999-09-30 18:02     ` Mark Klein
1999-09-30 18:02   ` Jeffrey A Law
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:40 Mark Klein
1999-09-08  1:40 ` Jeffrey A Law
1999-09-30 18:02   ` Jeffrey A Law
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:40 Mark Klein
1999-09-30 18:02 ` Mark Klein
1999-10-25 22:32 ` Jeffrey A Law
1999-10-26  6:51   ` Mark Klein
1999-10-26 19:05     ` Jeffrey A Law
1999-10-26 19:21       ` Mark Klein
1999-10-31 23:35         ` Mark Klein
1999-10-31 23:35       ` Jeffrey A Law
1999-10-31 23:35     ` Mark Klein
1999-10-31 23:35   ` Jeffrey A Law
1999-09-06 10:40 Mark Klein
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:40 Mark Klein
1999-09-07  2:38 ` Jeffrey A Law
1999-09-07  6:39   ` Mark Klein
1999-09-08  0:45     ` Jeffrey A Law
1999-09-08 20:04       ` Mark Klein
1999-09-15  2:47         ` Jeffrey A Law
1999-09-15  8:32           ` Mark Klein
1999-09-30 18:02             ` Mark Klein
1999-09-30 18:02           ` Jeffrey A Law
1999-10-09 20:18           ` Mark Klein
1999-10-14  4:03             ` Jeffrey A Law
1999-10-14  7:20               ` Mark Klein
1999-10-14 10:45                 ` Jeffrey A Law
1999-10-14 11:05                   ` Mark Klein
1999-10-31 23:35                     ` Mark Klein
1999-10-31 23:35                   ` Jeffrey A Law
1999-10-31 23:35                 ` Mark Klein
1999-10-31 23:35               ` Jeffrey A Law
1999-10-31 23:35             ` Mark Klein
1999-11-08 19:34           ` Mark Klein
1999-11-08 19:54             ` Jeffrey A Law
1999-11-09  6:52               ` Mark Klein
1999-11-30 23:37                 ` Mark Klein
1999-11-30 23:37               ` Jeffrey A Law
1999-11-30 23:37             ` Mark Klein
1999-09-30 18:02         ` Mark Klein
1999-09-30 18:02       ` Jeffrey A Law
1999-09-30 18:02     ` Mark Klein
1999-09-30 18:02   ` Jeffrey A Law
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:40 Mark Klein
1999-09-08  1:39 ` Jeffrey A Law
1999-09-08  6:35   ` Mark Klein
1999-09-15  2:52     ` Jeffrey A Law
1999-09-15  8:26       ` Mark Klein
1999-09-30 18:02         ` Mark Klein
1999-09-30 18:02       ` Jeffrey A Law
1999-09-30 18:02     ` Mark Klein
1999-09-30 18:02   ` Jeffrey A Law
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:40 Mark Klein
1999-09-08  1:41 ` Jeffrey A Law
1999-09-08  6:37   ` Mark Klein
1999-09-30 18:02     ` Mark Klein
1999-09-30 18:02   ` Jeffrey A Law
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:39 Mark Klein
1999-09-30 18:02 ` Mark Klein
1999-09-06 10:39 Mark Klein
1999-09-07  3:20 ` Jeffrey A Law
1999-09-07  6:46   ` Mark Klein
1999-09-08  0:43     ` Jeffrey A Law
1999-09-30 18:02       ` Jeffrey A Law
1999-09-30 18:02     ` Mark Klein
1999-09-30 18:02   ` Jeffrey A Law
1999-09-30 18:02 ` Mark Klein
1999-08-27 17:20 HARD_REGNO_MODE_OK on PA-RISC (revisited) Mark Klein
1999-08-29  3:19 ` Jeffrey A Law
1999-09-06 10:39   ` MPE Port Mark Klein
1999-09-30 18:02     ` Mark Klein

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4.1.19990906102435.00c78df0@garfield.dis.com \
    --to=mklein@dis.com \
    --cc=gcc@gcc.gnu.org \
    --cc=law@cygnus.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).