gem5  v21.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  clear();
65 }
66 
67 void
69 {
72  // Microcode registers.
73  for (int i = 0; i < NumMicroIntRegs; i++)
79 }
80 
81 void
83 {
84  assert(offset >= 0 && offset + NumWindowedRegs <= NumIntRegs);
85  RegIndex *mapChunk = intRegMap + offset;
86  for (int i = 0; i < NumWindowedRegs; i++)
87  mapChunk[i] = TotalGlobals +
89 }
90 
91 void
93 {
94  assert(offset >= 0 && offset + NumGlobalRegs <= NumIntRegs);
95  RegIndex *mapChunk = intRegMap + offset;
96  mapChunk[0] = 0;
97  for (int i = 1; i < NumGlobalRegs; i++)
98  mapChunk[i] = i + gl * NumGlobalRegs;
99 }
100 
101 void
103 {
104  cwp = 0;
105  gl = 0;
106  reloadRegMap();
107 
108  // y = 0;
109  // ccr = 0;
110  asi = 0;
111  tick = ULL(1) << 63;
112  fprs = 0;
113  gsr = 0;
114  softint = 0;
115  tick_cmpr = 0;
116  stick = 0;
117  stick_cmpr = 0;
118  memset(tpc, 0, sizeof(tpc));
119  memset(tnpc, 0, sizeof(tnpc));
120  memset(tstate, 0, sizeof(tstate));
121  memset(tt, 0, sizeof(tt));
122  tba = 0;
123  pstate = 0;
124  tl = 0;
125  pil = 0;
126  // cansave = 0;
127  // canrestore = 0;
128  // cleanwin = 0;
129  // otherwin = 0;
130  // wstate = 0;
131  // In a T1, bit 11 is apparently always 1
132  hpstate = 0;
133  hpstate.id = 1;
134  memset(htstate, 0, sizeof(htstate));
135  hintp = 0;
136  htba = 0;
137  hstick_cmpr = 0;
138  // This is set this way in Legion for some reason
139  strandStatusReg = 0x50000;
140  fsr = 0;
141 
142  priContext = 0;
143  secContext = 0;
144  partId = 0;
145  lsuCtrlReg = 0;
146 
147  memset(scratchPad, 0, sizeof(scratchPad));
148 
149  cpu_mondo_head = 0;
150  cpu_mondo_tail = 0;
151  dev_mondo_head = 0;
152  dev_mondo_tail = 0;
153  res_error_head = 0;
154  res_error_tail = 0;
155  nres_error_head = 0;
156  nres_error_tail = 0;
157 
158  // If one of these events is active, it's not obvious to me how to get
159  // rid of it cleanly. For now we'll just assert that they're not.
160  if (tickCompare != NULL && sTickCompare != NULL && hSTickCompare != NULL)
161  panic("Tick comparison event active when clearing the ISA object.\n");
162 }
163 
164 RegVal
165 ISA::readMiscRegNoEffect(int miscReg) const
166 {
167 
168  // The three miscRegs are moved up from the switch statement
169  // due to more frequent calls.
170 
171  if (miscReg == MISCREG_GL)
172  return gl;
173  if (miscReg == MISCREG_CWP)
174  return cwp;
175  if (miscReg == MISCREG_TLB_DATA) {
176  /* Package up all the data for the tlb:
177  * 6666555555555544444444443333333333222222222211111111110000000000
178  * 3210987654321098765432109876543210987654321098765432109876543210
179  * secContext | priContext | |tl|partid| |||||^hpriv
180  * ||||^red
181  * |||^priv
182  * ||^am
183  * |^lsuim
184  * ^lsudm
185  */
186  return (uint64_t)hpstate.hpriv |
187  (uint64_t)hpstate.red << 1 |
188  (uint64_t)pstate.priv << 2 |
189  (uint64_t)pstate.am << 3 |
190  bits((uint64_t)lsuCtrlReg,3,2) << 4 |
191  bits((uint64_t)partId,7,0) << 8 |
192  bits((uint64_t)tl,2,0) << 16 |
193  (uint64_t)priContext << 32 |
194  (uint64_t)secContext << 48;
195  }
196 
197  switch (miscReg) {
198  // case MISCREG_TLB_DATA:
199  // [original contents see above]
200  // case MISCREG_Y:
201  // return y;
202  // case MISCREG_CCR:
203  // return ccr;
204  case MISCREG_ASI:
205  return asi;
206  case MISCREG_FPRS:
207  return fprs;
208  case MISCREG_TICK:
209  return tick;
210  case MISCREG_PCR:
211  panic("PCR not implemented\n");
212  case MISCREG_PIC:
213  panic("PIC not implemented\n");
214  case MISCREG_GSR:
215  return gsr;
216  case MISCREG_SOFTINT:
217  return softint;
218  case MISCREG_TICK_CMPR:
219  return tick_cmpr;
220  case MISCREG_STICK:
221  return stick;
222  case MISCREG_STICK_CMPR:
223  return stick_cmpr;
224 
226  case MISCREG_TPC:
227  return tpc[tl-1];
228  case MISCREG_TNPC:
229  return tnpc[tl-1];
230  case MISCREG_TSTATE:
231  return tstate[tl-1];
232  case MISCREG_TT:
233  return tt[tl-1];
234  case MISCREG_PRIVTICK:
235  panic("Priviliged access to tick registers not implemented\n");
236  case MISCREG_TBA:
237  return tba;
238  case MISCREG_PSTATE:
239  return (RegVal)pstate;
240  case MISCREG_TL:
241  return tl;
242  case MISCREG_PIL:
243  return pil;
244  // CWP, GL moved
245  // case MISCREG_CWP:
246  // return cwp;
247  // case MISCREG_CANSAVE:
248  // return cansave;
249  // case MISCREG_CANRESTORE:
250  // return canrestore;
251  // case MISCREG_CLEANWIN:
252  // return cleanwin;
253  // case MISCREG_OTHERWIN:
254  // return otherwin;
255  // case MISCREG_WSTATE:
256  // return wstate;
257  // case MISCREG_GL:
258  // return gl;
259 
261  case MISCREG_HPSTATE:
262  return (RegVal)hpstate;
263  case MISCREG_HTSTATE:
264  return htstate[tl-1];
265  case MISCREG_HINTP:
266  return hintp;
267  case MISCREG_HTBA:
268  return htba;
270  return strandStatusReg;
271  case MISCREG_HSTICK_CMPR:
272  return hstick_cmpr;
273 
275  case MISCREG_FSR:
276  DPRINTF(MiscRegs, "FSR read as: %#x\n", fsr);
277  return fsr;
278 
280  return priContext;
282  return secContext;
283  case MISCREG_MMU_PART_ID:
284  return partId;
286  return lsuCtrlReg;
287 
289  return scratchPad[0];
291  return scratchPad[1];
293  return scratchPad[2];
295  return scratchPad[3];
297  return scratchPad[4];
299  return scratchPad[5];
301  return scratchPad[6];
303  return scratchPad[7];
305  return cpu_mondo_head;
307  return cpu_mondo_tail;
309  return dev_mondo_head;
311  return dev_mondo_tail;
313  return res_error_head;
315  return res_error_tail;
317  return nres_error_head;
319  return nres_error_tail;
320  default:
321  panic("Miscellaneous register %d not implemented\n", miscReg);
322  }
323 }
324 
325 RegVal
326 ISA::readMiscReg(int miscReg)
327 {
328  switch (miscReg) {
329  // tick and stick are aliased to each other in niagra
330  // well store the tick data in stick and the interrupt bit in tick
331  case MISCREG_STICK:
332  case MISCREG_TICK:
333  case MISCREG_PRIVTICK:
334  // I'm not sure why legion ignores the lowest two bits, but we'll go
335  // with it
336  // change from curCycle() to instCount() until we're done with legion
337  DPRINTF(Timer, "Instruction Count when TICK read: %#X stick=%#X\n",
338  tc->getCpuPtr()->instCount(), stick);
339  return mbits(tc->getCpuPtr()->instCount() + (int64_t)stick,62,2) |
340  mbits(tick,63,63);
341  case MISCREG_FPRS:
342  // in legion if fp is enabled du and dl are set
343  return fprs | 0x3;
344  case MISCREG_PCR:
345  case MISCREG_PIC:
346  panic("Performance Instrumentation not impl\n");
347  case MISCREG_SOFTINT_CLR:
348  case MISCREG_SOFTINT_SET:
349  panic("Can read from softint clr/set\n");
350  case MISCREG_SOFTINT:
351  case MISCREG_TICK_CMPR:
352  case MISCREG_STICK_CMPR:
353  case MISCREG_HINTP:
354  case MISCREG_HTSTATE:
355  case MISCREG_HTBA:
356  case MISCREG_HVER:
358  case MISCREG_HSTICK_CMPR:
367  case MISCREG_HPSTATE:
368  return readFSReg(miscReg);
369  }
370  return readMiscRegNoEffect(miscReg);
371 }
372 
373 void
375 {
376  switch (miscReg) {
377 // case MISCREG_Y:
378 // y = val;
379 // break;
380 // case MISCREG_CCR:
381 // ccr = val;
382 // break;
383  case MISCREG_ASI:
384  asi = val;
385  break;
386  case MISCREG_FPRS:
387  fprs = val;
388  break;
389  case MISCREG_TICK:
390  tick = val;
391  break;
392  case MISCREG_PCR:
393  panic("PCR not implemented\n");
394  case MISCREG_PIC:
395  panic("PIC not implemented\n");
396  case MISCREG_GSR:
397  gsr = val;
398  break;
399  case MISCREG_SOFTINT:
400  softint = val;
401  break;
402  case MISCREG_TICK_CMPR:
403  tick_cmpr = val;
404  break;
405  case MISCREG_STICK:
406  stick = val;
407  break;
408  case MISCREG_STICK_CMPR:
409  stick_cmpr = val;
410  break;
411 
413  case MISCREG_TPC:
414  tpc[tl-1] = val;
415  break;
416  case MISCREG_TNPC:
417  tnpc[tl-1] = val;
418  break;
419  case MISCREG_TSTATE:
420  tstate[tl-1] = val;
421  break;
422  case MISCREG_TT:
423  tt[tl-1] = val;
424  break;
425  case MISCREG_PRIVTICK:
426  panic("Priviliged access to tick regesiters not implemented\n");
427  case MISCREG_TBA:
428  // clear lower 7 bits on writes.
429  tba = val & ULL(~0x7FFF);
430  break;
431  case MISCREG_PSTATE:
432  pstate = (val & PstateMask);
433  break;
434  case MISCREG_TL:
435  tl = val;
436  break;
437  case MISCREG_PIL:
438  pil = val;
439  break;
440  case MISCREG_CWP:
441  cwp = val;
442  break;
443 // case MISCREG_CANSAVE:
444 // cansave = val;
445 // break;
446 // case MISCREG_CANRESTORE:
447 // canrestore = val;
448 // break;
449 // case MISCREG_CLEANWIN:
450 // cleanwin = val;
451 // break;
452 // case MISCREG_OTHERWIN:
453 // otherwin = val;
454 // break;
455 // case MISCREG_WSTATE:
456 // wstate = val;
457 // break;
458  case MISCREG_GL:
459  gl = val;
460  break;
461 
463  case MISCREG_HPSTATE:
464  hpstate = val;
465  break;
466  case MISCREG_HTSTATE:
467  htstate[tl-1] = val;
468  break;
469  case MISCREG_HINTP:
470  hintp = val;
471  break;
472  case MISCREG_HTBA:
473  htba = val;
474  break;
477  break;
478  case MISCREG_HSTICK_CMPR:
479  hstick_cmpr = val;
480  break;
481 
483  case MISCREG_FSR:
484  fsr = val;
485  DPRINTF(MiscRegs, "FSR written with: %#x\n", fsr);
486  break;
487 
489  priContext = val;
490  break;
492  secContext = val;
493  break;
494  case MISCREG_MMU_PART_ID:
495  partId = val;
496  break;
498  lsuCtrlReg = val;
499  break;
500 
502  scratchPad[0] = val;
503  break;
505  scratchPad[1] = val;
506  break;
508  scratchPad[2] = val;
509  break;
511  scratchPad[3] = val;
512  break;
514  scratchPad[4] = val;
515  break;
517  scratchPad[5] = val;
518  break;
520  scratchPad[6] = val;
521  break;
523  scratchPad[7] = val;
524  break;
527  break;
530  break;
533  break;
536  break;
539  break;
542  break;
545  break;
548  break;
549  default:
550  panic("Miscellaneous register %d not implemented\n", miscReg);
551  }
552 }
553 
554 void
556 {
557  RegVal new_val = val;
558 
559  switch (miscReg) {
560  case MISCREG_ASI:
561  tc->getDecoderPtr()->setContext(val);
562  break;
563  case MISCREG_STICK:
564  case MISCREG_TICK:
565  // stick and tick are same thing on niagra
566  // use stick for offset and tick for holding intrrupt bit
567  stick = mbits(val,62,0) - tc->getCpuPtr()->instCount();
568  tick = mbits(val,63,63);
569  DPRINTF(Timer, "Writing TICK=%#X\n", val);
570  break;
571  case MISCREG_FPRS:
572  // Configure the fpu based on the fprs
573  break;
574  case MISCREG_PCR:
575  // Set up performance counting based on pcr value
576  break;
577  case MISCREG_PSTATE:
578  pstate = val & PstateMask;
579  return;
580  case MISCREG_TL:
581  {
582  tl = val;
583  if (hpstate.tlz && tl == 0 && !hpstate.hpriv)
585  else
587  return;
588  }
589  case MISCREG_CWP:
590  new_val = val >= NWindows ? NWindows - 1 : val;
591  if (val >= NWindows)
592  new_val = NWindows - 1;
593 
595  installWindow(new_val - 1, NextWindowOffset);
596  installWindow(new_val + 1, PreviousWindowOffset);
597  break;
598  case MISCREG_GL:
602  break;
603  case MISCREG_PIL:
604  case MISCREG_SOFTINT:
605  case MISCREG_SOFTINT_SET:
606  case MISCREG_SOFTINT_CLR:
607  case MISCREG_TICK_CMPR:
608  case MISCREG_STICK_CMPR:
609  case MISCREG_HINTP:
610  case MISCREG_HTSTATE:
611  case MISCREG_HTBA:
612  case MISCREG_HVER:
614  case MISCREG_HSTICK_CMPR:
623  case MISCREG_HPSTATE:
624  setFSReg(miscReg, val);
625  return;
626  }
627  setMiscRegNoEffect(miscReg, new_val);
628 }
629 
630 void
632 {
671 
672  Tick tick_cmp = 0, stick_cmp = 0, hstick_cmp = 0;
674  tick_cmp = tickCompare->when();
676  stick_cmp = sTickCompare->when();
678  hstick_cmp = hSTickCompare->when();
679 
680  SERIALIZE_SCALAR(tick_cmp);
681  SERIALIZE_SCALAR(stick_cmp);
682  SERIALIZE_SCALAR(hstick_cmp);
683 }
684 
685 void
687 {
701  {
702  uint16_t pstate;
704  this->pstate = pstate;
705  }
710  reloadRegMap();
711  {
712  uint64_t hpstate;
714  this->hpstate = hpstate;
715  }
735 
736  Tick tick_cmp = 0, stick_cmp = 0, hstick_cmp = 0;
737  UNSERIALIZE_SCALAR(tick_cmp);
738  UNSERIALIZE_SCALAR(stick_cmp);
739  UNSERIALIZE_SCALAR(hstick_cmp);
740 
741  if (tick_cmp) {
742  tickCompare = new TickCompareEvent(this);
743  schedule(tickCompare, tick_cmp);
744  }
745  if (stick_cmp) {
746  sTickCompare = new STickCompareEvent(this);
747  schedule(sTickCompare, stick_cmp);
748  }
749  if (hstick_cmp) {
750  hSTickCompare = new HSTickCompareEvent(this);
751  schedule(hSTickCompare, hstick_cmp);
752  }
753 }
754 
755 }
SparcISA::ISA::reloadRegMap
void reloadRegMap()
Definition: isa.cc:68
SparcISA::MISCREG_PSTATE
@ MISCREG_PSTATE
Definition: miscregs.hh:62
SparcISA::ISA::Params
SparcISAParams Params
Definition: isa.hh:224
Event::scheduled
bool scheduled() const
Determine if the current event is scheduled.
Definition: eventq.hh:462
SparcISA::ISA::nres_error_tail
uint64_t nres_error_tail
Definition: isa.hh:113
SparcISA::MISCREG_TSTATE
@ MISCREG_TSTATE
Definition: miscregs.hh:58
SparcISA::MISCREG_PIC
@ MISCREG_PIC
Definition: miscregs.hh:46
SparcISA::MISCREG_QUEUE_CPU_MONDO_TAIL
@ MISCREG_QUEUE_CPU_MONDO_TAIL
Definition: miscregs.hh:103
SparcISA::ISA::tstate
uint64_t tstate[MaxTL]
Definition: isa.hh:70
SparcISA::NumIntRegs
const int NumIntRegs
Definition: registers.hh:96
SparcISA::ISA::secContext
uint16_t secContext
Definition: isa.hh:100
SparcISA::MISCREG_TICK_CMPR
@ MISCREG_TICK_CMPR
Definition: miscregs.hh:51
SparcISA::ISA::NumWindowedRegs
static const int NumWindowedRegs
Definition: isa.hh:139
UNSERIALIZE_SCALAR
#define UNSERIALIZE_SCALAR(scalar)
Definition: serialize.hh:591
SparcISA::MISCREG_PIL
@ MISCREG_PIL
Definition: miscregs.hh:64
SparcISA::ISA::sTickCompare
STickCompareEvent * sTickCompare
Definition: isa.hh:133
SparcISA::MISCREG_SCRATCHPAD_R3
@ MISCREG_SCRATCHPAD_R3
Definition: miscregs.hh:95
SparcISA::MISCREG_HINTP
@ MISCREG_HINTP
Definition: miscregs.hh:76
SparcISA::ISA::cwp
uint8_t cwp
Definition: isa.hh:78
ArmISA::i
Bitfield< 7 > i
Definition: miscregs_types.hh:63
SparcISA::MISCREG_SCRATCHPAD_R5
@ MISCREG_SCRATCHPAD_R5
Definition: miscregs.hh:97
SparcISA::MISCREG_HTSTATE
@ MISCREG_HTSTATE
Definition: miscregs.hh:75
SparcISA::MISCREG_SCRATCHPAD_R1
@ MISCREG_SCRATCHPAD_R1
Definition: miscregs.hh:93
SparcISA::ISA::STickCompareEvent
EventWrapper< ISA, &ISA::processSTickCompare > STickCompareEvent
Definition: isa.hh:132
SparcISA::PstateMask
static const PSTATE PstateMask
Definition: isa.cc:60
SparcISA::ISA::tt
uint16_t tt[MaxTL]
Definition: isa.hh:71
SparcISA::ISA::cpu_mondo_head
uint64_t cpu_mondo_head
Definition: isa.hh:106
SparcISA::ISA::PreviousGlobalsOffset
@ PreviousGlobalsOffset
Definition: isa.hh:152
Tick
uint64_t Tick
Tick count type.
Definition: types.hh:59
SparcISA::MISCREG_TLB_DATA
@ MISCREG_TLB_DATA
Definition: miscregs.hh:112
SparcISA::MISCREG_SOFTINT
@ MISCREG_SOFTINT
Definition: miscregs.hh:50
SparcISA::ISA::hintp
uint64_t hintp
Definition: isa.hh:89
BaseCPU::postInterrupt
void postInterrupt(ThreadID tid, int int_num, int index)
Definition: base.cc:191
SparcISA::MISCREG_FSR
@ MISCREG_FSR
Floating Point Status Register.
Definition: miscregs.hh:83
SparcISA::MISCREG_PCR
@ MISCREG_PCR
Definition: miscregs.hh:45
SparcISA::MISCREG_QUEUE_DEV_MONDO_HEAD
@ MISCREG_QUEUE_DEV_MONDO_HEAD
Definition: miscregs.hh:104
SparcISA::MISCREG_TPC
@ MISCREG_TPC
Privilged Registers.
Definition: miscregs.hh:56
SparcISA::NWindows
const int NWindows
Definition: sparc_traits.hh:41
SparcISA::ISA::fprs
uint8_t fprs
Definition: isa.hh:57
SparcISA::MISCREG_GSR
@ MISCREG_GSR
Definition: miscregs.hh:47
Event::when
Tick when() const
Get the time that the event is scheduled.
Definition: eventq.hh:505
SparcISA::MISCREG_SCRATCHPAD_R6
@ MISCREG_SCRATCHPAD_R6
Definition: miscregs.hh:98
SparcISA::ISA::setFSReg
void setFSReg(int miscReg, RegVal val)
Definition: ua2005.cc:89
SparcISA::ISA::strandStatusReg
uint64_t strandStatusReg
Definition: isa.hh:93
SparcISA::MISCREG_QUEUE_DEV_MONDO_TAIL
@ MISCREG_QUEUE_DEV_MONDO_TAIL
Definition: miscregs.hh:105
SparcISA::MISCREG_PRIVTICK
@ MISCREG_PRIVTICK
Definition: miscregs.hh:60
SparcISA::ISA::MicroIntOffset
@ MicroIntOffset
Definition: isa.hh:149
SparcISA::ISA::CurrentWindowOffset
@ CurrentWindowOffset
Definition: isa.hh:148
SparcISA::MISCREG_SOFTINT_CLR
@ MISCREG_SOFTINT_CLR
Definition: miscregs.hh:49
SparcISA::ISA::tpc
uint64_t tpc[MaxTL]
Definition: isa.hh:66
SparcISA::ISA::hpstate
HPSTATE hpstate
Hyperprivileged Registers.
Definition: isa.hh:87
SparcISA::ISA::asi
uint8_t asi
Definition: isa.hh:55
SparcISA::ISA::NextWindowOffset
@ NextWindowOffset
Definition: isa.hh:151
SparcISA::ISA::readMiscRegNoEffect
RegVal readMiscRegNoEffect(int miscReg) const
Definition: isa.cc:165
SparcISA
Definition: asi.cc:31
SparcISA::ISA::stick_cmpr
uint64_t stick_cmpr
Definition: isa.hh:62
SparcISA::IT_TRAP_LEVEL_ZERO
@ IT_TRAP_LEVEL_ZERO
Definition: interrupts.hh:46
SparcISA::MISCREG_GL
@ MISCREG_GL
Definition: miscregs.hh:71
SparcISA::ISA::installGlobals
void installGlobals(int gl, int offset)
Definition: isa.cc:92
SparcISA::ISA::fsr
uint64_t fsr
Floating point misc registers.
Definition: isa.hh:96
SparcISA::MISCREG_TT
@ MISCREG_TT
Definition: miscregs.hh:59
SparcISA::MISCREG_TICK
@ MISCREG_TICK
Definition: miscregs.hh:43
SparcISA::ISA::res_error_head
uint64_t res_error_head
Definition: isa.hh:110
cp
Definition: cprintf.cc:37
EventManager::schedule
void schedule(Event &event, Tick when)
Definition: eventq.hh:1016
SparcISA::ISA::setMiscRegNoEffect
void setMiscRegNoEffect(int miscReg, RegVal val)
Definition: isa.cc:374
SparcISA::ISA::readMiscReg
RegVal readMiscReg(int miscReg)
Definition: isa.cc:326
SparcISA::buildPstateMask
static PSTATE buildPstateMask()
Definition: isa.cc:46
SparcISA::ISA::serialize
void serialize(CheckpointOut &cp) const override
Serialize an object.
Definition: isa.cc:631
SparcISA::MISCREG_QUEUE_NRES_ERROR_TAIL
@ MISCREG_QUEUE_NRES_ERROR_TAIL
Definition: miscregs.hh:109
bitfield.hh
SparcISA::ISA::CurrentGlobalsOffset
@ CurrentGlobalsOffset
Definition: isa.hh:147
SparcISA::MISCREG_TL
@ MISCREG_TL
Definition: miscregs.hh:63
DPRINTF
#define DPRINTF(x,...)
Definition: trace.hh:237
BaseISA::tc
ThreadContext * tc
Definition: isa.hh:52
asi.hh
SparcISA::ISA::installWindow
void installWindow(int cwp, int offset)
Definition: isa.cc:82
SparcISA::MISCREG_SOFTINT_SET
@ MISCREG_SOFTINT_SET
Definition: miscregs.hh:48
SparcISA::ISA::gsr
uint64_t gsr
Definition: isa.hh:58
SparcISA::ISA::priContext
uint16_t priContext
MMU Internal Registers.
Definition: isa.hh:99
SparcISA::ISA::TotalWindowed
static const int TotalWindowed
Definition: isa.hh:144
SparcISA::ISA::partId
uint16_t partId
Definition: isa.hh:101
SparcISA::ISA::dev_mondo_head
uint64_t dev_mondo_head
Definition: isa.hh:108
SparcISA::ISA::res_error_tail
uint64_t res_error_tail
Definition: isa.hh:111
BaseCPU::clearInterrupt
void clearInterrupt(ThreadID tid, int int_num, int index)
Definition: base.hh:251
SparcISA::MISCREG_QUEUE_CPU_MONDO_HEAD
@ MISCREG_QUEUE_CPU_MONDO_HEAD
Definition: miscregs.hh:102
SparcISA::ISA::cpu_mondo_tail
uint64_t cpu_mondo_tail
Definition: isa.hh:107
mbits
constexpr T mbits(T val, unsigned first, unsigned last)
Mask off the given bits in place like bits() but without shifting.
Definition: bitfield.hh:100
SERIALIZE_ARRAY
#define SERIALIZE_ARRAY(member, size)
Definition: serialize.hh:626
SparcISA::MISCREG_QUEUE_RES_ERROR_HEAD
@ MISCREG_QUEUE_RES_ERROR_HEAD
Definition: miscregs.hh:106
SparcISA::ISA::tick_cmpr
uint64_t tick_cmpr
Definition: isa.hh:60
SparcISA::ISA::pil
uint8_t pil
Definition: isa.hh:77
SparcISA::ISA::tick
uint64_t tick
Definition: isa.hh:56
SparcISA::MISCREG_MMU_LSU_CTRL
@ MISCREG_MMU_LSU_CTRL
Definition: miscregs.hh:89
SparcISA::MISCREG_STRAND_STS_REG
@ MISCREG_STRAND_STS_REG
Definition: miscregs.hh:79
X86ISA::val
Bitfield< 63 > val
Definition: misc.hh:769
SparcISA::MISCREG_STICK_CMPR
@ MISCREG_STICK_CMPR
Definition: miscregs.hh:53
SparcISA::ISA::setMiscReg
void setMiscReg(int miscReg, RegVal val)
Definition: isa.cc:555
SparcISA::ISA::TotalGlobals
static const int TotalGlobals
Definition: isa.hh:142
SparcISA::ISA::softint
uint64_t softint
Definition: isa.hh:59
SparcISA::MISCREG_HSTICK_CMPR
@ MISCREG_HSTICK_CMPR
Definition: miscregs.hh:80
SparcISA::ISA::scratchPad
uint64_t scratchPad[8]
Definition: isa.hh:104
SparcISA::ISA::NextGlobalsOffset
@ NextGlobalsOffset
Definition: isa.hh:150
SparcISA::ISA::htba
uint64_t htba
Definition: isa.hh:90
SparcISA::MISCREG_MMU_PART_ID
@ MISCREG_MMU_PART_ID
Definition: miscregs.hh:88
SERIALIZE_SCALAR
#define SERIALIZE_SCALAR(scalar)
Definition: serialize.hh:584
SparcISA::ISA::htstate
uint64_t htstate[MaxTL]
Definition: isa.hh:88
SparcISA::ISA::RegsPerWindow
static const int RegsPerWindow
Definition: isa.hh:143
SparcISA::MISCREG_SCRATCHPAD_R0
@ MISCREG_SCRATCHPAD_R0
Scratchpad regiscers.
Definition: miscregs.hh:92
SparcISA::ISA::clear
void clear()
Definition: isa.cc:102
SparcISA::ISA::lsuCtrlReg
uint64_t lsuCtrlReg
Definition: isa.hh:102
SparcISA::MISCREG_HPSTATE
@ MISCREG_HPSTATE
Hyper privileged registers.
Definition: miscregs.hh:74
SparcISA::MISCREG_STICK
@ MISCREG_STICK
Definition: miscregs.hh:52
SparcISA::MISCREG_ASI
@ MISCREG_ASI
Ancillary State Registers.
Definition: miscregs.hh:42
base.hh
UNSERIALIZE_ARRAY
#define UNSERIALIZE_ARRAY(member, size)
Definition: serialize.hh:634
RegIndex
uint16_t RegIndex
Definition: types.hh:52
SparcISA::MISCREG_SCRATCHPAD_R7
@ MISCREG_SCRATCHPAD_R7
Definition: miscregs.hh:99
SparcISA::MISCREG_QUEUE_NRES_ERROR_HEAD
@ MISCREG_QUEUE_NRES_ERROR_HEAD
Definition: miscregs.hh:108
decoder.hh
SparcISA::MISCREG_HTBA
@ MISCREG_HTBA
Definition: miscregs.hh:77
SparcISA::ISA::tl
uint8_t tl
Definition: isa.hh:76
interrupts.hh
SparcISA::MISCREG_QUEUE_RES_ERROR_TAIL
@ MISCREG_QUEUE_RES_ERROR_TAIL
Definition: miscregs.hh:107
SparcISA::ISA::tnpc
uint64_t tnpc[MaxTL]
Definition: isa.hh:68
CheckpointOut
std::ostream CheckpointOut
Definition: serialize.hh:64
ThreadContext::getDecoderPtr
virtual TheISA::Decoder * getDecoderPtr()=0
bits
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
Definition: bitfield.hh:73
SparcISA::ISA::hSTickCompare
HSTickCompareEvent * hSTickCompare
Definition: isa.hh:136
SparcISA::ISA::hstick_cmpr
uint64_t hstick_cmpr
Definition: isa.hh:91
SparcISA::ISA::unserialize
void unserialize(CheckpointIn &cp) override
Unserialize an object.
Definition: isa.cc:686
trace.hh
SparcISA::ISA::tickCompare
TickCompareEvent * tickCompare
Definition: isa.hh:130
SparcISA::ISA::nres_error_head
uint64_t nres_error_head
Definition: isa.hh:112
SparcISA::MISCREG_SCRATCHPAD_R4
@ MISCREG_SCRATCHPAD_R4
Definition: miscregs.hh:96
MipsISA::p
Bitfield< 0 > p
Definition: pra_constants.hh:323
SparcISA::MISCREG_MMU_P_CONTEXT
@ MISCREG_MMU_P_CONTEXT
MMU Internal Registers.
Definition: miscregs.hh:86
SparcISA::ISA::ISA
ISA(const Params &p)
Definition: isa.cc:62
BaseCPU::instCount
Tick instCount()
Definition: base.hh:229
SparcISA::NumMicroIntRegs
@ NumMicroIntRegs
Definition: registers.hh:83
SparcISA::ISA::stick
uint64_t stick
Definition: isa.hh:61
SparcISA::MISCREG_TNPC
@ MISCREG_TNPC
Definition: miscregs.hh:57
SparcISA::ISA::PreviousWindowOffset
@ PreviousWindowOffset
Definition: isa.hh:153
CheckpointIn
Definition: serialize.hh:68
SparcISA::ISA::TickCompareEvent
EventWrapper< ISA, &ISA::processTickCompare > TickCompareEvent
Definition: isa.hh:129
SparcISA::ISA::readFSReg
RegVal readFSReg(int miscReg)
Definition: ua2005.cc:245
SparcISA::ISA::HSTickCompareEvent
EventWrapper< ISA, &ISA::processHSTickCompare > HSTickCompareEvent
Definition: isa.hh:135
ThreadContext::getCpuPtr
virtual BaseCPU * getCpuPtr()=0
SparcISA::ISA::dev_mondo_tail
uint64_t dev_mondo_tail
Definition: isa.hh:109
SparcISA::ISA::pstate
PSTATE pstate
Definition: isa.hh:75
BaseISA
Definition: isa.hh:47
SparcISA::MISCREG_SCRATCHPAD_R2
@ MISCREG_SCRATCHPAD_R2
Definition: miscregs.hh:94
isa.hh
SparcISA::MISCREG_HVER
@ MISCREG_HVER
Definition: miscregs.hh:78
thread_context.hh
SparcISA::MISCREG_MMU_S_CONTEXT
@ MISCREG_MMU_S_CONTEXT
Definition: miscregs.hh:87
ULL
#define ULL(N)
uint64_t constant
Definition: types.hh:46
SparcISA::ISA::intRegMap
RegIndex intRegMap[TotalInstIntRegs]
Definition: isa.hh:157
RegVal
uint64_t RegVal
Definition: types.hh:174
SparcISA::ISA::gl
uint8_t gl
Definition: isa.hh:84
SparcISA::MISCREG_FPRS
@ MISCREG_FPRS
Definition: miscregs.hh:44
ArmISA::mask
Bitfield< 28, 24 > mask
Definition: miscregs_types.hh:711
SparcISA::ISA::tba
uint64_t tba
Definition: isa.hh:73
SparcISA::MISCREG_CWP
@ MISCREG_CWP
Definition: miscregs.hh:65
SparcISA::MISCREG_TBA
@ MISCREG_TBA
Definition: miscregs.hh:61
SparcISA::MaxTL
const int MaxTL
Definition: sparc_traits.hh:36
panic
#define panic(...)
This implements a cprintf based panic() function.
Definition: logging.hh:171
SparcISA::ISA::NumGlobalRegs
static const int NumGlobalRegs
Definition: isa.hh:138
ArmISA::offset
Bitfield< 23, 0 > offset
Definition: types.hh:153

Generated on Tue Mar 23 2021 19:41:18 for gem5 by doxygen 1.8.17