rsp_regr_vu_mul.c
2.66 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include <sys/types.h>
#ifdef __sgi__
#include <sys/sbd.h>
#endif
#include <sys/stat.h>
#include <sys/mman.h>
#ifdef __sgi__
#include <sys/sema.h>
#endif
#include <netinet/in.h>
#include <errno.h>
#include <stdio.h>
#include <fcntl.h>
#include <stdlib.h>
#include <getopt.h>
#include <rcp.h>
#include <rsp.h>
/* From $ROOT/usr/include/ide, which is installed from PR/diags/include */
#include "diag.h"
#include "dbg_comm.h"
#define RSP_TEST_BASE 001
static int NumFailures = 0;
/* From rsp_regr_common.c: */
extern int generic_rsp_regression (const char *file_name);
extern void imem_init(FILE *file_p);
extern int rsp_regrInit();
extern int rsp_regrDo(TEST_REF *test_ref);
extern int rsp_regr(TEST_REF TestRefs[]);
int vmulf_h();
int vmulf_q();
int vmulf_v();
int vmulf_v1();
int vmulf_w();
int vmulq_v();
int vmulu_h();
int vmulu_q();
int vmulu_v();
int vmulu_v1();
int vmulu_w();
/*
* An array of tests, each of which corresponds to a separate menu
* item callable from the master ide menu.
*/
static TEST_REF TestRefs[] = {
{"vmulf_h", RSP_TEST_BASE+0, vmulf_h},
{"vmulf_q", RSP_TEST_BASE+1, vmulf_q},
{"vmulf_v", RSP_TEST_BASE+2, vmulf_v},
{"vmulf_v1", RSP_TEST_BASE+3, vmulf_v1},
{"vmulf_w", RSP_TEST_BASE+4, vmulf_w},
{"vmulq_v", RSP_TEST_BASE+5, vmulq_v},
{"vmulu_h", RSP_TEST_BASE+6, vmulu_h},
{"vmulu_q", RSP_TEST_BASE+7, vmulu_q},
{"vmulu_v", RSP_TEST_BASE+8, vmulu_v},
{"vmulu_v1", RSP_TEST_BASE+9, vmulu_v1},
{"vmulu_w", RSP_TEST_BASE+10, vmulu_w},
{"",0,0}
};
static int failed_tests[512];
/*
* diagnostic entry point:
*
* Each separately invokable ide diagnostic command corresponds to an
* independent ".c" module; the entry point herein must match
* the test name as specified in the rspcmd.awk script. These command
* names correspond to the names you see from the ide menu. For this
* module, there will be an ide command "rsp_regr".
*/
int rsp_regr_vu_mul(void) {rsp_regr(TestRefs);}
/*
* Tests
*/
int vmulf_h() {return generic_rsp_regression("tests/vmulf_h");}
int vmulf_q() {return generic_rsp_regression("tests/vmulf_q");}
int vmulf_v() {return generic_rsp_regression("tests/vmulf_v");}
int vmulf_v1() {return generic_rsp_regression("tests/vmulf_v1");}
int vmulf_w() {return generic_rsp_regression("tests/vmulf_w");}
int vmulq_v() {return generic_rsp_regression("tests/vmulq_v");}
int vmulu_h() {return generic_rsp_regression("tests/vmulu_h");}
int vmulu_q() {return generic_rsp_regression("tests/vmulu_q");}
int vmulu_v() {return generic_rsp_regression("tests/vmulu_v");}
int vmulu_v1() {return generic_rsp_regression("tests/vmulu_v1");}
int vmulu_w() {return generic_rsp_regression("tests/vmulu_w");}