gem5
v21.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
c
d
e
f
g
h
i
m
n
o
p
r
s
t
u
v
w
x
Enumerations
a
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
n
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
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
q
r
s
t
v
Enumerator
_
a
b
c
d
e
f
g
h
i
k
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
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
void
clear
() {}
56
57
public
:
58
RegVal
59
readMiscRegNoEffect
(
int
misc_reg)
const
60
{
61
fatal
(
"Power does not currently have any misc regs defined\n"
);
62
return
dummy
;
63
}
64
65
RegVal
66
readMiscReg
(
int
misc_reg)
67
{
68
fatal
(
"Power does not currently have any misc regs defined\n"
);
69
return
dummy
;
70
}
71
72
void
73
setMiscRegNoEffect
(
int
misc_reg,
RegVal
val
)
74
{
75
fatal
(
"Power does not currently have any misc regs defined\n"
);
76
}
77
78
void
79
setMiscReg
(
int
misc_reg,
RegVal
val
)
80
{
81
fatal
(
"Power does not currently have any misc regs defined\n"
);
82
}
83
84
RegId
flattenRegId
(
const
RegId
& regId)
const
{
return
regId; }
85
86
int
87
flattenIntIndex
(
int
reg
)
const
88
{
89
return
reg
;
90
}
91
92
int
93
flattenFloatIndex
(
int
reg
)
const
94
{
95
return
reg
;
96
}
97
98
int
99
flattenVecIndex
(
int
reg
)
const
100
{
101
return
reg
;
102
}
103
104
int
105
flattenVecElemIndex
(
int
reg
)
const
106
{
107
return
reg
;
108
}
109
110
int
111
flattenVecPredIndex
(
int
reg
)
const
112
{
113
return
reg
;
114
}
115
116
// dummy
117
int
118
flattenCCIndex
(
int
reg
)
const
119
{
120
return
reg
;
121
}
122
123
int
124
flattenMiscIndex
(
int
reg
)
const
125
{
126
return
reg
;
127
}
128
129
bool
130
inUserMode
()
const override
131
{
132
return
false
;
133
}
134
135
using
Params
= PowerISAParams;
136
137
ISA
(
const
Params
&
p
);
138
};
139
140
}
// namespace PowerISA
141
142
#endif // __ARCH_POWER_ISA_HH__
fatal
#define fatal(...)
This implements a cprintf based fatal() function.
Definition:
logging.hh:183
PowerISA::ISA::flattenCCIndex
int flattenCCIndex(int reg) const
Definition:
isa.hh:118
PowerISA::ISA::inUserMode
bool inUserMode() const override
Definition:
isa.hh:130
PowerISA::ISA::flattenFloatIndex
int flattenFloatIndex(int reg) const
Definition:
isa.hh:93
PowerISA::ISA::flattenVecElemIndex
int flattenVecElemIndex(int reg) const
Definition:
isa.hh:105
PowerISA::ISA::flattenRegId
RegId flattenRegId(const RegId ®Id) const
Definition:
isa.hh:84
PowerISA::ISA
Definition:
isa.hh:48
PowerISA::ISA::flattenIntIndex
int flattenIntIndex(int reg) const
Definition:
isa.hh:87
PowerISA::ISA::flattenVecIndex
int flattenVecIndex(int reg) const
Definition:
isa.hh:99
PowerISA::ISA::flattenMiscIndex
int flattenMiscIndex(int reg) const
Definition:
isa.hh:124
PowerISA::ISA::dummy
RegVal dummy
Definition:
isa.hh:51
PowerISA::ISA::setMiscReg
void setMiscReg(int misc_reg, RegVal val)
Definition:
isa.hh:79
X86ISA::reg
Bitfield< 5, 3 > reg
Definition:
types.hh:88
RegId
Register ID: describe an architectural register with its class and index.
Definition:
reg_class.hh:75
PowerISA::ISA::readMiscRegNoEffect
RegVal readMiscRegNoEffect(int misc_reg) const
Definition:
isa.hh:59
ThreadContext
ThreadContext is the external interface to all thread state for anything outside of the CPU.
Definition:
thread_context.hh:88
PowerISA
Definition:
decoder.cc:31
PowerISA::ISA::miscRegs
RegVal miscRegs[NumMiscRegs]
Definition:
isa.hh:52
sim_object.hh
registers.hh
X86ISA::val
Bitfield< 63 > val
Definition:
misc.hh:769
isa.hh
PowerISA::NumMiscRegs
const int NumMiscRegs
Definition:
registers.hh:70
PowerISA::ISA::readMiscReg
RegVal readMiscReg(int misc_reg)
Definition:
isa.hh:66
reg_class.hh
PowerISA::ISA::Params
PowerISAParams Params
Definition:
isa.hh:135
logging.hh
PowerISA::ISA::ISA
ISA(const Params &p)
Definition:
isa.cc:45
PowerISA::ISA::clear
void clear()
Definition:
isa.hh:55
EventManager
Definition:
eventq.hh:984
MipsISA::p
Bitfield< 0 > p
Definition:
pra_constants.hh:323
PowerISA::ISA::flattenVecPredIndex
int flattenVecPredIndex(int reg) const
Definition:
isa.hh:111
PowerISA::ISA::setMiscRegNoEffect
void setMiscRegNoEffect(int misc_reg, RegVal val)
Definition:
isa.hh:73
BaseISA
Definition:
isa.hh:47
types.hh
RegVal
uint64_t RegVal
Definition:
types.hh:174
Generated on Tue Mar 23 2021 19:41:19 for gem5 by
doxygen
1.8.17