gem5  v20.0.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
isa.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2009 The Regents of The University of Michigan
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are
7  * met: redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer;
9  * redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution;
12  * neither the name of the copyright holders nor the names of its
13  * contributors may be used to endorse or promote products derived from
14  * this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  */
28 
29 #include "arch/sparc/isa.hh"
30 
31 #include "arch/sparc/asi.hh"
32 #include "arch/sparc/decoder.hh"
33 #include "arch/sparc/interrupts.hh"
34 #include "base/bitfield.hh"
35 #include "base/trace.hh"
36 #include "cpu/base.hh"
37 #include "cpu/thread_context.hh"
38 #include "debug/MiscRegs.hh"
39 #include "debug/Timer.hh"
40 #include "params/SparcISA.hh"
41 
42 namespace SparcISA
43 {
44 
45 static PSTATE
47 {
48  PSTATE mask = 0;
49  mask.ie = 1;
50  mask.priv = 1;
51  mask.am = 1;
52  mask.pef = 1;
53  mask.mm = 3;
54  mask.tle = 1;
55  mask.cle = 1;
56  mask.pid1 = 1;
57  return mask;
58 }
59 
60 static const PSTATE PstateMask = buildPstateMask();
61 
63 {
64  tickCompare = NULL;
65  sTickCompare = NULL;
66  hSTickCompare = NULL;
67 
68  clear();
69 }
70 
71 const SparcISAParams *
72 ISA::params() const
73 {
74  return dynamic_cast<const Params *>(_params);
75 }
76 
77 void
79 {
82  // Microcode registers.
83  for (int i = 0; i < NumMicroIntRegs; i++)
89 }
90 
91 void
93 {
94  assert(offset >= 0 && offset + NumWindowedRegs <= NumIntRegs);
95  RegIndex *mapChunk = intRegMap + offset;
96  for (int i = 0; i < NumWindowedRegs; i++)
97  mapChunk[i] = TotalGlobals +
98  ((i - cwp * RegsPerWindow + TotalWindowed) % (TotalWindowed));
99 }
100 
101 void
103 {
104  assert(offset >= 0 && offset + NumGlobalRegs <= NumIntRegs);
105  RegIndex *mapChunk = intRegMap + offset;
106  mapChunk[0] = 0;
107  for (int i = 1; i < NumGlobalRegs; i++)
108  mapChunk[i] = i + gl * NumGlobalRegs;
109 }
110 
111 void
113 {
114  cwp = 0;
115  gl = 0;
116  reloadRegMap();
117 
118  // y = 0;
119  // ccr = 0;
120  asi = 0;
121  tick = ULL(1) << 63;
122  fprs = 0;
123  gsr = 0;
124  softint = 0;
125  tick_cmpr = 0;
126  stick = 0;
127  stick_cmpr = 0;
128  memset(tpc, 0, sizeof(tpc));
129  memset(tnpc, 0, sizeof(tnpc));
130  memset(tstate, 0, sizeof(tstate));
131  memset(tt, 0, sizeof(tt));
132  tba = 0;
133  pstate = 0;
134  tl = 0;
135  pil = 0;
136  // cansave = 0;
137  // canrestore = 0;
138  // cleanwin = 0;
139  // otherwin = 0;
140  // wstate = 0;
141  // In a T1, bit 11 is apparently always 1
142  hpstate = 0;
143  hpstate.id = 1;
144  memset(htstate, 0, sizeof(htstate));
145  hintp = 0;
146  htba = 0;
147  hstick_cmpr = 0;
148  // This is set this way in Legion for some reason
149  strandStatusReg = 0x50000;
150  fsr = 0;
151 
152  priContext = 0;
153  secContext = 0;
154  partId = 0;
155  lsuCtrlReg = 0;
156 
157  memset(scratchPad, 0, sizeof(scratchPad));
158 
159  cpu_mondo_head = 0;
160  cpu_mondo_tail = 0;
161  dev_mondo_head = 0;
162  dev_mondo_tail = 0;
163  res_error_head = 0;
164  res_error_tail = 0;
165  nres_error_head = 0;
166  nres_error_tail = 0;
167 
168  // If one of these events is active, it's not obvious to me how to get
169  // rid of it cleanly. For now we'll just assert that they're not.
170  if (tickCompare != NULL && sTickCompare != NULL && hSTickCompare != NULL)
171  panic("Tick comparison event active when clearing the ISA object.\n");
172 }
173 
174 RegVal
175 ISA::readMiscRegNoEffect(int miscReg) const
176 {
177 
178  // The three miscRegs are moved up from the switch statement
179  // due to more frequent calls.
180 
181  if (miscReg == MISCREG_GL)
182  return gl;
183  if (miscReg == MISCREG_CWP)
184  return cwp;
185  if (miscReg == MISCREG_TLB_DATA) {
186  /* Package up all the data for the tlb:
187  * 6666555555555544444444443333333333222222222211111111110000000000
188  * 3210987654321098765432109876543210987654321098765432109876543210
189  * secContext | priContext | |tl|partid| |||||^hpriv
190  * ||||^red
191  * |||^priv
192  * ||^am
193  * |^lsuim
194  * ^lsudm
195  */
196  return (uint64_t)hpstate.hpriv |
197  (uint64_t)hpstate.red << 1 |
198  (uint64_t)pstate.priv << 2 |
199  (uint64_t)pstate.am << 3 |
200  bits((uint64_t)lsuCtrlReg,3,2) << 4 |
201  bits((uint64_t)partId,7,0) << 8 |
202  bits((uint64_t)tl,2,0) << 16 |
203  (uint64_t)priContext << 32 |
204  (uint64_t)secContext << 48;
205  }
206 
207  switch (miscReg) {
208  // case MISCREG_TLB_DATA:
209  // [original contents see above]
210  // case MISCREG_Y:
211  // return y;
212  // case MISCREG_CCR:
213  // return ccr;
214  case MISCREG_ASI:
215  return asi;
216  case MISCREG_FPRS:
217  return fprs;
218  case MISCREG_TICK:
219  return tick;
220  case MISCREG_PCR:
221  panic("PCR not implemented\n");
222  case MISCREG_PIC:
223  panic("PIC not implemented\n");
224  case MISCREG_GSR:
225  return gsr;
226  case MISCREG_SOFTINT:
227  return softint;
228  case MISCREG_TICK_CMPR:
229  return tick_cmpr;
230  case MISCREG_STICK:
231  return stick;
232  case MISCREG_STICK_CMPR:
233  return stick_cmpr;
234 
236  case MISCREG_TPC:
237  return tpc[tl-1];
238  case MISCREG_TNPC:
239  return tnpc[tl-1];
240  case MISCREG_TSTATE:
241  return tstate[tl-1];
242  case MISCREG_TT:
243  return tt[tl-1];
244  case MISCREG_PRIVTICK:
245  panic("Priviliged access to tick registers not implemented\n");
246  case MISCREG_TBA:
247  return tba;
248  case MISCREG_PSTATE:
249  return (RegVal)pstate;
250  case MISCREG_TL:
251  return tl;
252  case MISCREG_PIL:
253  return pil;
254  // CWP, GL moved
255  // case MISCREG_CWP:
256  // return cwp;
257  // case MISCREG_CANSAVE:
258  // return cansave;
259  // case MISCREG_CANRESTORE:
260  // return canrestore;
261  // case MISCREG_CLEANWIN:
262  // return cleanwin;
263  // case MISCREG_OTHERWIN:
264  // return otherwin;
265  // case MISCREG_WSTATE:
266  // return wstate;
267  // case MISCREG_GL:
268  // return gl;
269 
271  case MISCREG_HPSTATE:
272  return (RegVal)hpstate;
273  case MISCREG_HTSTATE:
274  return htstate[tl-1];
275  case MISCREG_HINTP:
276  return hintp;
277  case MISCREG_HTBA:
278  return htba;
280  return strandStatusReg;
281  case MISCREG_HSTICK_CMPR:
282  return hstick_cmpr;
283 
285  case MISCREG_FSR:
286  DPRINTF(MiscRegs, "FSR read as: %#x\n", fsr);
287  return fsr;
288 
290  return priContext;
292  return secContext;
293  case MISCREG_MMU_PART_ID:
294  return partId;
296  return lsuCtrlReg;
297 
299  return scratchPad[0];
301  return scratchPad[1];
303  return scratchPad[2];
305  return scratchPad[3];
307  return scratchPad[4];
309  return scratchPad[5];
311  return scratchPad[6];
313  return scratchPad[7];
315  return cpu_mondo_head;
317  return cpu_mondo_tail;
319  return dev_mondo_head;
321  return dev_mondo_tail;
323  return res_error_head;
325  return res_error_tail;
327  return nres_error_head;
329  return nres_error_tail;
330  default:
331  panic("Miscellaneous register %d not implemented\n", miscReg);
332  }
333 }
334 
335 RegVal
336 ISA::readMiscReg(int miscReg, ThreadContext * tc)
337 {
338  switch (miscReg) {
339  // tick and stick are aliased to each other in niagra
340  // well store the tick data in stick and the interrupt bit in tick
341  case MISCREG_STICK:
342  case MISCREG_TICK:
343  case MISCREG_PRIVTICK:
344  // I'm not sure why legion ignores the lowest two bits, but we'll go
345  // with it
346  // change from curCycle() to instCount() until we're done with legion
347  DPRINTF(Timer, "Instruction Count when TICK read: %#X stick=%#X\n",
348  tc->getCpuPtr()->instCount(), stick);
349  return mbits(tc->getCpuPtr()->instCount() + (int64_t)stick,62,2) |
350  mbits(tick,63,63);
351  case MISCREG_FPRS:
352  // in legion if fp is enabled du and dl are set
353  return fprs | 0x3;
354  case MISCREG_PCR:
355  case MISCREG_PIC:
356  panic("Performance Instrumentation not impl\n");
357  case MISCREG_SOFTINT_CLR:
358  case MISCREG_SOFTINT_SET:
359  panic("Can read from softint clr/set\n");
360  case MISCREG_SOFTINT:
361  case MISCREG_TICK_CMPR:
362  case MISCREG_STICK_CMPR:
363  case MISCREG_HINTP:
364  case MISCREG_HTSTATE:
365  case MISCREG_HTBA:
366  case MISCREG_HVER:
368  case MISCREG_HSTICK_CMPR:
377  case MISCREG_HPSTATE:
378  return readFSReg(miscReg, tc);
379  }
380  return readMiscRegNoEffect(miscReg);
381 }
382 
383 void
385 {
386  switch (miscReg) {
387 // case MISCREG_Y:
388 // y = val;
389 // break;
390 // case MISCREG_CCR:
391 // ccr = val;
392 // break;
393  case MISCREG_ASI:
394  asi = val;
395  break;
396  case MISCREG_FPRS:
397  fprs = val;
398  break;
399  case MISCREG_TICK:
400  tick = val;
401  break;
402  case MISCREG_PCR:
403  panic("PCR not implemented\n");
404  case MISCREG_PIC:
405  panic("PIC not implemented\n");
406  case MISCREG_GSR:
407  gsr = val;
408  break;
409  case MISCREG_SOFTINT:
410  softint = val;
411  break;
412  case MISCREG_TICK_CMPR:
413  tick_cmpr = val;
414  break;
415  case MISCREG_STICK:
416  stick = val;
417  break;
418  case MISCREG_STICK_CMPR:
419  stick_cmpr = val;
420  break;
421 
423  case MISCREG_TPC:
424  tpc[tl-1] = val;
425  break;
426  case MISCREG_TNPC:
427  tnpc[tl-1] = val;
428  break;
429  case MISCREG_TSTATE:
430  tstate[tl-1] = val;
431  break;
432  case MISCREG_TT:
433  tt[tl-1] = val;
434  break;
435  case MISCREG_PRIVTICK:
436  panic("Priviliged access to tick regesiters not implemented\n");
437  case MISCREG_TBA:
438  // clear lower 7 bits on writes.
439  tba = val & ULL(~0x7FFF);
440  break;
441  case MISCREG_PSTATE:
442  pstate = (val & PstateMask);
443  break;
444  case MISCREG_TL:
445  tl = val;
446  break;
447  case MISCREG_PIL:
448  pil = val;
449  break;
450  case MISCREG_CWP:
451  cwp = val;
452  break;
453 // case MISCREG_CANSAVE:
454 // cansave = val;
455 // break;
456 // case MISCREG_CANRESTORE:
457 // canrestore = val;
458 // break;
459 // case MISCREG_CLEANWIN:
460 // cleanwin = val;
461 // break;
462 // case MISCREG_OTHERWIN:
463 // otherwin = val;
464 // break;
465 // case MISCREG_WSTATE:
466 // wstate = val;
467 // break;
468  case MISCREG_GL:
469  gl = val;
470  break;
471 
473  case MISCREG_HPSTATE:
474  hpstate = val;
475  break;
476  case MISCREG_HTSTATE:
477  htstate[tl-1] = val;
478  break;
479  case MISCREG_HINTP:
480  hintp = val;
481  break;
482  case MISCREG_HTBA:
483  htba = val;
484  break;
487  break;
488  case MISCREG_HSTICK_CMPR:
489  hstick_cmpr = val;
490  break;
491 
493  case MISCREG_FSR:
494  fsr = val;
495  DPRINTF(MiscRegs, "FSR written with: %#x\n", fsr);
496  break;
497 
499  priContext = val;
500  break;
502  secContext = val;
503  break;
504  case MISCREG_MMU_PART_ID:
505  partId = val;
506  break;
508  lsuCtrlReg = val;
509  break;
510 
512  scratchPad[0] = val;
513  break;
515  scratchPad[1] = val;
516  break;
518  scratchPad[2] = val;
519  break;
521  scratchPad[3] = val;
522  break;
524  scratchPad[4] = val;
525  break;
527  scratchPad[5] = val;
528  break;
530  scratchPad[6] = val;
531  break;
533  scratchPad[7] = val;
534  break;
537  break;
540  break;
543  break;
546  break;
549  break;
552  break;
555  break;
558  break;
559  default:
560  panic("Miscellaneous register %d not implemented\n", miscReg);
561  }
562 }
563 
564 void
566 {
567  RegVal new_val = val;
568 
569  switch (miscReg) {
570  case MISCREG_ASI:
571  tc->getDecoderPtr()->setContext(val);
572  break;
573  case MISCREG_STICK:
574  case MISCREG_TICK:
575  // stick and tick are same thing on niagra
576  // use stick for offset and tick for holding intrrupt bit
577  stick = mbits(val,62,0) - tc->getCpuPtr()->instCount();
578  tick = mbits(val,63,63);
579  DPRINTF(Timer, "Writing TICK=%#X\n", val);
580  break;
581  case MISCREG_FPRS:
582  // Configure the fpu based on the fprs
583  break;
584  case MISCREG_PCR:
585  // Set up performance counting based on pcr value
586  break;
587  case MISCREG_PSTATE:
588  pstate = val & PstateMask;
589  return;
590  case MISCREG_TL:
591  {
592  tl = val;
593  if (hpstate.tlz && tl == 0 && !hpstate.hpriv)
595  else
597  return;
598  }
599  case MISCREG_CWP:
600  new_val = val >= NWindows ? NWindows - 1 : val;
601  if (val >= NWindows)
602  new_val = NWindows - 1;
603 
605  installWindow(new_val - 1, NextWindowOffset);
606  installWindow(new_val + 1, PreviousWindowOffset);
607  break;
608  case MISCREG_GL:
612  break;
613  case MISCREG_PIL:
614  case MISCREG_SOFTINT:
615  case MISCREG_SOFTINT_SET:
616  case MISCREG_SOFTINT_CLR:
617  case MISCREG_TICK_CMPR:
618  case MISCREG_STICK_CMPR:
619  case MISCREG_HINTP:
620  case MISCREG_HTSTATE:
621  case MISCREG_HTBA:
622  case MISCREG_HVER:
624  case MISCREG_HSTICK_CMPR:
633  case MISCREG_HPSTATE:
634  setFSReg(miscReg, val, tc);
635  return;
636  }
637  setMiscRegNoEffect(miscReg, new_val);
638 }
639 
640 void
642 {
681  Tick tick_cmp = 0, stick_cmp = 0, hstick_cmp = 0;
682  ThreadContext *tc = NULL;
683  BaseCPU *cpu = NULL;
684  int tc_num = 0;
685  bool tick_intr_sched = true;
686 
687  if (tickCompare)
688  tc = tickCompare->getTC();
689  else if (sTickCompare)
690  tc = sTickCompare->getTC();
691  else if (hSTickCompare)
692  tc = hSTickCompare->getTC();
693  else
694  tick_intr_sched = false;
695 
696  SERIALIZE_SCALAR(tick_intr_sched);
697 
698  if (tc) {
699  cpu = tc->getCpuPtr();
700  tc_num = cpu->findContext(tc);
702  tick_cmp = tickCompare->when();
704  stick_cmp = sTickCompare->when();
706  hstick_cmp = hSTickCompare->when();
707 
708  SERIALIZE_OBJPTR(cpu);
709  SERIALIZE_SCALAR(tc_num);
710  SERIALIZE_SCALAR(tick_cmp);
711  SERIALIZE_SCALAR(stick_cmp);
712  SERIALIZE_SCALAR(hstick_cmp);
713  }
714 }
715 
716 void
718 {
732  {
733  uint16_t pstate;
734  UNSERIALIZE_SCALAR(pstate);
735  this->pstate = pstate;
736  }
741  reloadRegMap();
742  {
743  uint64_t hpstate;
744  UNSERIALIZE_SCALAR(hpstate);
745  this->hpstate = hpstate;
746  }
766 
767  Tick tick_cmp = 0, stick_cmp = 0, hstick_cmp = 0;
768  ThreadContext *tc = NULL;
769  BaseCPU *cpu = NULL;
770  int tc_num;
771  bool tick_intr_sched;
772  UNSERIALIZE_SCALAR(tick_intr_sched);
773  if (tick_intr_sched) {
774  UNSERIALIZE_OBJPTR(cpu);
775  if (cpu) {
776  UNSERIALIZE_SCALAR(tc_num);
777  UNSERIALIZE_SCALAR(tick_cmp);
778  UNSERIALIZE_SCALAR(stick_cmp);
779  UNSERIALIZE_SCALAR(hstick_cmp);
780  tc = cpu->getContext(tc_num);
781 
782  if (tick_cmp) {
783  tickCompare = new TickCompareEvent(this, tc);
784  schedule(tickCompare, tick_cmp);
785  }
786  if (stick_cmp) {
787  sTickCompare = new STickCompareEvent(this, tc);
788  schedule(sTickCompare, stick_cmp);
789  }
790  if (hstick_cmp) {
791  hSTickCompare = new HSTickCompareEvent(this, tc);
792  schedule(hSTickCompare, hstick_cmp);
793  }
794  }
795  }
796 
797 }
798 
799 }
800 
802 SparcISAParams::create()
803 {
804  return new SparcISA::ISA(this);
805 }
#define panic(...)
This implements a cprintf based panic() function.
Definition: logging.hh:163
RegVal readMiscRegNoEffect(int miscReg) const
Definition: isa.cc:175
#define DPRINTF(x,...)
Definition: trace.hh:225
int findContext(ThreadContext *tc)
Given a Thread Context pointer return the thread num.
Definition: base.cc:476
virtual TheISA::Decoder * getDecoderPtr()=0
uint64_t htba
Definition: isa.hh:91
void reloadRegMap()
Definition: isa.cc:78
void installGlobals(int gl, int offset)
Definition: isa.cc:102
uint64_t dev_mondo_tail
Definition: isa.hh:110
Bitfield< 7 > i
CpuEventWrapper< ISA, &ISA::processSTickCompare > STickCompareEvent
Definition: isa.hh:135
uint8_t pil
Definition: isa.hh:78
const int NumIntRegs
Definition: registers.hh:101
void serialize(CheckpointOut &cp) const override
Serialize an object.
Definition: isa.cc:641
uint64_t tnpc[MaxTL]
Definition: isa.hh:69
static const int NumWindowedRegs
Definition: isa.hh:143
#define SERIALIZE_OBJPTR(objptr)
Definition: serialize.hh:869
uint8_t cwp
Definition: isa.hh:79
uint16_t partId
Definition: isa.hh:102
void clearInterrupt(ThreadID tid, int int_num, int index)
Definition: base.hh:242
uint64_t htstate[MaxTL]
Definition: isa.hh:89
static const PSTATE PstateMask
Definition: isa.cc:60
uint64_t RegVal
Definition: types.hh:166
TickCompareEvent * tickCompare
Definition: isa.hh:132
PSTATE pstate
Definition: isa.hh:76
Bitfield< 23, 0 > offset
Definition: types.hh:152
ThreadContext * getTC()
Definition: cpuevent.hh:73
virtual BaseCPU * getCpuPtr()=0
CpuEventWrapper< ISA, &ISA::processTickCompare > TickCompareEvent
Definition: isa.hh:131
Definition: cprintf.cc:40
MMU Internal Registers.
Definition: miscregs.hh:86
uint64_t tick
Definition: isa.hh:57
uint64_t tpc[MaxTL]
Definition: isa.hh:67
RegIndex intRegMap[TotalInstIntRegs]
Definition: isa.hh:161
ThreadContext is the external interface to all thread state for anything outside of the CPU...
uint64_t nres_error_tail
Definition: isa.hh:114
uint64_t fsr
Floating point misc registers.
Definition: isa.hh:97
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Definition: isa.cc:717
uint64_t lsuCtrlReg
Definition: isa.hh:103
uint64_t tstate[MaxTL]
Definition: isa.hh:71
Bitfield< 63 > val
Definition: misc.hh:769
uint64_t hstick_cmpr
Definition: isa.hh:92
Tick instCount()
Definition: base.hh:213
#define UNSERIALIZE_SCALAR(scalar)
Definition: serialize.hh:770
static const int NumGlobalRegs
Definition: isa.hh:142
uint64_t dev_mondo_head
Definition: isa.hh:109
uint16_t RegIndex
Definition: types.hh:40
uint8_t asi
Definition: isa.hh:56
uint64_t tba
Definition: isa.hh:74
uint64_t nres_error_head
Definition: isa.hh:113
uint64_t Tick
Tick count type.
Definition: types.hh:61
Hyper privileged registers.
Definition: miscregs.hh:74
RegVal readMiscReg(int miscReg, ThreadContext *tc)
Definition: isa.cc:336
uint8_t gl
Definition: isa.hh:85
uint64_t res_error_head
Definition: isa.hh:111
HPSTATE hpstate
Hyperprivileged Registers.
Definition: isa.hh:88
CpuEventWrapper< ISA, &ISA::processHSTickCompare > HSTickCompareEvent
Definition: isa.hh:139
static PSTATE buildPstateMask()
Definition: isa.cc:46
void schedule(Event &event, Tick when)
Definition: eventq.hh:934
void setMiscReg(int miscReg, RegVal val, ThreadContext *tc)
Definition: isa.cc:565
uint64_t cpu_mondo_head
Definition: isa.hh:107
static const int RegsPerWindow
Definition: isa.hh:147
#define ULL(N)
uint64_t constant
Definition: types.hh:48
#define SERIALIZE_ARRAY(member, size)
Definition: serialize.hh:805
HSTickCompareEvent * hSTickCompare
Definition: isa.hh:140
Ancillary State Registers.
Definition: miscregs.hh:42
RegVal readFSReg(int miscReg, ThreadContext *tc)
Definition: ua2005.cc:247
#define SERIALIZE_SCALAR(scalar)
Definition: serialize.hh:763
uint16_t secContext
Definition: isa.hh:101
bool scheduled() const
Determine if the current event is scheduled.
Definition: eventq.hh:459
#define UNSERIALIZE_ARRAY(member, size)
Definition: serialize.hh:813
uint8_t fprs
Definition: isa.hh:58
uint64_t softint
Definition: isa.hh:60
const int MaxTL
Definition: sparc_traits.hh:36
std::ostream CheckpointOut
Definition: serialize.hh:63
Definition: asi.cc:31
Privilged Registers.
Definition: miscregs.hh:56
Scratchpad regiscers.
Definition: miscregs.hh:92
STickCompareEvent * sTickCompare
Definition: isa.hh:136
const SimObjectParams * _params
Cached copy of the object parameters.
Definition: sim_object.hh:111
const int NWindows
Definition: sparc_traits.hh:41
virtual ThreadContext * getContext(int tn)
Given a thread num get tho thread context for it.
Definition: base.hh:294
uint64_t cpu_mondo_tail
Definition: isa.hh:108
uint64_t stick
Definition: isa.hh:62
uint64_t res_error_tail
Definition: isa.hh:112
uint64_t strandStatusReg
Definition: isa.hh:94
const Params * params() const
Definition: isa.cc:72
Bitfield< 3, 0 > mask
Definition: types.hh:62
Definition: isa.hh:47
T mbits(T val, int first, int last)
Mask off the given bits in place like bits() but without shifting.
Definition: bitfield.hh:95
T bits(T val, int first, int last)
Extract the bitfield from position &#39;first&#39; to &#39;last&#39; (inclusive) from &#39;val&#39; and right justify it...
Definition: bitfield.hh:71
uint64_t tick_cmpr
Definition: isa.hh:61
static const int TotalGlobals
Definition: isa.hh:146
static const int TotalWindowed
Definition: isa.hh:148
Bitfield< 0 > p
uint8_t tl
Definition: isa.hh:77
Tick when() const
Get the time that the event is scheduled.
Definition: eventq.hh:499
uint16_t priContext
MMU Internal Registers.
Definition: isa.hh:100
void clear()
Definition: isa.cc:112
#define UNSERIALIZE_OBJPTR(objptr)
Definition: serialize.hh:876
uint16_t tt[MaxTL]
Definition: isa.hh:72
void postInterrupt(ThreadID tid, int int_num, int index)
Definition: base.hh:234
SparcISAParams Params
Definition: isa.hh:257
uint64_t hintp
Definition: isa.hh:90
ISA(Params *p)
Definition: isa.cc:62
void installWindow(int cwp, int offset)
Definition: isa.cc:92
uint64_t scratchPad[8]
Definition: isa.hh:105
uint64_t stick_cmpr
Definition: isa.hh:63
uint64_t gsr
Definition: isa.hh:59
void setMiscRegNoEffect(int miscReg, RegVal val)
Definition: isa.cc:384
void setFSReg(int miscReg, RegVal val, ThreadContext *tc)
Definition: ua2005.cc:92
Floating Point Status Register.
Definition: miscregs.hh:83

Generated on Thu May 28 2020 16:11:02 for gem5 by doxygen 1.8.13