 
                            ...
| Rule | Severity | Likelihood | Detectable | Repairable | Priority | Level | 
|---|---|---|---|---|---|---|
| MEM31-C | Medium | Probable | No | No | P4 | L3 | 
Automated Detection
| Tool | Version | Checker | Description | ||||||
|---|---|---|---|---|---|---|---|---|---|
| Astrée | 
 | Supported, but no explicit checker | |||||||
| Axivion Bauhaus Suite | 
 | CertC-MEM31 | Can detect dynamically allocated resources that are not freed | ||||||
| CodeSonar | 
 | ALLOC.LEAK | Leak | ||||||
| Compass/ROSE | |||||||||
| 
 | RESOURCE_LEAK ALLOC_FREE_MISMATCH | Finds resource leaks from variables that go out of scope while owning a resource | |||||||
| Cppcheck | 
 | memleak leakReturnValNotUsed leakUnsafeArgAlloc memleakOnRealloc | |||||||
| Cppcheck Premium | 
 | memleak leakReturnValNotUsed leakUnsafeArgAlloc memleakOnRealloc | |||||||
| Helix QAC | 
 | DF2706, DF2707, DF2708 C++3337, C++3338 | |||||||
| Klocwork | 
 | CL.FFM.ASSIGN CL.FFM.COPY CL.SHALLOW.ASSIGN CL.SHALLOW.COPY FMM.MIGHT FMM.MUST | |||||||
| LDRA tool suite | 
 | 50 D | Partially implemented | ||||||
| Parasoft C/C++test | 
 | CERT_C-MEM31-a | Ensure resources are freed | ||||||
| Parasoft Insure++ | Runtime analysis | ||||||||
| PC-lint Plus | 
 | 429 | Fully supported | ||||||
| Polyspace Bug Finder | 
 | CERT C: Rule MEM31-C | Checks for memory leak (rule fully covered) | ||||||
| PVS-Studio | 
 | V773 | |||||||
| SonarQube C/C++ Plugin | 
 | S3584 | |||||||
| Splint | 
 | ||||||||
| TrustInSoft Analyzer | 
 | malloc | Exhaustively verified. | 
...
CWE-404 = Union( FIO42-C, MEM31-C list) where list =
- Failure to free resources besides files or memory chunks, such as mutexes)
Bibliography
| [ISO/IEC 9899:2024] | Subclause 7.24.3, "Memory Management Functions" | 
...