aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFrank Ch. Eigler <fche@redhat.com>1998-04-20 22:59:16 +0000
committerFrank Ch. Eigler <fche@redhat.com>1998-04-20 22:59:16 +0000
commitf61321eaaf040dd9213c5031e41548f7071cd195 (patch)
tree417e84b6400ecf5739f5f302b142260821aa61c6
parentfa89ee43a5e0b1335406384395bc20dea31bc04d (diff)
downloadgdb-f61321eaaf040dd9213c5031e41548f7071cd195.zip
gdb-f61321eaaf040dd9213c5031e41548f7071cd195.tar.gz
gdb-f61321eaaf040dd9213c5031e41548f7071cd195.tar.bz2
* Added one new R5900 COP2 test.
Mon Apr 20 18:36:50 1998 Frank Ch. Eigler <fche@cygnus.com> * t-cop2b.c (test01): Additional COP2 tests (QMFC2/QMTC2/LQ/SQ). Don't use $1 ($at) register in inline assembly.
-rw-r--r--sim/testsuite/sky/ChangeLog5
-rw-r--r--sim/testsuite/sky/t-cop2b.c64
2 files changed, 64 insertions, 5 deletions
diff --git a/sim/testsuite/sky/ChangeLog b/sim/testsuite/sky/ChangeLog
index b27ccc1..8f22c01 100644
--- a/sim/testsuite/sky/ChangeLog
+++ b/sim/testsuite/sky/ChangeLog
@@ -1,3 +1,8 @@
+Mon Apr 20 18:36:50 1998 Frank Ch. Eigler <fche@cygnus.com>
+
+ * t-cop2b.c (test01): Additional COP2 tests (QMFC2/QMTC2/LQ/SQ).
+ Don't use $1 ($at) register in inline assembly.
+
Mon Apr 20 19:05:41 1998 Jillian Ye <jillian@cygnus.com>
* t-pke2.trc t-pke2.vif1expect : Update the testcase
diff --git a/sim/testsuite/sky/t-cop2b.c b/sim/testsuite/sky/t-cop2b.c
index 7d3d6f4..f761d31 100644
--- a/sim/testsuite/sky/t-cop2b.c
+++ b/sim/testsuite/sky/t-cop2b.c
@@ -31,12 +31,10 @@ void do_test(int ok, const char* test, int line);
void
enable_cop2()
{
- asm volatile (".set noat");
- asm volatile ("mfc0 $1,$12; dli $2,0x40000000; or $1,$2,$2; mtc0 $1,$12"
+ asm volatile ("mfc0 $3,$12; dli $2,0x40000000; or $3,$2,$2; mtc0 $3,$12"
: /* no outputs */
: /* no inputs */
- : "$1", "$2" /* clobbered */);
- asm volatile (".set at");
+ : "$3", "$2" /* clobbered */);
}
@@ -45,7 +43,7 @@ do_test(int ok, const char* test, int line)
{
static int test_num = 0;
- printf("[%d @ %d] (%s): ", ++test_num, line, test);
+ printf("[%3d @ %3d] (%s): ", ++test_num, line, test);
if(ok)
{
num_ok ++;
@@ -116,6 +114,61 @@ void test00()
+/* test01: test QMFC2/QMTC2 data non-corruption */
+void test01()
+{
+ volatile float* data = & data_array[0];
+ volatile float* data2 = & data_array[4];
+
+ /* stuff some initial values */
+ data[0] = -10.0;
+ data[1] = +10.0;
+ data[2] = -20.0;
+ data[3] = +20.0;
+
+ /* save values */
+ asm volatile ("lq $4,%0; qmtc2 $4,vf01"
+ : /* no output */
+ : "m" (data[0]) /* input */
+ : "$4", "memory" /* clobbered */);
+
+ /* test no clobbering */
+ TEST(data[0] == -10.0f);
+ TEST(data[1] == +10.0f);
+ TEST(data[2] == -20.0f);
+ TEST(data[3] == +20.0f);
+
+ /* overwrite with VU constants */
+ asm volatile ("qmfc2 $4,vf00; sq $4,%0"
+ : /* no outputs */
+ : "m" (data[0]) /* input */
+ : "$4", "memory" /* clobbered */);
+
+ /* test proper values */
+ TEST(data[0] == 0.0f);
+ TEST(data[1] == 0.5f);
+ TEST(data[2] == -1.0f);
+ TEST(data[3] == +1.0f);
+
+ /* read back original array values */
+ asm volatile ("qmfc2 $4,vf01; sq $4,%0"
+ : /* no outputs */
+ : "m" (data2[0]) /* input */
+ : "$4", "memory" /* clobbered */);
+
+ /* printf("%f,%f,%f,%f\n", data2[0], data2[1], data2[2], data2[3]); */
+
+ /* test proper values */
+ TEST(data2[0] == -10.0f);
+ TEST(data2[1] == +10.0f);
+ TEST(data2[2] == -20.0f);
+ TEST(data2[3] == +20.0f);
+}
+
+
+
+
+
/* Mainline */
@@ -125,6 +178,7 @@ int main()
/* tests */
test00();
+ test01();
/* summarize */