Commit a7389272 authored by Andrew Honig's avatar Andrew Honig Committed by Kleber Sacilotto de Souza

KVM: x86: Add memory barrier on vmcs field lookup

BugLink: http://bugs.launchpad.net/bugs/1745266

commit 75f139aa upstream.

This adds a memory barrier when performing a lookup into
the vmcs_field_to_offset_table.  This is related to
CVE-2017-5753.
Signed-off-by: default avatarAndrew Honig <ahonig@google.com>
Reviewed-by: default avatarJim Mattson <jmattson@google.com>
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
parent e9c0d5f4
...@@ -831,8 +831,16 @@ static inline short vmcs_field_to_offset(unsigned long field) ...@@ -831,8 +831,16 @@ static inline short vmcs_field_to_offset(unsigned long field)
{ {
BUILD_BUG_ON(ARRAY_SIZE(vmcs_field_to_offset_table) > SHRT_MAX); BUILD_BUG_ON(ARRAY_SIZE(vmcs_field_to_offset_table) > SHRT_MAX);
if (field >= ARRAY_SIZE(vmcs_field_to_offset_table) || if (field >= ARRAY_SIZE(vmcs_field_to_offset_table))
vmcs_field_to_offset_table[field] == 0) return -ENOENT;
/*
* FIXME: Mitigation for CVE-2017-5753. To be replaced with a
* generic mechanism.
*/
asm("lfence");
if (vmcs_field_to_offset_table[field] == 0)
return -ENOENT; return -ENOENT;
return vmcs_field_to_offset_table[field]; return vmcs_field_to_offset_table[field];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment