gem5
v19.0.0.0
Main Page
Related Pages
Modules
+
Namespaces
Namespace List
+
Namespace Members
+
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
+
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
+
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
+
Typedefs
a
b
c
d
e
f
g
h
i
m
n
o
p
r
s
t
u
v
w
x
+
Enumerations
a
b
c
d
e
f
i
l
m
o
p
r
s
t
v
x
+
Enumerator
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
+
Classes
Class List
Class Index
Class Hierarchy
+
Class Members
+
All
:
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
+
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
+
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
+
Typedefs
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
y
+
Enumerations
a
b
c
d
e
f
g
h
i
l
m
o
p
r
s
t
u
w
+
Enumerator
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
+
Related Functions
:
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
+
Files
File List
+
File Members
+
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
+
Functions
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
z
+
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
r
s
t
u
v
z
+
Typedefs
a
b
c
d
e
f
g
h
i
l
m
n
o
p
r
s
t
u
v
w
+
Enumerations
a
b
c
d
e
f
g
i
l
m
o
p
r
s
t
v
w
+
Enumerator
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
w
x
+
Macros
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
sim
faults.hh
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2003-2005 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
* Authors: Nathan Binkert
29
* Gabe Black
30
*/
31
32
#ifndef __FAULTS_HH__
33
#define __FAULTS_HH__
34
35
#include "
base/types.hh
"
36
#include "
cpu/static_inst.hh
"
37
#include "
sim/stats.hh
"
38
39
class
ThreadContext
;
40
41
typedef
const
char
*
FaultName
;
42
typedef
Stats::Scalar
FaultStat
;
43
44
class
FaultBase
45
{
46
public
:
47
virtual
FaultName
name
()
const
= 0;
48
virtual
void
invoke
(
ThreadContext
* tc,
const
StaticInstPtr
&inst =
49
StaticInst::nullStaticInstPtr
);
50
51
virtual
~FaultBase
() {};
52
};
53
54
class
UnimpFault
:
public
FaultBase
55
{
56
private
:
57
std::string
panicStr
;
58
public
:
59
UnimpFault
(std::string _str)
60
: panicStr(_str)
61
{ }
62
63
FaultName
name
()
const
{
return
"Unimplemented simulator feature"
; }
64
void
invoke
(
ThreadContext
* tc,
const
StaticInstPtr
&inst =
65
StaticInst::nullStaticInstPtr
);
66
};
67
68
class
ReExec
:
public
FaultBase
69
{
70
public
:
71
virtual
FaultName
name
()
const
{
return
"Re-execution fault"
; }
72
ReExec
() {}
73
void
invoke
(
ThreadContext
*tc,
const
StaticInstPtr
&inst =
74
StaticInst::nullStaticInstPtr
);
75
};
76
77
/*
78
* This class is needed to allow system call retries to occur for blocking
79
* system calls in SE mode. A retry fault will be generated by the system call
80
* emulation code if blocking conditions arise; the fault is passed up the
81
* function call chain into the CPU model where it is handled by retrying the
82
* syscall instruction on a later tick.
83
*/
84
class
SyscallRetryFault
:
public
FaultBase
85
{
86
public
:
87
virtual
FaultName
name
()
const
{
return
"System call retry fault"
; }
88
SyscallRetryFault
() {}
89
void
invoke
(
ThreadContext
*tc,
const
StaticInstPtr
&inst =
90
StaticInst::nullStaticInstPtr
);
91
};
92
93
class
GenericPageTableFault
:
public
FaultBase
94
{
95
private
:
96
Addr
vaddr
;
97
public
:
98
FaultName
name
()
const
{
return
"Generic page table fault"
; }
99
GenericPageTableFault
(
Addr
va
) : vaddr(va) {}
100
void
invoke
(
ThreadContext
* tc,
const
StaticInstPtr
&inst =
101
StaticInst::nullStaticInstPtr
);
102
Addr
getFaultVAddr
()
const
{
return
vaddr
; }
103
};
104
105
class
GenericAlignmentFault
:
public
FaultBase
106
{
107
private
:
108
Addr
vaddr
;
109
public
:
110
FaultName
name
()
const
{
return
"Generic alignment fault"
; }
111
GenericAlignmentFault
(
Addr
va
) : vaddr(va) {}
112
void
invoke
(
ThreadContext
* tc,
const
StaticInstPtr
&inst =
113
StaticInst::nullStaticInstPtr
);
114
Addr
getFaultVAddr
()
const
{
return
vaddr
; }
115
};
116
117
#endif // __FAULTS_HH__
FaultBase::~FaultBase
virtual ~FaultBase()
Definition:
faults.hh:51
GenericPageTableFault::vaddr
Addr vaddr
Definition:
faults.hh:96
stats.hh
FaultStat
Stats::Scalar FaultStat
Definition:
faults.hh:42
ReExec::name
virtual FaultName name() const
Definition:
faults.hh:71
GenericAlignmentFault::name
FaultName name() const
Definition:
faults.hh:110
RefCountingPtr< StaticInst >
ThreadContext
ThreadContext is the external interface to all thread state for anything outside of the CPU...
Definition:
thread_context.hh:93
SyscallRetryFault::name
virtual FaultName name() const
Definition:
faults.hh:87
FaultBase::name
virtual FaultName name() const =0
Stats::Scalar
This is a simple scalar statistic, like a counter.
Definition:
statistics.hh:2508
SyscallRetryFault::SyscallRetryFault
SyscallRetryFault()
Definition:
faults.hh:88
GenericAlignmentFault::vaddr
Addr vaddr
Definition:
faults.hh:108
GenericPageTableFault::GenericPageTableFault
GenericPageTableFault(Addr va)
Definition:
faults.hh:99
GenericAlignmentFault
Definition:
faults.hh:105
ReExec
Definition:
faults.hh:68
static_inst.hh
GenericAlignmentFault::GenericAlignmentFault
GenericAlignmentFault(Addr va)
Definition:
faults.hh:111
FaultName
const char * FaultName
Definition:
faults.hh:39
UnimpFault::UnimpFault
UnimpFault(std::string _str)
Definition:
faults.hh:59
MipsISA::vaddr
vaddr
Definition:
pra_constants.hh:277
SyscallRetryFault
Definition:
faults.hh:84
GenericAlignmentFault::getFaultVAddr
Addr getFaultVAddr() const
Definition:
faults.hh:114
types.hh
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,16,32,64}_t.
Addr
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition:
types.hh:142
GenericPageTableFault
Definition:
faults.hh:93
ArmISA::va
Bitfield< 8 > va
Definition:
miscregs_types.hh:274
UnimpFault
Definition:
faults.hh:54
GenericPageTableFault::name
FaultName name() const
Definition:
faults.hh:98
ReExec::ReExec
ReExec()
Definition:
faults.hh:72
UnimpFault::panicStr
std::string panicStr
Definition:
faults.hh:57
UnimpFault::name
FaultName name() const
Definition:
faults.hh:63
StaticInst::nullStaticInstPtr
static StaticInstPtr nullStaticInstPtr
Pointer to a statically allocated "null" instruction object.
Definition:
static_inst.hh:223
FaultBase
Definition:
faults.hh:44
FaultBase::invoke
virtual void invoke(ThreadContext *tc, const StaticInstPtr &inst=StaticInst::nullStaticInstPtr)
Definition:
faults.cc:43
GenericPageTableFault::getFaultVAddr
Addr getFaultVAddr() const
Definition:
faults.hh:102
Generated on Fri Feb 28 2020 16:26:55 for gem5 by
doxygen
1.8.13