CVE Vulnerabilities

CVE-2018-3615

Observable Discrepancy

Published: Aug 14, 2018 | Modified: Aug 24, 2020
CVSS 3.x
6.4
MEDIUM
Source:
NVD
CVSS:3.0/AV:L/AC:H/PR:L/UI:N/S:C/C:H/I:L/A:N
CVSS 2.x
5.4 MEDIUM
AV:L/AC:M/Au:N/C:C/I:P/A:N
RedHat/V2
RedHat/V3
Ubuntu
MEDIUM

Systems with microprocessors utilizing speculative execution and Intel software guard extensions (Intel SGX) may allow unauthorized disclosure of information residing in the L1 data cache from an enclave to an attacker with local user access via a side-channel analysis.

Weakness

The product behaves differently or sends different responses under different circumstances in a way that is observable to an unauthorized actor, which exposes security-relevant information about the state of the product, such as whether a particular operation was successful or not.

Affected Software

Name Vendor Start Version End Version
Core_i3 Intel 6006u (including) 6006u (including)
Core_i3 Intel 6098p (including) 6098p (including)
Core_i3 Intel 6100 (including) 6100 (including)
Core_i3 Intel 6100e (including) 6100e (including)
Core_i3 Intel 6100h (including) 6100h (including)
Core_i3 Intel 6100t (including) 6100t (including)
Core_i3 Intel 6100te (including) 6100te (including)
Core_i3 Intel 6100u (including) 6100u (including)
Core_i3 Intel 6102e (including) 6102e (including)
Core_i3 Intel 6157u (including) 6157u (including)
Core_i3 Intel 6167u (including) 6167u (including)
Core_i3 Intel 6300 (including) 6300 (including)
Core_i3 Intel 6300t (including) 6300t (including)
Core_i3 Intel 6320 (including) 6320 (including)
Core_i5 Intel 650 (including) 650 (including)
Core_i5 Intel 655k (including) 655k (including)
Core_i5 Intel 660 (including) 660 (including)
Core_i5 Intel 661 (including) 661 (including)
Core_i5 Intel 670 (including) 670 (including)
Core_i5 Intel 680 (including) 680 (including)
Core_i5 Intel 6200u (including) 6200u (including)
Core_i5 Intel 6260u (including) 6260u (including)
Core_i5 Intel 6267u (including) 6267u (including)
Core_i5 Intel 6287u (including) 6287u (including)
Core_i5 Intel 6300hq (including) 6300hq (including)
Core_i5 Intel 6300u (including) 6300u (including)
Core_i5 Intel 6350hq (including) 6350hq (including)
Core_i5 Intel 6360u (including) 6360u (including)
Core_i5 Intel 6400 (including) 6400 (including)
Core_i5 Intel 6400t (including) 6400t (including)
Core_i5 Intel 6402p (including) 6402p (including)
Core_i5 Intel 6440eq (including) 6440eq (including)
Core_i5 Intel 6440hq (including) 6440hq (including)
Core_i5 Intel 6442eq (including) 6442eq (including)
Core_i5 Intel 6500 (including) 6500 (including)
Core_i5 Intel 6500t (including) 6500t (including)
Core_i5 Intel 6500te (including) 6500te (including)
Core_i5 Intel 6585r (including) 6585r (including)
Core_i5 Intel 6600 (including) 6600 (including)
Core_i5 Intel 6600k (including) 6600k (including)
Core_i5 Intel 6600t (including) 6600t (including)
Core_i5 Intel 6685r (including) 6685r (including)
Core_i7 Intel 610e (including) 610e (including)
Core_i7 Intel 620le (including) 620le (including)
Core_i7 Intel 620lm (including) 620lm (including)
Core_i7 Intel 620m (including) 620m (including)
Core_i7 Intel 620ue (including) 620ue (including)
Core_i7 Intel 620um (including) 620um (including)
Core_i7 Intel 640lm (including) 640lm (including)
Core_i7 Intel 640m (including) 640m (including)
Core_i7 Intel 640um (including) 640um (including)
Core_i7 Intel 660lm (including) 660lm (including)
Core_i7 Intel 660ue (including) 660ue (including)
Core_i7 Intel 660um (including) 660um (including)
Core_i7 Intel 680um (including) 680um (including)
Linux-flo Ubuntu esm-apps/xenial *
Linux-flo Ubuntu trusty *
Linux-flo Ubuntu xenial *
Linux-gke Ubuntu xenial *
Linux-goldfish Ubuntu trusty *
Linux-grouper Ubuntu trusty *
Linux-lts-utopic Ubuntu trusty *
Linux-lts-vivid Ubuntu trusty *
Linux-lts-wily Ubuntu trusty *
Linux-maguro Ubuntu trusty *
Linux-mako Ubuntu esm-apps/xenial *
Linux-mako Ubuntu trusty *
Linux-mako Ubuntu xenial *
Linux-manta Ubuntu trusty *

Potential Mitigations

  • Compartmentalize the system to have “safe” areas where trust boundaries can be unambiguously drawn. Do not allow sensitive data to go outside of the trust boundary and always be careful when interfacing with a compartment outside of the safe area.
  • Ensure that appropriate compartmentalization is built into the system design, and the compartmentalization allows for and reinforces privilege separation functionality. Architects and designers should rely on the principle of least privilege to decide the appropriate time to use privileges and the time to drop privileges.
  • Ensure that error messages only contain minimal details that are useful to the intended audience and no one else. The messages need to strike the balance between being too cryptic (which can confuse users) or being too detailed (which may reveal more than intended). The messages should not reveal the methods that were used to determine the error. Attackers can use detailed information to refine or optimize their original attack, thereby increasing their chances of success.
  • If errors must be captured in some detail, record them in log messages, but consider what could occur if the log messages can be viewed by attackers. Highly sensitive information such as passwords should never be saved to log files.
  • Avoid inconsistent messaging that might accidentally tip off an attacker about internal state, such as whether a user account exists or not.

References