public inbox for gdb@sourceware.org
 help / color / mirror / Atom feed
* MIPS o32 ABI spec, $fp1 valid?
@ 2003-06-16 18:36 Andrew Cagney
  2003-06-16 18:51 ` Daniel Jacobowitz
  0 siblings, 1 reply; 7+ messages in thread
From: Andrew Cagney @ 2003-06-16 18:36 UTC (permalink / raw)
  To: gdb

Hello,

KevinB and I were discussing MIPS cleanups for better handling things 
like o32 ABI.  One question was can the o32 ABI use odd floating point 
registers?  The MIPS certainly has them, and instructions can certainly 
access them.  However, according to the o32 ABI, can they be used?

(alternativly, does anyone have a MIPS o32 ABI spec, and even the 
original ABI spec that went with the MIPS 1).

Andrew

^ permalink raw reply	[flat|nested] 7+ messages in thread
* MIPS o32 ABI spec, $fp1 valid?
@ 2003-06-17 19:51 David Anderson
  0 siblings, 0 replies; 7+ messages in thread
From: David Anderson @ 2003-06-17 19:51 UTC (permalink / raw)
  To: gdb, ac131313

>
>
>KevinB and I were discussing MIPS cleanups for better handling things 
>like o32 ABI.  One question was can the o32 ABI use odd floating point 
>registers?  The MIPS certainly has them, and instructions can certainly 
>access them.  However, according to the o32 ABI, can they be used?
>
>(alternativly, does anyone have a MIPS o32 ABI spec, and even the 
>original ABI spec that went with the MIPS 1).
>
>Andrew


The o32 ABI was published by Prentice Hall and was more
recently on line at SCO, now at Caldera.  See
http://www.caldera.com/developers/devspecs/ Called the "MIPS
Processor Supplement" This document implies (Chap 3, Floating
Point Registers) strongly that only the even register numbers
are usable (see below here).

The actual detailed ABI (called the Black Book, titled "ABI
Conformance Guide") was never available generally (I have a
copy of several versions).

According to Sweetman ("See MIPS Run")  the odd fp registers
are usable only as part of the load-store/move.  Not in
operations like add/sum/mul

I also looked at Heinrich, "MIPS R4000 Uses Guide" and  "MIPS
IV Instruction Set" (SGI/MTI, prerelease version from July
1994).

All of these are consistent, if differently worded and with
some lack of precision in places.

This means, effectively, that there are just 16 double fp regs
or (viewed as single precision) 16 single precision fp regs and
only the even numbers are used.  Assembler code does not even
use the odd regs, as assembler 'macros' take care of that
detail. (not truly macros in the sense of C, but nonetheless
the necessity to mfc1/mtc1 of the odd regs is not coded in
assembly, but created by the assembler)

The confusing side effect is that if you look at a
*disassembly* of o32 code you will see the odd regs named in
mfc1/mtc1 ops but that's an 'implementation detail'.  You can't
do arithmetic on them o32 (ie FR bit in CPU status reg == 0)


Regards,
David B. Anderson davea@sgi.com http://reality.sgiweb.org/davea
[any mistakes here are my own, not those of the respective
authors, most likely...]

^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: MIPS o32 ABI spec, $fp1 valid?
@ 2003-06-17 20:13 David Anderson
  2003-06-18 16:12 ` Andrew Cagney
  0 siblings, 1 reply; 7+ messages in thread
From: David Anderson @ 2003-06-17 20:13 UTC (permalink / raw)
  To: cgd, ac131313; +Cc: gdb, drow


