51 CCFlagBits ccflags =
flags;
61 return !(!ccflags.ezf && ccflags.zf);
63 panic(
"This condition is not implemented!");
65 panic(
"This condition is not implemented!");
67 panic(
"This condition is not implemented!");
69 return !ccflags.ezf && ccflags.zf;
78 return ccflags.cf | ccflags.zf;
84 return ccflags.sf ^ ccflags.of;
86 return (ccflags.sf ^ ccflags.of) | ccflags.zf;
94 return !ccflags.ezf && ccflags.zf;
96 panic(
"This condition is not implemented!");
98 panic(
"This condition is not implemented!");
100 panic(
"This condition is not implemented!");
102 return !ccflags.ezf && !ccflags.zf;
111 return !(ccflags.cf | ccflags.zf);
117 return !(ccflags.sf ^ ccflags.of);
119 return !((ccflags.sf ^ ccflags.of) | ccflags.zf);
121 panic(
"Unknown condition: %d\n", condition);
125std::unique_ptr<PCStateBase>
129 DPRINTF(X86,
"branchTarget PC info: %s, Immediate: %lx\n", *pcs,
134 return std::unique_ptr<PCStateBase>{pcs};
virtual PCStateBase * clone() const =0
std::bitset< Num_Flags > flags
Flag values for this instruction.
bool checkCondition(uint64_t flags, int condition) const
std::unique_ptr< PCStateBase > branchTarget(const PCStateBase &branch_pc) const override
Return the target address for a PC-relative branch.
#define panic(...)
This implements a cprintf based panic() function.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....