JavaScript is not currently enabled, but is required for full CodeSonar manual search and browse functionality.

If you are viewing this file in your hub's Web GUI, enable JavaScript in your browser: you will also need it for GUI functionality.

If you opened this file directly from disk, your browser may be directly suppressing JavaScript functionality: certain browsers perform this suppression on local files (but not files delivered by web servers) for security reasons.

CodeSonar® 9.2p0 CONFIDENTIAL CodeSecure Inc
C and C++
Binaries


BADFUNC.BO.OEMTOCHAR : Use of {OemToAnsi,OemToChar}

Summary

A use of OemToAnsi(), OemToAnsiA(), OemToAnsiW(), OemToChar(), OemToCharA(), or OemToCharW(), which are vulnerable to buffer overflows.

Properties

Multiple warning classes share this mnemonic.

Checks for all these warning classes are disabled by default. To enable them all at once, add the following WARNING_FILTER rule to the project configuration file.

WARNING_FILTER += allow categories:BADFUNC.BO.OEMTOCHAR
Class Name Use of OemToAnsi
Significance security
Mnemonic BADFUNC.BO.OEMTOCHAR
Categories
AUTOSARC++14 AUTOSARC++14:A5-2-5 An array or container shall not be accessed beyond its range.
CWE CWE:120 Buffer Copy without Checking Size of Input ('Classic Buffer Overflow')
  CWE:676 Use of Potentially Dangerous Function
CERT-C CERT-C:API02-C Functions that read or write to or from an array should take an argument to specify the source or target size
  CERT-C:STR07-C Use the bounds-checking interfaces for string manipulation
  CERT-C:STR31-C Guarantee that storage for strings has sufficient space for character data and the null terminator
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:OemToChar  
OWASP-2017 OWASP-2017:A9 Using components with known vulnerabilities
OWASP-2021 OWASP-2021:A4 Insecure design
  OWASP-2021:A6 Vulnerable and outdated components
OWASP-2025 OWASP-2025:A03 Software Supply Chain Failures
  OWASP-2025:A06 Insecure Design
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 OemToAnsi"
To enable all BSI-related classes, including all BSI-specific BADFUNC classes, use the bsi configuration preset.
Class Name Use of OemToChar
Significance security
Mnemonic BADFUNC.BO.OEMTOCHAR
Categories
AUTOSARC++14 AUTOSARC++14:A5-2-5 An array or container shall not be accessed beyond its range.
CWE CWE:120 Buffer Copy without Checking Size of Input ('Classic Buffer Overflow')
  CWE:676 Use of Potentially Dangerous Function
CERT-C CERT-C:API02-C Functions that read or write to or from an array should take an argument to specify the source or target size
  CERT-C:STR07-C Use the bounds-checking interfaces for string manipulation
  CERT-C:STR31-C Guarantee that storage for strings has sufficient space for character data and the null terminator
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:OemToChar  
OWASP-2017 OWASP-2017:A9 Using components with known vulnerabilities
OWASP-2021 OWASP-2021:A4 Insecure design
  OWASP-2021:A6 Vulnerable and outdated components
OWASP-2025 OWASP-2025:A03 Software Supply Chain Failures
  OWASP-2025:A06 Insecure Design
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 OemToChar"
To enable all BSI-related classes, including all BSI-specific BADFUNC classes, use the bsi configuration preset.

Warning Classes

Warning Class Triggering Functions
Use of OemToAnsi OemToAnsi(), OemToAnsiA(), OemToAnsiW()
Use of OemToChar OemToChar(), OemToCharA(), OemToCharW()

Resolution

Use OemToCharBuff() instead.

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.

 

To report problems with this documentation, please visit https://support.codesecure.com/.