diff options
author | Kristof Umann <dkszelethus@gmail.com> | 2019-03-14 16:10:29 +0000 |
---|---|---|
committer | Kristof Umann <dkszelethus@gmail.com> | 2019-03-14 16:10:29 +0000 |
commit | 4962816e7242b9cec7a1a1157e4efaac75a6120a (patch) | |
tree | 2ddff6e82f79a0a6ef6901f2058909cad53bf67c /llvm/lib/CodeGen/MachineInstr.cpp | |
parent | ac093d61c468b96f82d719f75e4dca8eab1e85cb (diff) | |
download | llvm-4962816e7242b9cec7a1a1157e4efaac75a6120a.zip llvm-4962816e7242b9cec7a1a1157e4efaac75a6120a.tar.gz llvm-4962816e7242b9cec7a1a1157e4efaac75a6120a.tar.bz2 |
[analyzer] Fix an assertation failure for invalid sourcelocation, add a new debug checker
For a rather short code snippet, if debug.ReportStmts (added in this patch) was
enabled, a bug reporter visitor crashed:
struct h {
operator int();
};
int k() {
return h();
}
Ultimately, this originated from PathDiagnosticLocation::createMemberLoc, as it
didn't handle the case where it's MemberExpr typed parameter returned and
invalid SourceLocation for MemberExpr::getMemberLoc. The solution was to find
any related valid SourceLocaion, and Stmt::getBeginLoc happens to be just that.
Differential Revision: https://reviews.llvm.org/D58777
llvm-svn: 356161
Diffstat (limited to 'llvm/lib/CodeGen/MachineInstr.cpp')
0 files changed, 0 insertions, 0 deletions