CVE Vulnerabilities

CVE-2018-4121

Improper Restriction of Operations within the Bounds of a Memory Buffer

Published: Apr 03, 2018 | Modified: Nov 21, 2024
CVSS 3.x
8.8
HIGH
Source:
NVD
CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:U/C:H/I:H/A:H
CVSS 2.x
6.8 MEDIUM
AV:N/AC:M/Au:N/C:P/I:P/A:P
RedHat/V2
RedHat/V3
5 MODERATE
CVSS:3.0/AV:N/AC:H/PR:N/UI:R/S:U/C:L/I:L/A:L
Ubuntu
MEDIUM
root.io logo minimus.io logo echo.ai logo

An issue was discovered in certain Apple products. iOS before 11.3 is affected. Safari before 11.1 is affected. iCloud before 7.4 on Windows is affected. iTunes before 12.7.4 on Windows is affected. tvOS before 11.3 is affected. watchOS before 4.3 is affected. The issue involves the WebKit component. It allows remote attackers to execute arbitrary code or cause a denial of service (memory corruption and application crash) via a crafted web site.

Weakness

The product performs operations on a memory buffer, but it reads from or writes to a memory location outside the buffer’s intended boundary. This may result in read or write operations on unexpected memory locations that could be linked to other variables, data structures, or internal program data.

Affected Software

