Use of path manipulation function without maximum-sized buffer checking
Destination buffer of getwd or realpath is
smaller than PATH_MAX bytes
Description
This defect occurs when the destination argument of a path manipulation function such
as realpath or getwd has a buffer size less than
PATH_MAX bytes.
Risk
A buffer smaller than PATH_MAX bytes can overflow but you
cannot test the function return value to determine if an overflow occurred. If an
overflow occurs, following the function call, the content of the buffer is
undefined.
For instance, char *getwd(char *buf) copies an absolute path
name of the current folder to its argument. If the length of the absolute path name
is greater than PATH_MAX bytes, getwd returns
NULL and the content of *buf is undefined.
You can test the return value of getwd for
NULL to see if the function call succeeded.
However, if the allowed buffer for buf is less than
PATH_MAX bytes, a failure can occur for a smaller absolute
path name. In this case, getwd does not return
NULL even though a failure occurred. Therefore, the allowed
buffer for buf must be PATH_MAX bytes
long.
Fix
Possible fixes are:
Use a buffer size of
PATH_MAXbytes. If you obtain the buffer from an unknown source, before using the buffer as argument ofgetwdorrealpathfunction, make sure that the size is less thanPATH_MAXbytes.Use a path manipulation function that allows you to specify a buffer size.
For instance, if you are using
getwdto get the absolute path name of the current folder, usechar *getcwd(char *buf, size_t size);instead. The additional argumentsizeallows you to specify a size greater than or equal toPATH_MAX.Allow the function to allocate additional memory dynamically, if possible.
For instance,
char *realpath(const char *path, char *resolved_path);dynamically allocates memory ifresolved_pathisNULL. However, you have to deallocate this memory later using thefreefunction.
Examples
Result Information
| Group: Static memory |
| Language: C | C++ |
| Default: Off |
Command-Line Syntax:
PATH_BUFFER_OVERFLOW |
| Impact: High |
Version History
Introduced in R2015b
See Also
Topics
- Interpret Bug Finder Results in Polyspace Desktop User Interface
- Interpret Bug Finder Results in Polyspace Access Web Interface (Polyspace Access)
- Address Results in Polyspace User Interface Through Bug Fixes or Justifications
- Address Results in Polyspace Access Through Bug Fixes or Justifications (Polyspace Access)