OpenCores
URL https://opencores.org/ocsvn/mips_enhanced/mips_enhanced/trunk

Subversion Repositories mips_enhanced

[/] [mips_enhanced/] [trunk/] [grlib-gpl-1.0.19-b3188/] [software/] [leon3/] [mptest.c] - Blame information for rev 2

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 dimamali
#include "testmod.h"
2
 
3
asm(
4
"       .text\n"
5
"       .align 4\n"
6
"       .global get_pid\n"
7
 
8
"get_sem:\n"
9
"       set  mpsem, %o1\n"
10
"       set  0, %o0\n"
11
"       retl\n"
12
"       ldstuba [%o1] 1, %o0 \n"
13
/*"     swapa [%o1] 1, %o0 \n"*/
14
 
15
"ret_sem:\n"
16
/*"     set 1, %o0 \n" */
17
"       set 0, %o0 \n"
18
"       set mpsem, %o1\n"
19
"       retl\n"
20
"       st  %o0, [%o1]          \n"
21
 
22
"get_pid:\n"
23
"        mov  %asr17, %o0\n"
24
"        srl  %o0, 28, %o0\n"
25
"        retl\n"
26
"        and %o0, 0xf, %o0\n"
27
 
28
"mread: retl\n"
29
"        lda  [%o0] 1, %o0\n"
30
 
31
"getccfg: set 0xc, %o0\n"
32
"         retl\n"
33
"         lda [%o0] 2, %o0\n"
34
 
35
"       .data\n"
36
"       .align 4\n"
37
"       .global mpsem\n"
38
/*"mpsem:       .word 1\n"*/
39
"mpsem: .word 0\n"
40
 
41
);
42
 
43
#define MPLOOPS 10
44
 
45
volatile int cnt = 0;
46
 
47
volatile int pstart[17] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1};
48
volatile int pdone[17] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1};
49
volatile int pindex[17] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1};
50
 
51
 
52
static int absl(int a, int b)
53
{
54
  if (a > b)
55
    return(a-b);
56
  else
57
    return(b-a);
58
}
59
 
60
static void psync(volatile int arr[], int n, int ncpu)
61
{
62
  int i, go;
63
 
64
  arr[n] = 1;
65
  do {
66
    go = 1;
67
    for (i = 0; i < ncpu; i++)
68
      if (!arr[i]) go = 0;
69
  } while (!go);
70
}
71
 
72
int mptest(volatile int *irqmp_ptr)
73
{
74
  int id, i, sem, ncpu;
75
  unsigned int ccfg;
76
 
77
  ncpu = (((*(irqmp_ptr + 0x10/4)) >> 28) & 0x0f) + 1;
78
  if (ncpu == 1) return(-1);
79
 
80
  id = get_pid();
81
  report_subtest(MP_TEST + (id <<4));
82
  ccfg = getccfg();
83
  if (!((ccfg >> 27) & 1)) fail(1);
84
 
85
 
86
  *(irqmp_ptr + 0x10/4) = (1 << (id+1));
87
 
88
  psync(pstart, id, ncpu);
89
 
90
  for (pindex[id] = 0; pindex[id] < MPLOOPS; pindex[id]++)
91
  {
92
//    do {sem = get_sem();} while (!sem);
93
    do {sem = get_sem();} while (sem);
94
    for (i = 0; i < ncpu; i++)
95
    {
96
      if (absl(pindex[id], pindex[i]) > 1) fail(2);
97
    }
98
    cnt++;
99
    ret_sem();
100
  }
101
 
102
  psync(pdone, id, ncpu);
103
  if (cnt != (MPLOOPS*ncpu)) fail(3);
104
  if ((cnt <= 0) || (cnt > (MPLOOPS*ncpu))) fail(3);
105
 
106
  if (id != 0) asm("ta 0");
107
  return(0);
108
 
109
}
110
 
111
 
112
 
113
 
114
int mptest_start(volatile int *irqmp_ptr)
115
{
116
  int id, i, sem, ncpu;
117
  unsigned int ccfg;
118
 
119
  ncpu = (((*(irqmp_ptr + 0x10/4)) >> 28) & 0x0f) + 1;
120
  if (ncpu == 1) return(-1);
121
 
122
  id = get_pid();
123
 
124
  if (id == 0) {
125
    *(irqmp_ptr + 0x10/4) = 0x0ffff;
126
  }
127
}
128
 
129
int mptest_end(volatile int *irqmp_ptr)
130
{
131
  int id, i, sem, ncpu;
132
  unsigned int ccfg;
133
 
134
  ncpu = (((*(irqmp_ptr + 0x10/4)) >> 28) & 0x0f) + 1;
135
  if (ncpu == 1) return(-1);
136
 
137
  id = get_pid();
138
  report_subtest(MP_TEST + (id << 4));
139
  ccfg = getccfg();
140
  if (!((ccfg >> 27) & 1)) fail(1);
141
 
142
 
143
  psync(pstart, id, ncpu);
144
 
145
  for (pindex[id] = 0; pindex[id] < MPLOOPS; pindex[id]++)
146
  {
147
//    do {sem = get_sem();} while (!sem);
148
    do {sem = get_sem();} while (sem);
149
    for (i = 0; i < ncpu; i++)
150
    {
151
      if (absl(pindex[id], pindex[i]) > 1) fail(2);
152
    }
153
    cnt++;
154
    ret_sem();
155
  }
156
 
157
  psync(pdone, id, ncpu);
158
  if (cnt != (MPLOOPS*ncpu)) fail(3);
159
  if ((cnt <= 0) || (cnt > (MPLOOPS*ncpu))) fail(3);
160
 
161
  if (id != 0) asm("ta 0");
162
  return(0);
163
 
164
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.