[Forgot Password]
Login  Register Subscribe

23631

 
 

115083

 
 

97147

 
 

909

 
 

78764

 
 

109

Paid content will be excluded from the download.


Download | Alert*
CWE
view XML

Access of Uninitialized Pointer

ID: 824Date: (C)2012-05-14   (M)2017-09-27
Type: weaknessStatus: INCOMPLETE
Abstraction Type: Base





Description

The program accesses or uses a pointer that has not been initialized.

Extended Description

If the pointer contains an uninitialized value, then the value might not point to a valid memory location. This could cause the program to read from or write to unexpected memory locations, leading to a denial of service. If the uninitialized pointer is used as a function call, then arbitrary functions could be invoked. If an attacker can influence the portion of uninitialized memory that is contained in the pointer, this weakness could be leveraged to execute code or perform other attacks.

Depending on memory layout, associated memory management behaviors, and program operation, the attacker might be able to influence the contents of the uninitialized pointer, thus gaining more fine-grained control of the memory location to be accessed.

Applicable Platforms
None

Common Consequences

ScopeTechnical ImpactNotes
Confidentiality
 
Read memory
 
If the uninitialized pointer is used in a read operation, an attacker might be able to read sensitive portions of memory.
 
Availability
 
DoS: crash / exit / restart
 
If the uninitialized pointer references a memory location that is not accessible to the program, or points to a location that is "malformed" (such as NULL) or larger than expected by a read or write operation, then a crash may occur.
 
Integrity
Confidentiality
Availability
 
Execute unauthorized code or commands
 
If the uninitialized pointer is used in a function call, or points to unexpected data in a write operation, then code execution may be possible.
 

Detection Methods
None

Potential Mitigations
None

Relationships

Related CWETypeViewChain
CWE-824 CanPrecede CWE-787 Weakness CWE-1000  

Demonstrative Examples
None

Observed Examples

  1. CVE-2010-0211 : chain: unchecked return value (CWE-252) leads to free of invalid, uninitialized pointer (CWE-824).
  2. CVE-2009-2768 : Pointer in structure is not initialized, leading to NULL pointer dereference (CWE-476) and system crash.
  3. CVE-2009-1721 : Free of an uninitialized pointer.
  4. CVE-2009-1415 : Improper handling of invalid signatures leads to free of invalid pointer.
  5. CVE-2009-0846 : Invalid encoding triggers free of uninitialized pointer.
  6. CVE-2009-0040 : Crafted PNG image leads to free of uninitialized pointer.
  7. CVE-2008-2934 : Crafted GIF image leads to free of uninitialized pointer.
  8. CVE-2007-4682 : Access of uninitialized pointer might lead to code execution.
  9. CVE-2007-4639 : Step-based manipulation: invocation of debugging function before the primary initialization function leads to access of an uninitialized pointer and code execution.
  10. CVE-2007-4000 : Unchecked return values can lead to a write to an uninitialized pointer.
  11. CVE-2007-2442 : zero-length input leads to free of uninitialized pointer.
  12. CVE-2007-1213 : Crafted font leads to uninitialized function pointer.
  13. CVE-2006-6143 : Uninitialized function pointer in freed memory is invoked
  14. CVE-2006-4175 : LDAP server mishandles malformed BER queries, leading to free of uninitialized memory
  15. CVE-2006-0054 : Firewall can crash with certain ICMP packets that trigger access of an uninitialized pointer.
  16. CVE-2003-1201 : LDAP server does not initialize members of structs, which leads to free of uninitialized pointer if an LDAP request fails.

For more examples, refer to CVE relations in the bottom box.

White Box Definitions
None

Black Box Definitions
None

Taxynomy Mappings
None

References:

  1. Mark Dowd John McDonald Justin Schuh .The Art of Software Security Assessment 1st Edition. Addison Wesley. Section:'Chapter 7, "Variable Initialization", Page 312.'. Published on 2006.

© 2013 SecPod Technologies