gem5
v21.0.0.0
|
#include <inst_res.hh>
Classes | |
union | MultiResult |
Public Types | |
enum | ResultType { ResultType::Scalar, ResultType::VecElem, ResultType::VecReg, ResultType::VecPredReg, ResultType::NumResultTypes, ResultType::Invalid } |
Public Member Functions | |
InstResult () | |
Default constructor creates an invalid result. More... | |
InstResult (const InstResult &)=default | |
template<typename T > | |
InstResult (T i, const ResultType &t) | |
Scalar result from scalar. More... | |
InstResult (const TheISA::VecRegContainer &v, const ResultType &t) | |
Vector result. More... | |
InstResult (const TheISA::VecPredRegContainer &v, const ResultType &t) | |
Predicate result. More... | |
InstResult & | operator= (const InstResult &that) |
bool | operator== (const InstResult &that) const |
Result comparison Two invalid results always differ. More... | |
bool | operator!= (const InstResult &that) const |
bool | isScalar () const |
Checks. More... | |
bool | isVector () const |
Is this a vector result?. More... | |
bool | isVecElem () const |
Is this a vector element result?. More... | |
bool | isPred () const |
Is this a predicate result?. More... | |
bool | isValid () const |
Is this a valid result?. More... | |
const uint64_t & | asInteger () const |
Explicit cast-like operations. More... | |
const uint64_t & | asIntegerNoAssert () const |
Cast to integer without checking type. More... | |
const TheISA::VecRegContainer & | asVector () const |
const TheISA::VecElem & | asVectorElem () const |
const TheISA::VecPredRegContainer & | asPred () const |
Private Attributes | |
MultiResult | result |
ResultType | type |
Definition at line 46 of file inst_res.hh.
|
strong |
Enumerator | |
---|---|
Scalar | |
VecElem | |
VecReg | |
VecPredReg | |
NumResultTypes | |
Invalid |
Definition at line 58 of file inst_res.hh.
|
inline |
Default constructor creates an invalid result.
Definition at line 73 of file inst_res.hh.
|
default |
|
inlineexplicit |
Scalar result from scalar.
Definition at line 77 of file inst_res.hh.
References InstResult::MultiResult::dbl, ArmISA::i, InstResult::MultiResult::integer, and result.
|
inlineexplicit |
Vector result.
Definition at line 88 of file inst_res.hh.
References result, ArmISA::v, and InstResult::MultiResult::vector.
|
inlineexplicit |
Predicate result.
Definition at line 91 of file inst_res.hh.
References InstResult::MultiResult::pred, result, and ArmISA::v.
|
inline |
Explicit cast-like operations.
Definition at line 165 of file inst_res.hh.
References InstResult::MultiResult::integer, isScalar(), and result.
Referenced by Checker< O3CPUImpl >::copyResult(), and Checker< O3CPUImpl >::validateExecution().
|
inline |
Cast to integer without checking type.
This is required to have the o3 cpu checker happy, as it compares results as integers without being fully aware of their nature.
Definition at line 176 of file inst_res.hh.
References InstResult::MultiResult::integer, and result.
Referenced by Checker< O3CPUImpl >::validateExecution().
|
inline |
Definition at line 194 of file inst_res.hh.
References isPred(), panic_if, InstResult::MultiResult::pred, and result.
|
inline |
Definition at line 181 of file inst_res.hh.
References isVector(), panic_if, result, and InstResult::MultiResult::vector.
Referenced by Checker< O3CPUImpl >::copyResult().
|
inline |
Definition at line 187 of file inst_res.hh.
References isVecElem(), panic_if, result, and InstResult::MultiResult::vecElem.
Referenced by Checker< O3CPUImpl >::copyResult().
|
inline |
Is this a predicate result?.
Definition at line 157 of file inst_res.hh.
References type, and VecPredReg.
Referenced by asPred().
|
inline |
Checks.
Is this a scalar result?.
Definition at line 151 of file inst_res.hh.
Referenced by asInteger(), Checker< O3CPUImpl >::copyResult(), and Checker< O3CPUImpl >::validateExecution().
|
inline |
Is this a valid result?.
Definition at line 159 of file inst_res.hh.
Referenced by Checker< O3CPUImpl >::copyResult().
|
inline |
Is this a vector element result?.
Definition at line 155 of file inst_res.hh.
Referenced by asVectorElem(), and Checker< O3CPUImpl >::copyResult().
|
inline |
Is this a vector result?.
Definition at line 153 of file inst_res.hh.
Referenced by asVector(), Checker< O3CPUImpl >::copyResult(), and Checker< O3CPUImpl >::validateExecution().
|
inline |
Definition at line 144 of file inst_res.hh.
References operator==().
|
inline |
Definition at line 95 of file inst_res.hh.
References InstResult::MultiResult::integer, Invalid, panic, InstResult::MultiResult::pred, result, Scalar, type, InstResult::MultiResult::vecElem, VecElem, VecPredReg, VecReg, and InstResult::MultiResult::vector.
|
inline |
Result comparison Two invalid results always differ.
Definition at line 125 of file inst_res.hh.
References InstResult::MultiResult::integer, Invalid, panic, InstResult::MultiResult::pred, result, Scalar, type, InstResult::MultiResult::vecElem, VecElem, VecPredReg, VecReg, and InstResult::MultiResult::vector.
Referenced by operator!=().
|
private |
Definition at line 68 of file inst_res.hh.
Referenced by asInteger(), asIntegerNoAssert(), asPred(), asVector(), asVectorElem(), InstResult(), operator=(), and operator==().
|
private |
Definition at line 69 of file inst_res.hh.
Referenced by isPred(), isScalar(), isValid(), isVecElem(), isVector(), operator=(), and operator==().