CVE Vulnerabilities

CVE-2018-5392

Access of Uninitialized Pointer

Published: Aug 14, 2018 | Modified: Nov 21, 2024
CVSS 3.x
7.5
HIGH
Source:
NVD
CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:N
CVSS 2.x
5 MEDIUM
AV:N/AC:L/Au:N/C:N/I:P/A:N
RedHat/V2
RedHat/V3
Ubuntu
LOW

mingw-w64 version 5.0.4 by default produces executables that opt in to ASLR, but are not compatible with ASLR. ASLR is an exploit mitigation technique used by modern Windows platforms. For ASLR to function, Windows executables must contain a relocations table. Despite containing the Dynamic base PE header, which indicates ASLR compatibility, Windows executables produced by mingw-w64 have the relocations table stripped from them by default. This means that executables produced by mingw-w64 are vulnerable to return-oriented programming (ROP) attacks. Windows executables generated by mingw-w64 claim to be ASLR compatible, but are not. Vulnerabilities in such executables are more easily exploitable as a result.

Weakness

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

Affected Software

Name Vendor Start Version End Version
Mingw-w64 Mingw 5.0.4 (including) 5.0.4 (including)
Mingw-w64 Ubuntu bionic *
Mingw-w64 Ubuntu cosmic *
Mingw-w64 Ubuntu disco *
Mingw-w64 Ubuntu eoan *
Mingw-w64 Ubuntu groovy *
Mingw-w64 Ubuntu hirsute *
Mingw-w64 Ubuntu impish *
Mingw-w64 Ubuntu kinetic *
Mingw-w64 Ubuntu lunar *
Mingw-w64 Ubuntu mantic *
Mingw-w64 Ubuntu trusty *
Mingw-w64 Ubuntu trusty/esm *
Mingw-w64 Ubuntu xenial *

Extended Description

If the pointer contains an uninitialized value, then the value might not point to a valid memory location. This could cause the product 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 product 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.

References