Today the safepoint IR verifier catches some unrelocated uses of base pointers
that are actually valid.
With this change, we narrow down the set of false positives. Specifically, the
verifier knows about compares to null and compares between 2 unrelocated
pointers.
Details
Diff Detail
- Build Status
Buildable 8032 Build 8032: arc lint + arc unit
Event Timeline
lib/IR/SafepointIRVerifier.cpp | ||
---|---|---|
222–223 | Don't you want to re-write this utility function without recursion? | |
433 | if both parts are true it means both are relocated pointers, why do we return false? Did I miss anything? |
lib/IR/SafepointIRVerifier.cpp | ||
---|---|---|
222–223 | Yeah, that might be better. I'll check it in as NFC, along with the BaseType enum return. We'll still need the visited parameter to avoid traversing through the operands again in the worklist. | |
433 | The reason is because we are interested only in valid *unrelocated* uses. This happens only when both operands are unrelocated: these operands are either null, constant pointers or non-constant pointers (please see the comment above: lines 383). |
Need to rebase code over the NFC refactoring.
lib/IR/SafepointIRVerifier.cpp | ||
---|---|---|
222–223 | Checked in NFC refactoring change: https://reviews.llvm.org/rL307340 |
lib/IR/SafepointIRVerifier.cpp | ||
---|---|---|
433 | Got it. It is not a bool algebra :) !hasValidUnrelocatedUse does not mean has invalid :) it means has not or has invalid. |
Don't you want to re-write this utility function without recursion?
In this case you will not need Visited parameter. Also I would suggest this function returns enum BaseType.