gem5
v20.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
+
Typedefs
_
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
u
v
w
+
Enumerations
_
a
b
c
d
e
f
g
h
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
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
arch
power
isa.hh
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2009 The Regents of The University of Michigan
3
* Copyright (c) 2009 The University of Edinburgh
4
* All rights reserved.
5
*
6
* Redistribution and use in source and binary forms, with or without
7
* modification, are permitted provided that the following conditions are
8
* met: redistributions of source code must retain the above copyright
9
* notice, this list of conditions and the following disclaimer;
10
* redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution;
13
* neither the name of the copyright holders nor the names of its
14
* contributors may be used to endorse or promote products derived from
15
* this software without specific prior written permission.
16
*
17
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
*/
29
30
#ifndef __ARCH_POWER_ISA_HH__
31
#define __ARCH_POWER_ISA_HH__
32
33
#include "
arch/generic/isa.hh
"
34
#include "
arch/power/registers.hh
"
35
#include "
arch/power/types.hh
"
36
#include "
base/logging.hh
"
37
#include "
cpu/reg_class.hh
"
38
#include "
sim/sim_object.hh
"
39
40
struct
PowerISAParams;
41
class
ThreadContext
;
42
class
Checkpoint;
43
class
EventManager
;
44
45
namespace
PowerISA
46
{
47
48
class
ISA
:
public
BaseISA
49
{
50
protected
:
51
RegVal
dummy
;
52
RegVal
miscRegs
[
NumMiscRegs
];
53
54
public
:
55
typedef
PowerISAParams
Params
;
56
57
void
58
clear
(
ThreadContext
*tc)
59
{
60
clear
();
61
}
62
63
protected
:
64
void
65
clear
()
66
{
67
}
68
69
public
:
70
RegVal
71
readMiscRegNoEffect
(
int
misc_reg)
const
72
{
73
fatal
(
"Power does not currently have any misc regs defined\n"
);
74
return
dummy
;
75
}
76
77
RegVal
78
readMiscReg
(
int
misc_reg,
ThreadContext
*tc)
79
{
80
fatal
(
"Power does not currently have any misc regs defined\n"
);
81
return
dummy
;
82
}
83
84
void
85
setMiscRegNoEffect
(
int
misc_reg,
RegVal
val
)
86
{
87
fatal
(
"Power does not currently have any misc regs defined\n"
);
88
}
89
90
void
91
setMiscReg
(
int
misc_reg,
RegVal
val
,
ThreadContext
*tc)
92
{
93
fatal
(
"Power does not currently have any misc regs defined\n"
);
94
}
95
96
RegId
flattenRegId
(
const
RegId
& regId)
const
{
return
regId; }
97
98
int
99
flattenIntIndex
(
int
reg
)
const
100
{
101
return
reg
;
102
}
103
104
int
105
flattenFloatIndex
(
int
reg
)
const
106
{
107
return
reg
;
108
}
109
110
int
111
flattenVecIndex
(
int
reg
)
const
112
{
113
return
reg
;
114
}
115
116
int
117
flattenVecElemIndex
(
int
reg
)
const
118
{
119
return
reg
;
120
}
121
122
int
123
flattenVecPredIndex
(
int
reg
)
const
124
{
125
return
reg
;
126
}
127
128
// dummy
129
int
130
flattenCCIndex
(
int
reg
)
const
131
{
132
return
reg
;
133
}
134
135
int
136
flattenMiscIndex
(
int
reg
)
const
137
{
138
return
reg
;
139
}
140
141
void
startup
(
ThreadContext
*tc) {}
142
144
using
BaseISA::startup
;
145
146
const
Params *
params
()
const
;
147
148
ISA
(Params *
p
);
149
};
150
151
}
// namespace PowerISA
152
153
#endif // __ARCH_POWER_ISA_HH__
logging.hh
X86ISA::reg
Bitfield< 5, 3 > reg
Definition:
types.hh:87
fatal
#define fatal(...)
This implements a cprintf based fatal() function.
Definition:
logging.hh:171
PowerISA::ISA::flattenIntIndex
int flattenIntIndex(int reg) const
Definition:
isa.hh:99
PowerISA::ISA::Params
PowerISAParams Params
Definition:
isa.hh:55
registers.hh
PowerISA::ISA::clear
void clear()
Definition:
isa.hh:65
RegVal
uint64_t RegVal
Definition:
types.hh:166
PowerISA::ISA::flattenVecPredIndex
int flattenVecPredIndex(int reg) const
Definition:
isa.hh:123
PowerISA::ISA::miscRegs
RegVal miscRegs[NumMiscRegs]
Definition:
isa.hh:52
PowerISA::ISA::startup
void startup(ThreadContext *tc)
Definition:
isa.hh:141
ThreadContext
ThreadContext is the external interface to all thread state for anything outside of the CPU...
Definition:
thread_context.hh:91
PowerISA::ISA::params
const Params * params() const
Definition:
isa.cc:51
PowerISA::ISA::setMiscReg
void setMiscReg(int misc_reg, RegVal val, ThreadContext *tc)
Definition:
isa.hh:91
X86ISA::val
Bitfield< 63 > val
Definition:
misc.hh:769
PowerISA::ISA::clear
void clear(ThreadContext *tc)
Definition:
isa.hh:58
SimObject::startup
virtual void startup()
startup() is the final initialization call before simulation.
Definition:
sim_object.cc:96
PowerISA::ISA::dummy
RegVal dummy
Definition:
isa.hh:51
PowerISA::ISA::flattenVecElemIndex
int flattenVecElemIndex(int reg) const
Definition:
isa.hh:117
PowerISA::NumMiscRegs
const int NumMiscRegs
Definition:
registers.hh:79
PowerISA::ISA::flattenRegId
RegId flattenRegId(const RegId ®Id) const
Definition:
isa.hh:96
PowerISA
Definition:
decoder.cc:31
PowerISA::ISA::readMiscRegNoEffect
RegVal readMiscRegNoEffect(int misc_reg) const
Definition:
isa.hh:71
isa.hh
types.hh
PowerISA::ISA::flattenFloatIndex
int flattenFloatIndex(int reg) const
Definition:
isa.hh:105
PowerISA::ISA::setMiscRegNoEffect
void setMiscRegNoEffect(int misc_reg, RegVal val)
Definition:
isa.hh:85
PowerISA::ISA::flattenVecIndex
int flattenVecIndex(int reg) const
Definition:
isa.hh:111
PowerISA::ISA::flattenMiscIndex
int flattenMiscIndex(int reg) const
Definition:
isa.hh:136
sim_object.hh
reg_class.hh
RegId
Register ID: describe an architectural register with its class and index.
Definition:
reg_class.hh:75
BaseISA
Definition:
isa.hh:47
PowerISA::ISA::ISA
ISA(Params *p)
Definition:
isa.cc:45
PowerISA::ISA::flattenCCIndex
int flattenCCIndex(int reg) const
Definition:
isa.hh:130
MipsISA::p
Bitfield< 0 > p
Definition:
pra_constants.hh:323
EventManager
Definition:
eventq.hh:905
PowerISA::ISA::readMiscReg
RegVal readMiscReg(int misc_reg, ThreadContext *tc)
Definition:
isa.hh:78
PowerISA::ISA
Definition:
isa.hh:48
Generated on Thu May 28 2020 16:11:02 for gem5 by
doxygen
1.8.13