aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sim/testsuite/sky/ChangeLog5
-rw-r--r--sim/testsuite/sky/t-pke3.trc103
2 files changed, 107 insertions, 1 deletions
diff --git a/sim/testsuite/sky/ChangeLog b/sim/testsuite/sky/ChangeLog
index a65207c..d2de9e0 100644
--- a/sim/testsuite/sky/ChangeLog
+++ b/sim/testsuite/sky/ChangeLog
@@ -1,3 +1,8 @@
+Wed Feb 25 14:24:04 1998 Frank Ch. Eigler <fche@cygnus.com>
+
+ * t-pke3.trc: Added tests for PKEcode[i] stalling and masking,
+ FBRST register STP and STC, erroneous register accesses.
+
Tue Feb 24 19:32:10 1998 Frank Ch. Eigler <fche@cygnus.com>
* ChangeLog, Makefile.in, configure, configure.in, t-pke1.trc,
diff --git a/sim/testsuite/sky/t-pke3.trc b/sim/testsuite/sky/t-pke3.trc
index 318cf74..4dd3711 100644
--- a/sim/testsuite/sky/t-pke3.trc
+++ b/sim/testsuite/sky/t-pke3.trc
@@ -88,7 +88,7 @@
? 0x10003830 0x00001234 0xffffffff
#
#
-# ---- ERROR/ER1 ----
+# ---- bad PKEcode/ER1, interrupts ----
#
# A bad PKEcode
1 0x00000000_00000000_00000000_08000000 0x00000000 PPPP
@@ -101,6 +101,35 @@
! 0x10003c10 0x00000001
# Read STAT register; confirm ER1 no longer set
? 0x10003c00 0x00000000 0x00002000
+#
+# Mask ME1 (ER1 stall) this time
+! 0x10003c20 0x00000004
+# A bad PKEcode with ER1 masked
+1 0x00000000_00000000_00000000_08000000 0x00000000 PPPP
+# should not put PKE into stalled mode, should execute following PKENOPs
+# Read STAT register; confirm ER1 bit set
+? 0x10003c00 0x00002000 0x00002000
+# Read CODE register; confirm PKE went past bad code
+? 0x10003c80 0x00000000 0xffffffff
+# Reset PKE
+! 0x10003c10 0x00000001
+# Read STAT register; confirm ER1 no longer set
+? 0x10003c00 0x00000000 0x00002000
+#
+#
+# A good PKEcode (STMOD) with interrupt
+1 0x00000000_00000000_00000000_85000000 0x00000000 PPPP
+# should put PKE into stalled mode, not executing following PKENOPs
+# Read STAT register; confirm PIS & INT bits set
+? 0x10003c00 0x00000c00 0x00000c00
+# Read CODE register; confirm PKE is stuck at bad code
+? 0x10003c80 0x85000000 0xffffffff
+# Resume PKE with STC
+! 0x10003c10 0x00000008
+# Read STAT register; confirm PIS & INT no longer set
+? 0x10003c00 0x00000000 0x00000c00
+# Read CODE register; confirm PKE executed trailing no-ops
+? 0x10003c80 0x00000000 0xffffffff
#
#
# ---- STMASK/MASK ----
@@ -304,6 +333,37 @@
# Read STAT register; confirm ER1 not set
? 0x10003800 0x00000000 0x00002000
#
+# Try stopping using STP bit this time
+# Test STCOL instruction; leave operand out for now
+1 0x31000000_00000000_00000000_00000000 0x00000000 PPPP
+# Read STAT register; confirm PPS field set at WAIT
+? 0x10003c00 0x00000001 0x00000003
+# Stop PKE after current instruction with STP bit
+! 0x10003c10 0x00000004
+# Supply operand - four words
+1 0x1234abcd_2345bcde_5432dcba_76543210 0x00000000 ....
+# Check column registers for value
+? 0x10003d40 0x76543210 0xffffffff
+? 0x10003d50 0x5432dcba 0xffffffff
+? 0x10003d60 0x2345bcde 0xffffffff
+? 0x10003d70 0x1234abcd 0xffffffff
+# Now send a new instruction with operands; this should stall
+1 0x31000000_00000000_00000000_00000000 0x00000000 PPPP
+1 0x11111111_22222222_33333333_44444444 0x00000000 ....
+# Confirm that PKE is continuing to stall due to PSS
+? 0x10003c00 0x00000100 0x00000100
+? 0x10003c00 0x00000100 0x00000100
+? 0x10003c00 0x00000100 0x00000100
+# Resume PKE with STC bit; it should process pent-up STCOL
+! 0x10003c10 0x00000008
+# Check column registers for value
+? 0x10003d40 0x44444444 0xffffffff
+? 0x10003d50 0x33333333 0xffffffff
+? 0x10003d60 0x22222222 0xffffffff
+? 0x10003d70 0x11111111 0xffffffff
+# Read STAT register; confirm ER1 not set
+? 0x10003c00 0x00000000 0x00002000
+#
#
# ---- MSKPATH3 ----
#
@@ -331,3 +391,44 @@
? 0x10005008 0x00000000 0xffffffff
? 0x1000500c 0x00000000 0xffffffff
#
+# Erroneously read PKE1-only registers on PKE0
+? 0x100038a0 0x00000000 0xffffffff
+? 0x100038b0 0x00000000 0xffffffff
+? 0x100038c0 0x00000000 0xffffffff
+? 0x100038e0 0x00000000 0xffffffff
+? 0x100038f0 0x00000000 0xffffffff
+#
+# Erroneously write PKE1-only registers on PKE0
+! 0x100038a0 0x00000000
+! 0x100038b0 0x00000000
+! 0x100038c0 0x00000000
+! 0x100038e0 0x00000000
+! 0x100038f0 0x00000000
+#
+# Erroneously read write-only registers
+? 0x10003810 0x00000000 0xffffffff
+? 0x10003c10 0x00000000 0xffffffff
+#
+# Erroneously write read-only registers
+! 0x10003c00 0x00000000
+! 0x10003c40 0x00000000
+! 0x10003c50 0x00000000
+! 0x10003c60 0x00000000
+! 0x10003c70 0x00000000
+! 0x10003c80 0x00000000
+! 0x10003c90 0x00000000
+! 0x10003ca0 0x00000000
+! 0x10003cb0 0x00000000
+! 0x10003cc0 0x00000000
+! 0x10003cd0 0x00000000
+! 0x10003ce0 0x00000000
+! 0x10003cf0 0x00000000
+! 0x10003d00 0x00000000
+! 0x10003d10 0x00000000
+! 0x10003d20 0x00000000
+! 0x10003d30 0x00000000
+! 0x10003d40 0x00000000
+! 0x10003d50 0x00000000
+! 0x10003d60 0x00000000
+! 0x10003d70 0x00000000
+# \ No newline at end of file