diff options
author | Ben Shi <2283975856@qq.com> | 2024-01-31 12:50:23 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-31 12:50:23 +0800 |
commit | c12f30c7ffedb2338d64d8f98a76ae56c497cfbb (patch) | |
tree | 9b4a71f8666a968dae18510f1395a4cc5800b62e | |
parent | 150ab99583e252a809b94f89da2576a1fc808297 (diff) | |
download | llvm-c12f30c7ffedb2338d64d8f98a76ae56c497cfbb.zip llvm-c12f30c7ffedb2338d64d8f98a76ae56c497cfbb.tar.gz llvm-c12f30c7ffedb2338d64d8f98a76ae56c497cfbb.tar.bz2 |
[clang][analyzer] Improve modeling of 'realpath' in StdLibraryFunctionsChecker (#79939)
-rw-r--r-- | clang/lib/StaticAnalyzer/Checkers/StdLibraryFunctionsChecker.cpp | 8 | ||||
-rw-r--r-- | clang/test/Analysis/errno-stdlibraryfunctions.c | 10 |
2 files changed, 16 insertions, 2 deletions
diff --git a/clang/lib/StaticAnalyzer/Checkers/StdLibraryFunctionsChecker.cpp b/clang/lib/StaticAnalyzer/Checkers/StdLibraryFunctionsChecker.cpp index be26f55..0c6293e6 100644 --- a/clang/lib/StaticAnalyzer/Checkers/StdLibraryFunctionsChecker.cpp +++ b/clang/lib/StaticAnalyzer/Checkers/StdLibraryFunctionsChecker.cpp @@ -2992,12 +2992,16 @@ void StdLibraryFunctionsChecker::initFunctionSummaries( // char *realpath(const char *restrict file_name, // char *restrict resolved_name); - // FIXME: Improve for errno modeling. + // FIXME: If the argument 'resolved_name' is not NULL, macro 'PATH_MAX' + // should be defined in "limits.h" to guarrantee a success. addToFunctionSummaryMap( "realpath", Signature(ArgTypes{ConstCharPtrRestrictTy, CharPtrRestrictTy}, RetType{CharPtrTy}), - Summary(NoEvalCall).ArgConstraint(NotNull(ArgNo(0)))); + Summary(NoEvalCall) + .Case({NotNull(Ret)}, ErrnoMustNotBeChecked, GenericSuccessMsg) + .Case({IsNull(Ret)}, ErrnoNEZeroIrrelevant, GenericFailureMsg) + .ArgConstraint(NotNull(ArgNo(0)))); QualType CharPtrConstPtr = getPointerTy(getConstTy(CharPtrTy)); diff --git a/clang/test/Analysis/errno-stdlibraryfunctions.c b/clang/test/Analysis/errno-stdlibraryfunctions.c index 9b487fe..a28efb7 100644 --- a/clang/test/Analysis/errno-stdlibraryfunctions.c +++ b/clang/test/Analysis/errno-stdlibraryfunctions.c @@ -128,3 +128,13 @@ void errno_pclose(void) { if (errno) {} // expected-warning{{An undefined value may be read from 'errno'}} } } + +void errno_realpath(char *Path, char *Buf) { + char *Ret = realpath(Path, Buf); + if (!Ret) { + clang_analyzer_eval(errno != 0); // expected-warning{{TRUE}} + if (errno) {} // no-warning + } else { + if (errno) {} // expected-warning{{An undefined value may be read from 'errno'}} + } +} |