aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gas/ChangeLog5
-rw-r--r--gas/config/tc-ppc.c5
-rw-r--r--gas/testsuite/ChangeLog9
-rw-r--r--gas/testsuite/gas/ppc/cell.d10
-rw-r--r--gas/testsuite/gas/ppc/cell.s7
-rw-r--r--gas/testsuite/gas/ppc/power6.d31
-rw-r--r--gas/testsuite/gas/ppc/power6.s25
-rw-r--r--gas/testsuite/gas/ppc/ppc.exp3
8 files changed, 90 insertions, 5 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index dfe775f..2fe19f2 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,8 @@
+2008-07-31 Peter Bergner <bergner@vnet.ibm.com>
+
+ * config/tc-ppc.c (parse_cpu) <power6>: Accept Altivec instructions.
+ <cell>: Likewise.
+
2008-07-30 Michael J. Eager <eager@eagercon.com>
* config/tc-ppc.c (parse_cpu): Separate handling of -m403/405.
diff --git a/gas/config/tc-ppc.c b/gas/config/tc-ppc.c
index b4a9e1d..bded5f3 100644
--- a/gas/config/tc-ppc.c
+++ b/gas/config/tc-ppc.c
@@ -932,13 +932,14 @@ parse_cpu (const char *arg)
{
ppc_cpu = (PPC_OPCODE_PPC | PPC_OPCODE_CLASSIC
| PPC_OPCODE_64 | PPC_OPCODE_POWER4
- | PPC_OPCODE_POWER5 | PPC_OPCODE_POWER6);
+ | PPC_OPCODE_POWER5 | PPC_OPCODE_POWER6
+ | PPC_OPCODE_ALTIVEC);
}
else if (strcmp (arg, "cell") == 0)
{
ppc_cpu = (PPC_OPCODE_PPC | PPC_OPCODE_CLASSIC
| PPC_OPCODE_64 | PPC_OPCODE_POWER4
- | PPC_OPCODE_CELL);
+ | PPC_OPCODE_CELL | PPC_OPCODE_ALTIVEC);
}
/* -mcom means assemble for the common intersection between Power
and PowerPC. At present, we just allow the union, rather
diff --git a/gas/testsuite/ChangeLog b/gas/testsuite/ChangeLog
index 037b6a0..7c43370 100644
--- a/gas/testsuite/ChangeLog
+++ b/gas/testsuite/ChangeLog
@@ -1,3 +1,12 @@
+2008-07-31 Peter Bergner <bergner@vnet.ibm.com>
+
+ * gas/ppc/cell.s: Add altivec instructions.
+ * gas/ppc/cell.d: Update expected output.
+ * gas/ppc/power6.d: New.
+ * gas/ppc/power6.s: Likewise.
+ * gas/ppc/ppc.exp (powerpc64*-*-*): Move cell from here to...
+ (powerpc*-*-*): Here. Run power6 test.
+
2008-07-24 H.J. Lu <hongjiu.lu@intel.com>
* gas/i386/nops-1.d: Add -mtune=generic32.
diff --git a/gas/testsuite/gas/ppc/cell.d b/gas/testsuite/gas/ppc/cell.d
index 799a8e0..ca1db2b 100644
--- a/gas/testsuite/gas/ppc/cell.d
+++ b/gas/testsuite/gas/ppc/cell.d
@@ -1,6 +1,6 @@
#as: -mcell
#objdump: -dr -Mcell
-#name: Cell tests
+#name: Cell tests (includes Altivec)
.*: +file format elf(32)?(64)?-powerpc.*
@@ -8,7 +8,7 @@
Disassembly of section \.text:
-0000000000000000 <.text>:
+0+00 <.text>:
0: 7c 01 14 0e lvlx v0,r1,r2
4: 7c 00 14 0e lvlx v0,0,r2
8: 7c 01 16 0e lvlxl v0,r1,r2
@@ -29,3 +29,9 @@ Disassembly of section \.text:
44: 7c 01 14 28 ldbrx r0,r1,r2
48: 7c 00 0d 28 stdbrx r0,0,r1
4c: 7c 01 15 28 stdbrx r0,r1,r2
+ 50: 7c 60 06 6c dss 3
+ 54: 7e 00 06 6c dssall
+ 58: 7c 25 22 ac dst r5,r4,1
+ 5c: 7e 08 3a ac dstt r8,r7,0
+ 60: 7c 65 32 ec dstst r5,r6,3
+ 64: 7e 44 2a ec dststt r4,r5,2
diff --git a/gas/testsuite/gas/ppc/cell.s b/gas/testsuite/gas/ppc/cell.s
index 2985386..681364c 100644
--- a/gas/testsuite/gas/ppc/cell.s
+++ b/gas/testsuite/gas/ppc/cell.s
@@ -22,3 +22,10 @@
stdbrx %r0, 0, %r1
stdbrx %r0, %r1, %r2
+
+ dss 3
+ dssall
+ dst 5,4,1
+ dstt 8,7,0
+ dstst 5,6,3
+ dststt 4,5,2
diff --git a/gas/testsuite/gas/ppc/power6.d b/gas/testsuite/gas/ppc/power6.d
new file mode 100644
index 0000000..2048823
--- /dev/null
+++ b/gas/testsuite/gas/ppc/power6.d
@@ -0,0 +1,31 @@
+#as: -a32 -mpower6
+#objdump: -dr -Mpower6
+#name: POWER6 tests (includes DFP and Altivec)
+
+.*: +file format elf32-powerpc.*
+
+Disassembly of section \.text:
+
+0+00 <start>:
+ 0: 4c 00 03 24 doze
+ 4: 4c 00 03 64 nap
+ 8: 4c 00 03 a4 sleep
+ c: 4c 00 03 e4 rvwinkle
+ 10: 7c 83 01 34 prtyw r3,r4
+ 14: 7d cd 01 74 prtyd r13,r14
+ 18: 7d 5c 02 a6 mfcfar r10
+ 1c: 7d 7c 03 a6 mtcfar r11
+ 20: 7c 83 2b f8 cmpb r3,r4,r5
+ 24: 7c c0 3c be mffgpr f6,r7
+ 28: 7d 00 4d be mftgpr r8,f9
+ 2c: 7d 4b 66 2a lwzcix r10,r11,r12
+ 30: 7d ae 7e 2e lfdpx f13,r14,r15
+ 34: ee 11 90 04 dadd f16,f17,f18
+ 38: fe 96 c0 04 daddq f20,f22,f24
+ 3c: 7c 60 06 6c dss 3
+ 40: 7e 00 06 6c dssall
+ 44: 7c 25 22 ac dst r5,r4,1
+ 48: 7e 08 3a ac dstt r8,r7,0
+ 4c: 7c 65 32 ec dstst r5,r6,3
+ 50: 7e 44 2a ec dststt r4,r5,2
+
diff --git a/gas/testsuite/gas/ppc/power6.s b/gas/testsuite/gas/ppc/power6.s
new file mode 100644
index 0000000..30cb7ef
--- /dev/null
+++ b/gas/testsuite/gas/ppc/power6.s
@@ -0,0 +1,25 @@
+# PowerPC POWER6 AltiVec tests
+#as: -mpower6
+ .section ".text"
+start:
+ doze
+ nap
+ sleep
+ rvwinkle
+ prtyw 3,4
+ prtyd 13,14
+ mfcfar 10
+ mtcfar 11
+ cmpb 3,4,5
+ mffgpr 6,7
+ mftgpr 8,9
+ lwzcix 10,11,12
+ lfdpx 13,14,15
+ dadd 16,17,18
+ daddq 20,22,24
+ dss 3
+ dssall
+ dst 5,4,1
+ dstt 8,7,0
+ dstst 5,6,3
+ dststt 4,5,2
diff --git a/gas/testsuite/gas/ppc/ppc.exp b/gas/testsuite/gas/ppc/ppc.exp
index 9db2401..595e79c 100644
--- a/gas/testsuite/gas/ppc/ppc.exp
+++ b/gas/testsuite/gas/ppc/ppc.exp
@@ -11,7 +11,6 @@ if { [istarget powerpc64*-*-*] || [istarget *-*-elf64*]} then {
run_dump_test "astest2_64"
run_dump_test "test1elf64"
run_dump_test "power4"
- run_dump_test "cell"
run_list_test "range64" "-a64"
} elseif { [istarget powerpc*-*aix*] } then {
run_dump_test "test1xcoff32"
@@ -45,5 +44,7 @@ if { [istarget powerpc*-*-*] } then {
run_list_test "range" "-a32"
run_dump_test "ppc750ps"
run_dump_test "e500mc"
+ run_dump_test "cell"
+ run_dump_test "power6"
}
}