NameVendorStart VersionEnd Version
SafariApple*11.1 (excluding)
Iphone_osApple*11.3 (excluding)
TvosApple*11.3 (excluding)
WatchosApple*4.3 (excluding)
Red Hat Enterprise Linux 7RedHataccountsservice-0:0.6.50-2.el7*
Red Hat Enterprise Linux 7RedHatadwaita-icon-theme-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatappstream-data-0:7-20180614.el7*
Red Hat Enterprise Linux 7RedHatatk-0:2.28.1-1.el7*
Red Hat Enterprise Linux 7RedHatat-spi2-atk-0:2.26.2-1.el7*
Red Hat Enterprise Linux 7RedHatat-spi2-core-0:2.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatbaobab-0:3.28.0-2.el7*
Red Hat Enterprise Linux 7RedHatbolt-0:0.4-3.el7*
Red Hat Enterprise Linux 7RedHatbrasero-0:3.12.2-5.el7*
Red Hat Enterprise Linux 7RedHatcairo-0:1.15.12-3.el7*
Red Hat Enterprise Linux 7RedHatcheese-2:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatclutter-gst3-0:3.0.26-1.el7*
Red Hat Enterprise Linux 7RedHatcompat-exiv2-023-0:0.23-2.el7*
Red Hat Enterprise Linux 7RedHatcontrol-center-1:3.28.1-4.el7*
Red Hat Enterprise Linux 7RedHatdconf-0:0.28.0-4.el7*
Red Hat Enterprise Linux 7RedHatdconf-editor-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatdevhelp-1:3.28.1-1.el7*
Red Hat Enterprise Linux 7RedHatekiga-0:4.0.1-8.el7*
Red Hat Enterprise Linux 7RedHatempathy-0:3.12.13-1.el7*
Red Hat Enterprise Linux 7RedHateog-0:3.28.3-1.el7*
Red Hat Enterprise Linux 7RedHatevince-0:3.28.2-5.el7*
Red Hat Enterprise Linux 7RedHatevolution-0:3.28.5-2.el7*
Red Hat Enterprise Linux 7RedHatevolution-data-server-0:3.28.5-1.el7*
Red Hat Enterprise Linux 7RedHatevolution-ews-0:3.28.5-1.el7*
Red Hat Enterprise Linux 7RedHatevolution-mapi-0:3.28.3-2.el7*
Red Hat Enterprise Linux 7RedHatfile-roller-0:3.28.1-2.el7*
Red Hat Enterprise Linux 7RedHatflatpak-0:1.0.2-2.el7*
Red Hat Enterprise Linux 7RedHatfolks-1:0.11.4-1.el7*
Red Hat Enterprise Linux 7RedHatfontconfig-0:2.13.0-4.3.el7*
Red Hat Enterprise Linux 7RedHatfreetype-0:2.8-12.el7*
Red Hat Enterprise Linux 7RedHatfribidi-0:1.0.2-1.el7*
Red Hat Enterprise Linux 7RedHatfwupd-0:1.0.8-4.el7*
Red Hat Enterprise Linux 7RedHatfwupdate-0:12-5.el7*
Red Hat Enterprise Linux 7RedHatgcr-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgdk-pixbuf2-0:2.36.12-3.el7*
Red Hat Enterprise Linux 7RedHatgdm-1:3.28.2-9.el7*
Red Hat Enterprise Linux 7RedHatgedit-2:3.28.1-1.el7*
Red Hat Enterprise Linux 7RedHatgedit-plugins-0:3.28.1-1.el7*
Red Hat Enterprise Linux 7RedHatgeoclue2-0:2.4.8-1.el7*
Red Hat Enterprise Linux 7RedHatgeocode-glib-0:3.26.0-2.el7*
Red Hat Enterprise Linux 7RedHatgjs-0:1.52.3-1.el7*
Red Hat Enterprise Linux 7RedHatglade-0:3.22.1-1.el7*
Red Hat Enterprise Linux 7RedHatglib2-0:2.56.1-2.el7*
Red Hat Enterprise Linux 7RedHatglibmm24-0:2.56.0-1.el7*
Red Hat Enterprise Linux 7RedHatglib-networking-0:2.56.1-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-backgrounds-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-bluetooth-1:3.28.2-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-boxes-0:3.28.5-2.el7*
Red Hat Enterprise Linux 7RedHatgnome-calculator-0:3.28.2-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-clocks-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-color-manager-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-contacts-0:3.28.2-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-desktop3-0:3.28.2-2.el7*
Red Hat Enterprise Linux 7RedHatgnome-devel-docs-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-dictionary-0:3.26.1-2.el7*
Red Hat Enterprise Linux 7RedHatgnome-disk-utility-0:3.28.3-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-documents-0:3.28.2-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-font-viewer-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-getting-started-docs-0:3.28.2-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-initial-setup-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-keyring-0:3.28.2-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-online-accounts-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-online-miners-0:3.26.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-packagekit-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-screenshot-0:3.26.0-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-session-0:3.28.1-5.el7*
Red Hat Enterprise Linux 7RedHatgnome-settings-daemon-0:3.28.1-2.el7*
Red Hat Enterprise Linux 7RedHatgnome-shell-0:3.28.3-6.el7*
Red Hat Enterprise Linux 7RedHatgnome-shell-extensions-0:3.28.1-5.el7*
Red Hat Enterprise Linux 7RedHatgnome-software-0:3.28.2-3.el7*
Red Hat Enterprise Linux 7RedHatgnome-system-monitor-0:3.28.2-1.el7*
Red Hat Enterprise Linux 7RedHatgnome-terminal-0:3.28.2-2.el7*
Red Hat Enterprise Linux 7RedHatgnome-themes-standard-0:3.28-2.el7*
Red Hat Enterprise Linux 7RedHatgnome-tweak-tool-0:3.28.1-2.el7*
Red Hat Enterprise Linux 7RedHatgnome-user-docs-0:3.28.2-1.el7*
Red Hat Enterprise Linux 7RedHatgnote-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatgobject-introspection-0:1.56.1-1.el7*
Red Hat Enterprise Linux 7RedHatgom-0:0.3.3-1.el7*
Red Hat Enterprise Linux 7RedHatgoogle-noto-emoji-fonts-0:20180508-4.el7*
Red Hat Enterprise Linux 7RedHatgrilo-0:0.3.6-1.el7*
Red Hat Enterprise Linux 7RedHatgrilo-plugins-0:0.3.7-1.el7*
Red Hat Enterprise Linux 7RedHatgsettings-desktop-schemas-0:3.28.0-2.el7*
Red Hat Enterprise Linux 7RedHatgspell-0:1.6.1-1.el7*
Red Hat Enterprise Linux 7RedHatgssdp-0:1.0.2-1.el7*
Red Hat Enterprise Linux 7RedHatgstreamer1-plugins-base-0:1.10.4-2.el7*
Red Hat Enterprise Linux 7RedHatgtk3-0:3.22.30-3.el7*
Red Hat Enterprise Linux 7RedHatgtk-doc-0:1.28-2.el7*
Red Hat Enterprise Linux 7RedHatgtksourceview3-0:3.24.8-1.el7*
Red Hat Enterprise Linux 7RedHatgucharmap-0:10.0.4-1.el7*
Red Hat Enterprise Linux 7RedHatgupnp-0:1.0.2-5.el7*
Red Hat Enterprise Linux 7RedHatgupnp-igd-0:0.2.5-2.el7*
Red Hat Enterprise Linux 7RedHatgvfs-0:1.36.2-1.el7*
Red Hat Enterprise Linux 7RedHatharfbuzz-0:1.7.5-2.el7*
Red Hat Enterprise Linux 7RedHatjson-glib-0:1.4.2-2.el7*
Red Hat Enterprise Linux 7RedHatlibappstream-glib-0:0.7.8-2.el7*
Red Hat Enterprise Linux 7RedHatlibchamplain-0:0.12.16-2.el7*
Red Hat Enterprise Linux 7RedHatlibcroco-0:0.6.12-4.el7*
Red Hat Enterprise Linux 7RedHatlibgdata-0:0.17.9-1.el7*
Red Hat Enterprise Linux 7RedHatlibgee-0:0.20.1-1.el7*
Red Hat Enterprise Linux 7RedHatlibgepub-0:0.6.0-1.el7*
Red Hat Enterprise Linux 7RedHatlibgexiv2-0:0.10.8-1.el7*
Red Hat Enterprise Linux 7RedHatlibgnomekbd-0:3.26.0-1.el7*
Red Hat Enterprise Linux 7RedHatlibgovirt-0:0.3.4-1.el7*
Red Hat Enterprise Linux 7RedHatlibgtop2-0:2.38.0-3.el7*
Red Hat Enterprise Linux 7RedHatlibgweather-0:3.28.2-2.el7*
Red Hat Enterprise Linux 7RedHatlibgxps-0:0.3.0-4.el7*
Red Hat Enterprise Linux 7RedHatlibical-0:3.0.3-2.el7*
Red Hat Enterprise Linux 7RedHatlibjpeg-turbo-0:1.2.90-6.el7*
Red Hat Enterprise Linux 7RedHatlibmediaart-0:1.9.4-1.el7*
Red Hat Enterprise Linux 7RedHatlibosinfo-0:1.1.0-2.el7*
Red Hat Enterprise Linux 7RedHatlibpeas-0:1.22.0-1.el7*
Red Hat Enterprise Linux 7RedHatlibrsvg2-0:2.40.20-1.el7*
Red Hat Enterprise Linux 7RedHatlibsecret-0:0.18.6-1.el7*
Red Hat Enterprise Linux 7RedHatlibsoup-0:2.62.2-2.el7*
Red Hat Enterprise Linux 7RedHatlibwnck3-0:3.24.1-2.el7*
Red Hat Enterprise Linux 7RedHatmozjs52-0:52.9.0-1.el7*
Red Hat Enterprise Linux 7RedHatmutter-0:3.28.3-4.el7*
Red Hat Enterprise Linux 7RedHatnautilus-0:3.26.3.1-2.el7*
Red Hat Enterprise Linux 7RedHatnautilus-sendto-1:3.8.6-1.el7*
Red Hat Enterprise Linux 7RedHatopenchange-0:2.3-3.el7*
Red Hat Enterprise Linux 7RedHatosinfo-db-0:20180531-1.el7*
Red Hat Enterprise Linux 7RedHatPackageKit-0:1.1.10-1.el7*
Red Hat Enterprise Linux 7RedHatpango-0:1.42.4-1.el7*
Red Hat Enterprise Linux 7RedHatpoppler-0:0.26.5-20.el7*
Red Hat Enterprise Linux 7RedHatpyatspi-0:2.26.0-3.el7*
Red Hat Enterprise Linux 7RedHatredhat-logos-0:70.0.3-7.el7*
Red Hat Enterprise Linux 7RedHatrest-0:0.8.1-2.el7*
Red Hat Enterprise Linux 7RedHatrhythmbox-0:3.4.2-2.el7*
Red Hat Enterprise Linux 7RedHatseahorse-nautilus-0:3.11.92-11.el7*
Red Hat Enterprise Linux 7RedHatshotwell-0:0.28.4-1.el7*
Red Hat Enterprise Linux 7RedHatsushi-0:3.28.3-1.el7*
Red Hat Enterprise Linux 7RedHattotem-1:3.26.2-1.el7*
Red Hat Enterprise Linux 7RedHattotem-pl-parser-0:3.26.1-1.el7*
Red Hat Enterprise Linux 7RedHatupower-0:0.99.7-1.el7*
Red Hat Enterprise Linux 7RedHatvala-0:0.40.8-1.el7*
Red Hat Enterprise Linux 7RedHatvino-0:3.22.0-7.el7*
Red Hat Enterprise Linux 7RedHatvte291-0:0.52.2-2.el7*
Red Hat Enterprise Linux 7RedHatwayland-0:1.15.0-1.el7*
Red Hat Enterprise Linux 7RedHatwayland-protocols-0:1.14-1.el7*
Red Hat Enterprise Linux 7RedHatwebkitgtk4-0:2.20.5-1.el7*
Red Hat Enterprise Linux 7RedHatxdg-desktop-portal-0:1.0.2-1.el7*
Red Hat Enterprise Linux 7RedHatxdg-desktop-portal-gtk-0:1.0.2-1.el7*
Red Hat Enterprise Linux 7RedHatyelp-2:3.28.1-1.el7*
Red Hat Enterprise Linux 7RedHatyelp-tools-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatyelp-xsl-0:3.28.0-1.el7*
Red Hat Enterprise Linux 7RedHatzenity-0:3.28.1-1.el7*
QtwebkitUbuntueoan*
Qtwebkit-opensource-srcUbuntuartful*
Qtwebkit-opensource-srcUbuntubionic*
Qtwebkit-opensource-srcUbuntucosmic*
Qtwebkit-opensource-srcUbuntudevel*
Qtwebkit-opensource-srcUbuntudisco*
Qtwebkit-opensource-srcUbuntueoan*
Qtwebkit-opensource-srcUbuntuesm-apps/bionic*
Qtwebkit-opensource-srcUbuntuesm-apps/focal*
Qtwebkit-opensource-srcUbuntuesm-apps/jammy*
Qtwebkit-opensource-srcUbuntuesm-apps/noble*
Qtwebkit-opensource-srcUbuntuesm-infra/xenial*
Qtwebkit-opensource-srcUbuntufocal*
Qtwebkit-opensource-srcUbuntugroovy*
Qtwebkit-opensource-srcUbuntuhirsute*
Qtwebkit-opensource-srcUbuntuimpish*
Qtwebkit-opensource-srcUbuntujammy*
Qtwebkit-opensource-srcUbuntukinetic*
Qtwebkit-opensource-srcUbuntulunar*
Qtwebkit-opensource-srcUbuntumantic*
Qtwebkit-opensource-srcUbuntunoble*
Qtwebkit-opensource-srcUbuntutrusty*
Qtwebkit-opensource-srcUbuntuupstream*
Qtwebkit-opensource-srcUbuntuxenial*
Qtwebkit-sourceUbuntuartful*
Qtwebkit-sourceUbuntubionic*
Qtwebkit-sourceUbuntucosmic*
Qtwebkit-sourceUbuntudisco*
Qtwebkit-sourceUbuntuesm-apps/bionic*
Qtwebkit-sourceUbuntuesm-apps/xenial*
Qtwebkit-sourceUbuntutrusty*
Qtwebkit-sourceUbuntuxenial*
Webkit2gtkUbuntuartful*
Webkit2gtkUbuntuesm-infra/xenial*
Webkit2gtkUbuntuupstream*
Webkit2gtkUbuntuxenial*
WebkitgtkUbuntuartful*
WebkitgtkUbuntubionic*
WebkitgtkUbuntucosmic*
WebkitgtkUbuntuesm-apps/bionic*
WebkitgtkUbuntuesm-apps/xenial*
WebkitgtkUbuntutrusty*
WebkitgtkUbuntuxenial*

