Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Content by Label
showLabelsfalse
max99
spacescom.atlassian.confluence.content.render.xhtml.model.resource.identifiers.SpaceResourceIdentifier@3bbaf8c
showSpacefalse
sorttitle
cqllabel = "mem" and label = "rule" and label != "void" and space = currentSpace()
labels+mem,+rule,-void

Info

Information for Editors
In order to have a new guideline automatically listed above be sure to label it mem and rule.

Risk Assessment Summary

Rule

Severity

Likelihood

Detectable

Repairable

Priority

Level

MEM30-CHighLikelyNoNo

P9

L2

MEM31-CMediumProbableNoNo

P4

L3

MEM33-CLowUnlikelyYesNo

P2

L3

MEM34-CHighLikelyNoNo

P9

L2

MEM35-CHighProbableNoNo

P6

L2

MEM36-CLowProbableNoNo

P2

L3

Recommendations

MEM00-C. Allocate and free memory in the same module, at the same level of abstraction

MEM01-C. Store a new value in pointers immediately after free()

MEM02-C. Immediately cast the result of a memory allocation function call into a pointer to the allocated type

MEM03-C. Clear sensitive information stored in reusable resources returned for reuse

MEM04-C. Do not perform zero length allocations

MEM05-C. Avoid large stack allocations

MEM06-C. Ensure that sensitive data is not written out to disk

MEM07-C. Ensure that the arguments to calloc(), when multiplied, can be represented as a size_t

MEM08-C. Use realloc() only to resize dynamically allocated arrays

MEM09-C. Do not assume memory allocation routines initialize memory

MEM10-C. Define and use a pointer validation function

MEM11-C. Do not assume infinite heap space

MEM12-C. Use a Goto-Chain when leaving a function on error after allocating multiple objects

Rules

MEM30-C. Do not access freed memory

MEM31-C. Free dynamically allocated memory exactly once

MEM32-C. Detect and handle memory allocation errors

MEM33-C. Understand how flexible array members are to be used

MEM34-C. Only free memory allocated dynamically

MEM35-C. Allocate sufficient memory for an object

Risk Assessment Summary

Recommendation

Severity

likelihood

Remediation Cost

Priority

Level

MEM00-C

high

probable

medium

P12

L1

MEM01-C

high

unlikely

low

P9

L2

MEM02-C

low

unlikely

low

P3

L3

MEM03-C

medium

unlikely

high

P2

L3

MEM04-C

low

likely

medium

P6

L2

MEM05-C

low

likely

medium

P6

L2

MEM06-C

medium

unlikely

high

P2

L3

MEM07-C

high

unlikely

medium

P6

L2

MEM08-C

high

likely

medium

P18

L1

MEM09-C

medium

unlikely

medium

P4

L3

MEM10-C

high

unlikely

high

P3

L3

MEM12-C

low

probable

medium

P3

L3

Rule

Severity

likelihood

Remediation Cost

Priority

Level

MEM30-C

high

likely

medium

P18

L1

MEM31-C

high

probable

medium

P12

L1

MEM32-C

high

likely

medium

P18

L1

MEM33-C

low

unlikely

low

P3

L3

MEM34-C

high

likely

medium

P18

L1

MEM35-C

high

probable

high

P6

L2

Related Rules and Recommendations

Navigation Map
memory-management
memory-management
cellWidth700
wrapAfter1
cellHeight15

...

STR38-C. Do not use wide-char functions on narrow-char strings and vice versa      CERT C Secure Coding Standard      Image Added Image Added Image Modified