Andrew Cagney <ac131313@redhat.com> writes:
>Does the o32 ABI specify how to spill a loating point register (a spill 
>is different to a double store of a parameter as a spilt register is 
>recovered by the unwind code.  mdebug might, for instance, specify 
>something.

No, mdebug says nothing about how spills are done (it says nothing
about how exactly float/double are stored, AFAICT).

The hardware requires mentioning the odd regs to get the entire
64 bits stored.  In MIPS1.

Here is some mips1 o32 disassembly output, IRIX, so big-endian:
Given 
...stuff
double x1(double d)
{
        double d2 = d + 3.0;
        d2 += x2(5.0);
        return d2/4.5;
}
...stuff

x1:
[  11] 0x  48:  3c 1c 00 00    lui $gp,0
[  11] 0x  4c:  27 9c 00 00    addiu $gp,$gp,0
[  11] 0x  50:  03 99 e0 21    addu $gp,$gp,$25
[  11] 0x  54:  27 bd ff c8    addiu $sp,$sp,-56
[  11] 0x  58:  e7 ad 00 38    swc1 $f13,56($sp)
[  11] 0x  5c:  e7 ac 00 3c    swc1 $f12,60($sp)
[  12] 0x  60:  3c 01 40 08    lui $1,16392
[  12] 0x  64:  44 81 38 00    mtc1 $1,$f7
[  12] 0x  68:  c7 a4 00 3c    lwc1 $f4,60($sp)
[  12] 0x  6c:  c7 a5 00 38    lwc1 $f5,56($sp)
[  12] 0x  70:  44 80 30 00    mtc1 $0,$f6
[  13] 0x  74:  8f 99 00 00    lw $25,0($gp)
[  12] 0x  78:  46 26 22 00    add.d $f8,$f4,$f6
[  13] 0x  7c:  3c 01 40 14    lui $1,16404
[  11] 0x  80:  af bf 00 24    sw $31,36($sp)
[  13] 0x  84:  44 81 68 00    mtc1 $1,$f13
[  13] 0x  88:  44 80 60 00    mtc1 $0,$f12
[  11] 0x  8c:  af bc 00 20    sw $gp,32($sp)
[  11] 0x  90:  e7 b5 00 18    swc1 $f21,24($sp)
[  11] 0x  94:  e7 b4 00 1c    swc1 $f20,28($sp)
[  12] 0x  98:  e7 a8 00 34    swc1 $f8,52($sp)
[  13] 0x  9c:  03 20 f8 09    jalr $25
[  12] 0x  a0:  e7 a9 00 30    swc1 $f9,48($sp)
[  13] 0x  a4:  c7 ab 00 30    lwc1 $f11,48($sp)
[  13] 0x  a8:  c7 aa 00 34    lwc1 $f10,52($sp)
[  13] 0x  ac:  46 20 05 06    mov.d $f20,$f0
[  13] 0x  b0:  46 34 54 00    add.d $f16,$f10,$f20
[  14] 0x  b4:  3c 01 40 12    lui $1,16402
[  14] 0x  b8:  44 81 98 00    mtc1 $1,$f19
[  14] 0x  bc:  44 80 90 00    mtc1 $0,$f18
[  14] 0x  c0:  8f bf 00 24    lw $31,36($sp)
[  13] 0x  c4:  e7 b0 00 34    swc1 $f16,52($sp)
[  13] 0x  c8:  e7 b1 00 30    swc1 $f17,48($sp)
[  13] 0x  cc:  8f bc 00 20    lw $gp,32($sp)
[  14] 0x  d0:  c7 b4 00 1c    lwc1 $f20,28($sp)
[  14] 0x  d4:  c7 b5 00 18    lwc1 $f21,24($sp)
[  14] 0x  d8:  27 bd 00 38    addiu $sp,$sp,56
[  14] 0x  dc:  03 e0 00 08    jr $31
[  14] 0x  e0:  46 32 80 03    div.d $f0,$f16,$f18


Looking at cc -S output we see the fp regs are not invidually
mentioned:

 #   9  }
 #  10  double x1(double d)
 #  11  {
        .ent    x1 2
x1:
        .option O1
        .set     noreorder
        .cpload $25
        .set     reorder
        subu    $sp, 56
        sw      $31, 36($sp)
        .cprestore      32
        s.d     $f12, 56($sp)
        s.d     $f20, 24($sp)
        .mask   0x90000000, -20
        .fmask  0x00300000, -32
        .frame  $sp, 56, $31
        .loc    2 11
...

Now I must admit I am using a modern compiler, not an original
old mips1 compiler. So while the spill would be the same, 
(and same as reg saves) I don't recall precisely how it would
really look in IRIX mips1 assembler.




Regards,
David B. Anderson davea@sgi.com http://reality.sgiweb.org/davea

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

end of thread, other threads:[~2003-06-18 16:12 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-06-16 18:36 MIPS o32 ABI spec, $fp1 valid? Andrew Cagney
2003-06-16 18:51 ` Daniel Jacobowitz
     [not found]   ` <mailpost.1055789524.339@news-sj1-1>
2003-06-17  5:34     ` cgd
2003-06-17 13:53       ` Andrew Cagney
2003-06-17 19:51 David Anderson
2003-06-17 20:13 David Anderson
2003-06-18 16:12 ` Andrew Cagney

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).