 
                            ...
If not properly performed, checking for the existence of symbolic links can lead to race conditions.
This rule is a specific instance of rule FIO45-C. Avoid TOCTOU race conditions while accessing files.
Noncompliant Code Example
...
This code contains a time-of-check, time-of-use (TOCTOU) race condition between the call to lstat() and the subsequent call to open() because both functions operate on a file name that can be manipulated asynchronously to the execution of the program. (See FIO01-C. Be careful using functions that use file names for identification.)
Compliant Solution (POSIX.1-2008 or newer)
This compliant solution eliminates the race condition by using O_NOFOLLOW to cause open() to fail if passed a symbolic link, avoiding the TOCTOU by not having a separate "check" and "use":
| Code Block | ||||
|---|---|---|---|---|
| 
 | ||||
| char *filename = /* file name */;
char *userbuf = /* user data */;
unsigned int userlen = /* length of userbuf string */;
int fd = open(filename, O_RDWR|O_NOFOLLOW);
if (fd == -1) {
  /* Handle error */
}
if (write(fd, userbuf, userlen) < userlen) {
  /* Handle error */
} | 
Compliant Solution (POSIX.1-2001 or older)
This compliant solution eliminates the race condition by
- Calling lstat()on the file name.
- Calling open()to open the file.
- Calling fstat()on the file descriptor returned byopen().
- Comparing the file information returned by the calls to lstat()andfstat()to ensure that the files are the same.
...
TOCTOU race condition vulnerabilities can be exploited to gain elevated privileges.
| Rule | Severity | Likelihood | Detectable | Remediation CostRepairable | Priority | Level | 
|---|---|---|---|---|---|---|
| POS35-C | High | Likelyhigh | likelyNo | mediumNo | P18P9 | L1L2 | 
Automated Detection
| Tool | Version | Checker | Description | ||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Astrée | 
 | user_defined | Soundly supported | ||||||||||
| Axivion Bauhaus Suite | 
 | CertC-POS35 | |||||||||||
| Compass/ROSE | Can detect some violations of this rule. In particular, it ensures that calls to  | ||||||||||||
| Coverity | 
 | TOCTOU | Implemented | ||||||||||
| Helix QAC | 
 | DF4886, DF4887, DF4888 | |||||||||||
| Klocwork | 
 | SV.TOCTOU.FILE_ACCESS | |||||||||||
| Parasoft C/C++test | 
 | SECURITY-19, BD-TRS-SYMLINKImplemented | CERT_C-POS35-b | Avoid race conditions while checking for the existence of a symbolic link | |||||||||
| Polyspace Bug Finder | File
 | CERT C: Rule POS35-C | )File or folder might change state due to access raceChecks for file access between time of check and use (TOCTOU | ) (rule fully covered) | 
Related Vulnerabilities
Search for vulnerabilities resulting from the violation of this rule on the CERT website.
...
| [Dowd 2006] | Chapter 9, "UNIX 1: Privileges and Files" | 
| [ISO/IEC 9899:20112024] | Section 7.2123, "Input/output <stdio.h>" | 
| [Open Group 2004] | lstat() fstat() open() | 
| [Seacord 2013] | Chapter 8, "File I/O" | 
...