MISRA C:2012 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
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 R2017a
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.