forked from OSchip/llvm-project
[TargetLowering] Respect recursive depth in SimplifyDemandedBits call to ComputeNumSignBits
This commit is contained in:
parent
66f93071cd
commit
4a5f9d9faf
|
@ -1629,7 +1629,8 @@ bool TargetLowering::SimplifyDemandedBits(
|
||||||
|
|
||||||
// If we only care about the highest bit, don't bother shifting right.
|
// If we only care about the highest bit, don't bother shifting right.
|
||||||
if (DemandedBits.isSignMask()) {
|
if (DemandedBits.isSignMask()) {
|
||||||
unsigned NumSignBits = TLO.DAG.ComputeNumSignBits(Op0);
|
unsigned NumSignBits =
|
||||||
|
TLO.DAG.ComputeNumSignBits(Op0, DemandedElts, Depth + 1);
|
||||||
bool AlreadySignExtended = NumSignBits >= BitWidth - ExVTBits + 1;
|
bool AlreadySignExtended = NumSignBits >= BitWidth - ExVTBits + 1;
|
||||||
// However if the input is already sign extended we expect the sign
|
// However if the input is already sign extended we expect the sign
|
||||||
// extension to be dropped altogether later and do not simplify.
|
// extension to be dropped altogether later and do not simplify.
|
||||||
|
|
Loading…
Reference in New Issue