The behavior of a program is undefined when it uses Using the value of a pointer to a FILE
object after the associated file is closed is undefined behavior. (see See undefined behavior 148153.) Programs that close the standard streams (especially stdout
but also stderr
and stdin
) must be careful not to use the stream objects these streams in subsequent function calls, particularly those that implicitly operate on such objects them (such as printf()
, perror()
, and getc()
).
This rule can be generalized to other representations of files, such as an int
representing a POSIX file descriptor that has been passed to close()
file representations.
Noncompliant Code Example
In this noncompliant code example the printf()
function is called after , the stdout
stream is used after it is closed.:
Code Block | ||||
---|---|---|---|---|
| ||||
#include <stdio.h> int close_stdout(void) { if (fclose(stdout) == EOF) { return -1; } printf("stdout successfully closed.\n"); return 0; } |
...
In this compliant solution, stdout
is not used again after it is closed. This must remain true for the remainder of the program, or stdout
must be assigned the address of an open file object.
Code Block | ||||
---|---|---|---|---|
| ||||
#include <stdio.h> int close_stdout(void) { if (fclose(stdout) == EOF) { return -1; } fprintffputs(stderr, "stdout successfully closed.\n", stderr); return 0; } |
Risk Assessment
Using the value of a pointer to a FILE
object after the associated file is closed is undefined behavior.
Rule | Severity | Likelihood | Remediation Cost | Priority | Level |
---|---|---|---|---|---|
FIO46-C | Medium | Unlikely | Medium | P4 | L3 |
Automated Detection
Tool | Version | Checker | Description | ||||||
---|---|---|---|---|---|---|---|---|---|
Astrée |
| Supported | |||||||
CodeSonar |
| IO.UAC | Use after close | ||||||
Compass/ROSE |
5.0
Coverity |
| USE_AFTER_FREE | Implemented | ||||||
Helix QAC |
| DF2696, DF2697, DF2698 | |||||||
Klocwork |
|
RH.LEAK
SV.INCORRECT_RESOURCE_HANDLING.URH | |||||||
LDRA tool suite |
|
49 D
48 D | Partially implemented | ||||||||
Parasoft C/C++test |
| CERT_C-FIO46-a | Do not use resources that have been freed | ||||||
PC-lint Plus |
| 2471 | Fully supported | ||||||
Polyspace Bug Finder |
| Checks for use of previously closed resource (rule partially covered) | |||||||
SonarQube C/C++ Plugin |
| S3588 |
Related Vulnerabilities
Search for vulnerabilities resulting from the violation of this rule on the CERT website.
Bibliography
[IEEE Std 1003.1:2013] | XSH, System Interfaces, open |
[ISO/IEC 9899: |
2024] |
Subclause 7. |
23.3, "Files" |
23.5.1, "The |
...