Skip to content

Commit c12f30c

Browse files
authored
[clang][analyzer] Improve modeling of 'realpath' in StdLibraryFunctionsChecker (#79939)
1 parent 150ab99 commit c12f30c

File tree

2 files changed

+16
-2
lines changed

2 files changed

+16
-2
lines changed

clang/lib/StaticAnalyzer/Checkers/StdLibraryFunctionsChecker.cpp

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2992,12 +2992,16 @@ void StdLibraryFunctionsChecker::initFunctionSummaries(
29922992

29932993
// char *realpath(const char *restrict file_name,
29942994
// char *restrict resolved_name);
2995-
// FIXME: Improve for errno modeling.
2995+
// FIXME: If the argument 'resolved_name' is not NULL, macro 'PATH_MAX'
2996+
// should be defined in "limits.h" to guarrantee a success.
29962997
addToFunctionSummaryMap(
29972998
"realpath",
29982999
Signature(ArgTypes{ConstCharPtrRestrictTy, CharPtrRestrictTy},
29993000
RetType{CharPtrTy}),
3000-
Summary(NoEvalCall).ArgConstraint(NotNull(ArgNo(0))));
3001+
Summary(NoEvalCall)
3002+
.Case({NotNull(Ret)}, ErrnoMustNotBeChecked, GenericSuccessMsg)
3003+
.Case({IsNull(Ret)}, ErrnoNEZeroIrrelevant, GenericFailureMsg)
3004+
.ArgConstraint(NotNull(ArgNo(0))));
30013005

30023006
QualType CharPtrConstPtr = getPointerTy(getConstTy(CharPtrTy));
30033007

clang/test/Analysis/errno-stdlibraryfunctions.c

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -128,3 +128,13 @@ void errno_pclose(void) {
128128
if (errno) {} // expected-warning{{An undefined value may be read from 'errno'}}
129129
}
130130
}
131+
132+
void errno_realpath(char *Path, char *Buf) {
133+
char *Ret = realpath(Path, Buf);
134+
if (!Ret) {
135+
clang_analyzer_eval(errno != 0); // expected-warning{{TRUE}}
136+
if (errno) {} // no-warning
137+
} else {
138+
if (errno) {} // expected-warning{{An undefined value may be read from 'errno'}}
139+
}
140+
}

0 commit comments

Comments
 (0)