C and C++ Binaries


BADFUNC.BO.STRCPY : Use of strcpy

Summary

A use of strcpy() or a similar function (see full list below), which are vulnerable to buffer overflows.

Properties

Class Name Use of strcpy
Significance security
Mnemonic BADFUNC.BO.STRCPY
Categories
MisraC2023 MisraC2023:21.17 Use of the string handling functions from <string.h> shall not result in accesses beyond the bounds of the objects referenced by their pointer parameters
Misra2012 Misra2012:21.17 Use of the string handling functions from <string.h> shall not result in accesses beyond the bounds of the objects referenced by their pointer parameters
AUTOSARC++14 AUTOSARC++14:A5-2-5 An array or container shall not be accessed beyond its range.
  AUTOSARC++14:M18-0-5 The unbounded functions of library <cstring> shall not be used.
MisraC++2008 MisraC++2008:18-0-5 The unbounded functions of library <cstring> shall not be used.
MisraC++2023 MisraC++2023:21.2.2 The string handling functions from <cstring>, <cstdlib>, <cwchar> and <cinttypes> shall not be used
CWE CWE:120 Buffer Copy without Checking Size of Input ('Classic Buffer Overflow')
  CWE:676 Use of Potentially Dangerous Function
TS17961 TS17961:5.36-taintstrcpy 5.36. Tainted strings are passed to a string copying function
CERT-C CERT-C:STR07-C Use the bounds-checking interfaces for string manipulation
CERT-CPP CERT-CPP:CTR52-CPP Guarantee that library functions do not overflow
DISA-6r1 DISA-6r1:V-222612 The application must not be vulnerable to overflow attacks.
DISA-5r3 DISA-5r3:V-70277 The application must not be vulnerable to overflow attacks.
DISA-4r3 DISA-4r3:V-70277 The application must not be vulnerable to overflow attacks.
DISA-3r10 DISA-3r10:V-6165 The designer will ensure the application does not have buffer overflows, use functions known to be vulnerable to buffer overflows, and does not use signed values for memory allocation where permitted by the programming language.
BSI BSI:STRCPY Use of strcpy
Availability Available for C and C++.
Enabling Checks for this warning class are disabled by default. To enable them, add the following WARNING_FILTER rule to the project configuration file.
WARNING_FILTER += allow class="Use of strcpy"
To enable all BSI-related classes, including all BSI-specific BADFUNC classes, use the bsi configuration preset.

Triggering Functions

Resolution

Use a function that does bounds checking, such as strncpy(), StrCbCopy(), or StrCchCopy().

Relevant Configuration File Parameters

This class is implemented using a BAD_FUNCTION_* rule set in the general template configuration file.

The following configuration file parameters affect checks for this warning class.