Potential Mitigations

  • Use a language that does not allow this weakness to occur or provides constructs that make this weakness easier to avoid.

  • For example, many languages that perform their own memory management, such as Java and Perl, are not subject to buffer overflows. Other languages, such as Ada and C#, typically provide overflow protection, but the protection can be disabled by the programmer.

  • Be wary that a language’s interface to native code may still be subject to overflows, even if the language itself is theoretically safe.

  • Use a vetted library or framework that does not allow this weakness to occur or provides constructs that make this weakness easier to avoid.

  • Examples include the Safe C String Library (SafeStr) by Messier and Viega [REF-57], and the Strsafe.h library from Microsoft [REF-56]. These libraries provide safer versions of overflow-prone string-handling functions.

  • Use automatic buffer overflow detection mechanisms that are offered by certain compilers or compiler extensions. Examples include: the Microsoft Visual Studio /GS flag, Fedora/Red Hat FORTIFY_SOURCE GCC flag, StackGuard, and ProPolice, which provide various mechanisms including canary-based detection and range/index checking.

  • D3-SFCV (Stack Frame Canary Validation) from D3FEND [REF-1334] discusses canary-based detection in detail.

  • Consider adhering to the following rules when allocating and managing an application’s memory:

  • Run or compile the software using features or extensions that randomly arrange the positions of a program’s executable and libraries in memory. Because this makes the addresses unpredictable, it can prevent an attacker from reliably jumping to exploitable code.

  • Examples include Address Space Layout Randomization (ASLR) [REF-58] [REF-60] and Position-Independent Executables (PIE) [REF-64]. Imported modules may be similarly realigned if their default memory addresses conflict with other modules, in a process known as “rebasing” (for Windows) and “prelinking” (for Linux) [REF-1332] using randomly generated addresses. ASLR for libraries cannot be used in conjunction with prelink since it would require relocating the libraries at run-time, defeating the whole purpose of prelinking.

  • For more information on these techniques see D3-SAOR (Segment Address Offset Randomization) from D3FEND [REF-1335].

  • Use a CPU and operating system that offers Data Execution Protection (using hardware NX or XD bits) or the equivalent techniques that simulate this feature in software, such as PaX [REF-60] [REF-61]. These techniques ensure that any instruction executed is exclusively at a memory address that is part of the code segment.

  • For more information on these techniques see D3-PSEP (Process Segment Execution Prevention) from D3FEND [REF-1336].

References