diff options
author | Richard Sandiford <rdsandiford@googlemail.com> | 2013-05-22 18:08:26 +0000 |
---|---|---|
committer | Richard Sandiford <rdsandiford@googlemail.com> | 2013-05-22 18:08:26 +0000 |
commit | c77c0862b26d536f91187c34c510cee96bef1f7a (patch) | |
tree | d528508e7690c671c6dc1f6d9b6194419c0bac32 /gas | |
parent | 45901633da81442f00f59211280e9697737131d5 (diff) | |
download | gdb-c77c0862b26d536f91187c34c510cee96bef1f7a.zip gdb-c77c0862b26d536f91187c34c510cee96bef1f7a.tar.gz gdb-c77c0862b26d536f91187c34c510cee96bef1f7a.tar.bz2 |
include/opcode/
2013-05-22 Jürgen Urban <JuergenUrban@gmx.de>
* mips.h (M_LQC2_AB, M_SQC2_AB): New macros.
opcodes/
2013-05-22 Jürgen Urban <JuergenUrban@gmx.de>
* mips-opc.c (mips_builtin_opcodes): Add R5900 VU0 instructions.
gas/
2013-05-22 Jürgen Urban <JuergenUrban@gmx.de>
* config/tc-mips.c (macro): Handle M_LQC2_AB and M_SQC2_AB.
gas/testsuite/
2013-05-22 Jürgen Urban <JuergenUrban@gmx.de>
* gas/mips/r5900-full.s, gas/mips/r5900-full.d: Add tests for LQ
and SQ macros.
* gas/mips/r5900-vu0.s, gas/mips/r5900-vu0.d: New test.
* gas/mips/mips.exp: Run it.
Diffstat (limited to 'gas')
-rw-r--r-- | gas/ChangeLog | 4 | ||||
-rw-r--r-- | gas/config/tc-mips.c | 14 | ||||
-rw-r--r-- | gas/testsuite/ChangeLog | 7 | ||||
-rw-r--r-- | gas/testsuite/gas/mips/mips.exp | 1 | ||||
-rw-r--r-- | gas/testsuite/gas/mips/r5900-full.d | 18 | ||||
-rw-r--r-- | gas/testsuite/gas/mips/r5900-full.s | 12 | ||||
-rw-r--r-- | gas/testsuite/gas/mips/r5900-vu0.d | 66 | ||||
-rw-r--r-- | gas/testsuite/gas/mips/r5900-vu0.s | 76 |
8 files changed, 196 insertions, 2 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog index 265ea22..83fb073 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,7 @@ +2013-05-22 Jürgen Urban <JuergenUrban@gmx.de> + + * config/tc-mips.c (macro): Handle M_LQC2_AB and M_SQC2_AB. + 2013-05-20 Peter Bergner <bergner@vnet.ibm.com> * config/tc-ppc.c (ppc_setup_opcodes): Use new_seg to fix error diff --git a/gas/config/tc-mips.c b/gas/config/tc-mips.c index b234795..9b191bb 100644 --- a/gas/config/tc-mips.c +++ b/gas/config/tc-mips.c @@ -8201,6 +8201,13 @@ macro (struct mips_cl_insn *ip) /* Itbl support may require additional care here. */ coproc = 1; goto ld_st; + case M_LQC2_AB: + ab = 1; + s = "lqc2"; + fmt = "E,o(b)"; + /* Itbl support may require additional care here. */ + coproc = 1; + goto ld_st; case M_LDC3_AB: ab = 1; s = "ldc3"; @@ -8390,6 +8397,13 @@ macro (struct mips_cl_insn *ip) /* Itbl support may require additional care here. */ coproc = 1; goto ld_st; + case M_SQC2_AB: + ab = 1; + s = "sqc2"; + fmt = "E,o(b)"; + /* Itbl support may require additional care here. */ + coproc = 1; + goto ld_st; case M_SDC3_AB: ab = 1; gas_assert (!mips_opts.micromips); diff --git a/gas/testsuite/ChangeLog b/gas/testsuite/ChangeLog index 7ff8eec..0f7e0fa 100644 --- a/gas/testsuite/ChangeLog +++ b/gas/testsuite/ChangeLog @@ -1,3 +1,10 @@ +2013-05-22 Jürgen Urban <JuergenUrban@gmx.de> + + * gas/mips/r5900-full.s, gas/mips/r5900-full.d: Add tests for LQ + and SQ macros. + * gas/mips/r5900-vu0.s, gas/mips/r5900-vu0.d: New test. + * gas/mips/mips.exp: Run it. + 2013-05-21 Alan Modra <amodra@gmail.com> * gas/ppc/vsx2.d: Ignore trailing padding. diff --git a/gas/testsuite/gas/mips/mips.exp b/gas/testsuite/gas/mips/mips.exp index d338e53..aef771a 100644 --- a/gas/testsuite/gas/mips/mips.exp +++ b/gas/testsuite/gas/mips/mips.exp @@ -1173,6 +1173,7 @@ if { [istarget mips*-*-vxworks*] } { run_dump_test "r5900" run_dump_test "r5900-full" if $elf { run_list_test "r5900-nollsc" "-mabi=o64 -march=r5900" } + run_dump_test "r5900-vu0" run_list_test_arches "ext-ill" [mips_arch_list_matching mips64r2] } diff --git a/gas/testsuite/gas/mips/r5900-full.d b/gas/testsuite/gas/mips/r5900-full.d index 26d97ca..9689209 100644 --- a/gas/testsuite/gas/mips/r5900-full.d +++ b/gas/testsuite/gas/mips/r5900-full.d @@ -43,10 +43,28 @@ Disassembly of section \.text: [0-9a-f]+ <[^>]*> 7c217fff sq \$1,32767\(\$1\) [0-9a-f]+ <[^>]*> 7d088000 sq \$8,-32768\(\$8\) [0-9a-f]+ <[^>]*> 7fffffff sq \$31,-1\(\$31\) +[0-9a-f]+ <[^>]*> 3c010001 lui \$1,0x1 +[0-9a-f]+ <[^>]*> 00220821 addu \$1,\$1,\$2 +[0-9a-f]+ <[^>]*> 7c208000 sq \$0,-32768\(\$1\) +[0-9a-f]+ <[^>]*> 3c01ffff lui \$1,0xffff +[0-9a-f]+ <[^>]*> 003f0821 addu \$1,\$1,\$31 +[0-9a-f]+ <[^>]*> 7c287fff sq \$8,32767\(\$1\) +[0-9a-f]+ <[^>]*> 3c01f123 lui \$1,0xf123 +[0-9a-f]+ <[^>]*> 00240821 addu \$1,\$1,\$4 +[0-9a-f]+ <[^>]*> 7c3f4567 sq \$31,17767\(\$1\) [0-9a-f]+ <[^>]*> 78000000 lq \$0,0\(\$0\) [0-9a-f]+ <[^>]*> 78217fff lq \$1,32767\(\$1\) [0-9a-f]+ <[^>]*> 79088000 lq \$8,-32768\(\$8\) [0-9a-f]+ <[^>]*> 7bffffff lq \$31,-1\(\$31\) +[0-9a-f]+ <[^>]*> 3c030001 lui \$3,0x1 +[0-9a-f]+ <[^>]*> 00621821 addu \$3,\$3,\$2 +[0-9a-f]+ <[^>]*> 78638000 lq \$3,-32768\(\$3\) +[0-9a-f]+ <[^>]*> 3c08ffff lui \$8,0xffff +[0-9a-f]+ <[^>]*> 011f4021 addu \$8,\$8,\$31 +[0-9a-f]+ <[^>]*> 79087fff lq \$8,32767\(\$8\) +[0-9a-f]+ <[^>]*> 3c1ff123 lui \$31,0xf123 +[0-9a-f]+ <[^>]*> 03e4f821 addu \$31,\$31,\$4 +[0-9a-f]+ <[^>]*> 7bff4567 lq \$31,17767\(\$31\) [0-9a-f]+ <[^>]*> cc000000 pref 0x0,0\(\$0\) [0-9a-f]+ <[^>]*> cc217fff pref 0x1,32767\(\$1\) [0-9a-f]+ <[^>]*> cd088000 pref 0x8,-32768\(\$8\) diff --git a/gas/testsuite/gas/mips/r5900-full.s b/gas/testsuite/gas/mips/r5900-full.s index f3c2454..9560dc7 100644 --- a/gas/testsuite/gas/mips/r5900-full.s +++ b/gas/testsuite/gas/mips/r5900-full.s @@ -53,7 +53,7 @@ stuff: trunc.w.s $f0, $f31 trunc.w.s $f31, $f0 - # Test ei/di, but not the R5900 has a bug. ei/di should not be used. + # Test ei/di, but the R5900 has a bug. ei/di should not be used. di ei @@ -68,12 +68,20 @@ stuff: sq $1, 0x7fff($1) sq $8, -0x8000($8) sq $31, -1($31) + .set at + sq $0, 0x8000($2) + sq $8, -0x8001($31) + sq $31, 0xF1234567($4) + .set noat # 128 bit load instruction. lq $0, 0($0) lq $1, 0x7fff($1) lq $8, -0x8000($8) lq $31, -1($31) + lq $3, 0x8000($2) + lq $8, -0x8001($31) + lq $31, 0xF1234567($4) # Prefetch cache pref 0, 0($0) @@ -210,7 +218,7 @@ stuff: rsqrt.s $f0, $f31, $f0 rsqrt.s $f31, $f0, $f31 - # FLoating point subtract to accumulator + # Floating point subtract to accumulator suba.s $f0, $f31 suba.s $f31, $f0 diff --git a/gas/testsuite/gas/mips/r5900-vu0.d b/gas/testsuite/gas/mips/r5900-vu0.d new file mode 100644 index 0000000..8375946 --- /dev/null +++ b/gas/testsuite/gas/mips/r5900-vu0.d @@ -0,0 +1,66 @@ +#objdump: -dr --prefix-addresses --show-raw-insn -M gpr-names=numeric -mmips:5900 +#name: MIPS R5900 VU0 +#as: -march=r5900 + +.*: +file format .*mips.* + +Disassembly of section \.text: +[0-9a-f]+ <[^>]*> d8000000 lqc2 \$0,0\(\$0\) +[0-9a-f]+ <[^>]*> d8217fff lqc2 \$1,32767\(\$1\) +[0-9a-f]+ <[^>]*> d9088000 lqc2 \$8,-32768\(\$8\) +[0-9a-f]+ <[^>]*> dbffffff lqc2 \$31,-1\(\$31\) +[0-9a-f]+ <[^>]*> 3c010001 lui \$1,0x1 +[0-9a-f]+ <[^>]*> 00220821 addu \$1,\$1,\$2 +[0-9a-f]+ <[^>]*> d8208000 lqc2 \$0,-32768\(\$1\) +[0-9a-f]+ <[^>]*> 3c01ffff lui \$1,0xffff +[0-9a-f]+ <[^>]*> 003f0821 addu \$1,\$1,\$31 +[0-9a-f]+ <[^>]*> d8287fff lqc2 \$8,32767\(\$1\) +[0-9a-f]+ <[^>]*> 3c01f123 lui \$1,0xf123 +[0-9a-f]+ <[^>]*> 00240821 addu \$1,\$1,\$4 +[0-9a-f]+ <[^>]*> d83f4567 lqc2 \$31,17767\(\$1\) +[0-9a-f]+ <[^>]*> f8000000 sqc2 \$0,0\(\$0\) +[0-9a-f]+ <[^>]*> f8217fff sqc2 \$1,32767\(\$1\) +[0-9a-f]+ <[^>]*> f9088000 sqc2 \$8,-32768\(\$8\) +[0-9a-f]+ <[^>]*> fbffffff sqc2 \$31,-1\(\$31\) +[0-9a-f]+ <[^>]*> 3c010001 lui \$1,0x1 +[0-9a-f]+ <[^>]*> 00220821 addu \$1,\$1,\$2 +[0-9a-f]+ <[^>]*> f8208000 sqc2 \$0,-32768\(\$1\) +[0-9a-f]+ <[^>]*> 3c01ffff lui \$1,0xffff +[0-9a-f]+ <[^>]*> 003f0821 addu \$1,\$1,\$31 +[0-9a-f]+ <[^>]*> f8287fff sqc2 \$8,32767\(\$1\) +[0-9a-f]+ <[^>]*> 3c01f123 lui \$1,0xf123 +[0-9a-f]+ <[^>]*> 00240821 addu \$1,\$1,\$4 +[0-9a-f]+ <[^>]*> f83f4567 sqc2 \$31,17767\(\$1\) +[0-9a-f]+ <[^>]*> 48400000 cfc2 \$0,\$0 +[0-9a-f]+ <[^>]*> 4840f800 cfc2 \$0,\$31 +[0-9a-f]+ <[^>]*> 48400001 cfc2.i \$0,\$0 +[0-9a-f]+ <[^>]*> 4840f801 cfc2.i \$0,\$31 +[0-9a-f]+ <[^>]*> 48400000 cfc2 \$0,\$0 +[0-9a-f]+ <[^>]*> 4840f800 cfc2 \$0,\$31 +[0-9a-f]+ <[^>]*> 48c00000 ctc2 \$0,\$0 +[0-9a-f]+ <[^>]*> 48c0f800 ctc2 \$0,\$31 +[0-9a-f]+ <[^>]*> 48c00001 ctc2.i \$0,\$0 +[0-9a-f]+ <[^>]*> 48c0f801 ctc2.i \$0,\$31 +[0-9a-f]+ <[^>]*> 48c00000 ctc2 \$0,\$0 +[0-9a-f]+ <[^>]*> 48c0f800 ctc2 \$0,\$31 +[0-9a-f]+ <[^>]*> 48200000 qmfc2 \$0,\$0 +[0-9a-f]+ <[^>]*> 4820f800 qmfc2 \$0,\$31 +[0-9a-f]+ <[^>]*> 48200001 qmfc2.i \$0,\$0 +[0-9a-f]+ <[^>]*> 4820f801 qmfc2.i \$0,\$31 +[0-9a-f]+ <[^>]*> 48200000 qmfc2 \$0,\$0 +[0-9a-f]+ <[^>]*> 4820f800 qmfc2 \$0,\$31 +[0-9a-f]+ <[^>]*> 48a00000 qmtc2 \$0,\$0 +[0-9a-f]+ <[^>]*> 48a0f800 qmtc2 \$0,\$31 +[0-9a-f]+ <[^>]*> 48a00001 qmtc2.i \$0,\$0 +[0-9a-f]+ <[^>]*> 48a0f801 qmtc2.i \$0,\$31 +[0-9a-f]+ <[^>]*> 48a00000 qmtc2 \$0,\$0 +[0-9a-f]+ <[^>]*> 48a0f800 qmtc2 \$0,\$31 +[0-9a-f]+ <[^>]*> 4900ffff bc2f [0-9a-f]+ <branch_label> +[0-9a-f]+ <[^>]*> 00000000 nop +[0-9a-f]+ <[^>]*> 4902fffd bc2fl [0-9a-f]+ <branch_label> +[0-9a-f]+ <[^>]*> 00000000 nop +[0-9a-f]+ <[^>]*> 4901fffb bc2t [0-9a-f]+ <branch_label> +[0-9a-f]+ <[^>]*> 00000000 nop +[0-9a-f]+ <[^>]*> 4903fff9 bc2tl [0-9a-f]+ <branch_label> +[0-9a-f]+ <[^>]*> 00000000 nop + \.\.\. diff --git a/gas/testsuite/gas/mips/r5900-vu0.s b/gas/testsuite/gas/mips/r5900-vu0.s new file mode 100644 index 0000000..13fe3d8 --- /dev/null +++ b/gas/testsuite/gas/mips/r5900-vu0.s @@ -0,0 +1,76 @@ + .text + + .set noreorder + .set noat + + .ent text_label + .global text_label +text_label: + # Floating point transfer to VU + lqc2 $0,0($0) + lqc2 $1, 0x7fff($1) + lqc2 $8, -0x8000($8) + lqc2 $31, -1($31) + .set at + lqc2 $0, 0x8000($2) + lqc2 $8, -0x8001($31) + lqc2 $31, 0xF1234567($4) + .set noat + + # Floating point transfer from VU + sqc2 $0,0($0) + sqc2 $1, 0x7fff($1) + sqc2 $8, -0x8000($8) + sqc2 $31, -1($31) + .set at + sqc2 $0, 0x8000($2) + sqc2 $8, -0x8001($31) + sqc2 $31, 0xF1234567($4) + .set noat + + # Integer transfer from VU + cfc2 $0,$0 + cfc2 $0,$31 + cfc2.i $0,$0 + cfc2.i $0,$31 + cfc2.ni $0,$0 + cfc2.ni $0,$31 + + # Integer transfer to VU + ctc2 $0,$0 + ctc2 $0,$31 + ctc2.i $0,$0 + ctc2.i $0,$31 + ctc2.ni $0,$0 + ctc2.ni $0,$31 + + # Floating point transfer from VU + qmfc2 $0,$0 + qmfc2 $0,$31 + qmfc2.i $0,$0 + qmfc2.i $0,$31 + qmfc2.ni $0,$0 + qmfc2.ni $0,$31 + + # Floating point transfer to VU + qmtc2 $0,$0 + qmtc2 $0,$31 + qmtc2.i $0,$0 + qmtc2.i $0,$31 + qmtc2.ni $0,$0 + qmtc2.ni $0,$31 + + # COP2 conditional branch instructions +branch_label: + bc2f branch_label + nop + bc2fl branch_label + nop + bc2t branch_label + nop + bc2tl branch_label + nop + +# Force at least 8 (non-delay-slot) zero bytes, to make 'objdump' print ... + .space 8 + .end text_label |