MISRA C:2023 Rule 21.15
The pointer arguments to the Standard Library functions memcpy, memmove and memcmp shall
be pointers to qualified or unqualified versions of compatible types
Since R2024a
Description
Rule Definition
The pointer arguments to the Standard Library functions memcpy, memmove and memcmp shall
be pointers to qualified or unqualified versions of compatible types.1
This rule comes from MISRA C™: 2012 Amendment 1.
Rationale
The functions
memcpy( arg1, arg2, num_bytes ); memmove( arg1, arg2, num_bytes ); memcmp( arg1, arg2, num_bytes );
arg1 and arg2 point
to. A byte-by-byte copy, move or comparison is meaningful only if arg1 and arg2 have
compatible types.Using pointers to different data types for arg1 and arg2 typically
indicates a coding error.
Troubleshooting
If you expect a rule violation but do not see it, refer to Diagnose Why Coding Standard Violations Do Not Appear as Expected.
Examples
Check Information
| Group: Standard libraries |
| Category: Required |
| AGC Category: Required |
Version History
Introduced in R2024a
1 All MISRA coding rules and directives are © Copyright The MISRA Consortium Limited 2021.
The MISRA coding standards referenced in the Polyspace® Bug Finder™ documentation are from the following MISRA standards:
MISRA C:2004
MISRA C:2012
MISRA C:2023
MISRA C++:2008
MISRA C++:2023
MISRA and MISRA C are registered trademarks of The MISRA Consortium Limited 2021.