mirror of
https://github.com/NationalSecurityAgency/ghidra.git
synced 2025-10-04 10:19:23 +02:00
added RulePositiveDiv
This commit is contained in:
parent
165377aad7
commit
992d32dd87
3 changed files with 39 additions and 0 deletions
|
@ -6448,6 +6448,33 @@ int4 RuleSubNormal::applyOp(PcodeOp *op,Funcdata &data)
|
|||
return 1;
|
||||
}
|
||||
|
||||
/// \class RulePositiveDiv
|
||||
/// \brief Signed division of positive values is unsigned division
|
||||
///
|
||||
/// If the sign bit of both the numerator and denominator of a signed division (or remainder)
|
||||
/// are zero, then convert to the unsigned form of the operation.
|
||||
void RulePositiveDiv::getOpList(vector<uint4> &oplist) const
|
||||
|
||||
{
|
||||
oplist.push_back(CPUI_INT_SDIV);
|
||||
oplist.push_back(CPUI_INT_SREM);
|
||||
}
|
||||
|
||||
int4 RulePositiveDiv::applyOp(PcodeOp *op,Funcdata &data)
|
||||
|
||||
{
|
||||
int4 sa = op->getOut()->getSize();
|
||||
if (sa > sizeof(uintb)) return 0;
|
||||
sa = sa * 8 - 1;
|
||||
if (((op->getIn(0)->getNZMask() >> sa) & 1) != 0)
|
||||
return 0; // Input 0 may be negative
|
||||
if (((op->getIn(1)->getNZMask() >> sa) & 1) != 0)
|
||||
return 0; // Input 1 may be negative
|
||||
OpCode opc = (op->code() == CPUI_INT_SDIV) ? CPUI_INT_DIV : CPUI_INT_REM;
|
||||
data.opSetOpcode(op, opc);
|
||||
return 1;
|
||||
}
|
||||
|
||||
/// \class RuleDivTermAdd
|
||||
/// \brief Simplify expressions associated with optimized division expressions
|
||||
///
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue