UBUNTU-CVE-2019-18421

Source
https://ubuntu.com/security/CVE-2019-18421
Import Source
https://github.com/canonical/ubuntu-security-notices/blob/main/osv/cve/2019/UBUNTU-CVE-2019-18421.json
JSON Data
https://api.osv.dev/v1/vulns/UBUNTU-CVE-2019-18421
Related
Published
2019-10-31T14:15:00Z
Modified
2024-10-15T14:07:03Z
Severity
  • 7.5 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:H/I:H/A:H CVSS Calculator
Summary
[none]
Details

An issue was discovered in Xen through 4.12.x allowing x86 PV guest OS users to gain host OS privileges by leveraging race conditions in pagetable promotion and demotion operations. There are issues with restartable PV type change operations. To avoid using shadow pagetables for PV guests, Xen exposes the actual hardware pagetables to the guest. In order to prevent the guest from modifying these page tables directly, Xen keeps track of how pages are used using a type system; pages must be "promoted" before being used as a pagetable, and "demoted" before being used for any other type. Xen also allows for "recursive" promotions: i.e., an operating system promoting a page to an L4 pagetable may end up causing pages to be promoted to L3s, which may in turn cause pages to be promoted to L2s, and so on. These operations may take an arbitrarily large amount of time, and so must be re-startable. Unfortunately, making recursive pagetable promotion and demotion operations restartable is incredibly complicated, and the code contains several races which, if triggered, can cause Xen to drop or retain extra type counts, potentially allowing guests to get write access to in-use pagetables. A malicious PV guest administrator may be able to escalate their privilege to that of the host. All x86 systems with untrusted PV guests are vulnerable. HVM and PVH guests cannot exercise this vulnerability.

References

Affected packages

Ubuntu:Pro:16.04:LTS / xen

Package

Name
xen
Purl
pkg:deb/ubuntu/xen?arch=src?distro=esm-infra/xenial

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected

Affected versions

4.*

4.5.1-0ubuntu1
4.5.1-0ubuntu2
4.6.0-1ubuntu1
4.6.0-1ubuntu2
4.6.0-1ubuntu4
4.6.0-1ubuntu4.1
4.6.0-1ubuntu4.2
4.6.0-1ubuntu4.3
4.6.5-0ubuntu1
4.6.5-0ubuntu1.1
4.6.5-0ubuntu1.2
4.6.5-0ubuntu1.4

Ecosystem specific

{
    "ubuntu_priority": "medium"
}

Ubuntu:Pro:18.04:LTS / xen

Package

Name
xen
Purl
pkg:deb/ubuntu/xen?arch=src?distro=esm-infra/bionic

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected

Affected versions

4.*

4.9.0-0ubuntu3
4.9.0-0ubuntu4
4.9.2-0ubuntu1

Ecosystem specific

{
    "ubuntu_priority": "medium"
}

Ubuntu:20.04:LTS / xen

Package

Name
xen
Purl
pkg:deb/ubuntu/xen?arch=src?distro=focal

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
4.11.3+24-g14b62ab3e5-1ubuntu1

Affected versions

4.*

4.9.2-0ubuntu2
4.9.2-0ubuntu6
4.9.2-0ubuntu7

Ecosystem specific

{
    "availability": "No subscription required",
    "ubuntu_priority": "medium",
    "binaries": [
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxen-dev"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxencall1"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxencall1-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxendevicemodel1"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxendevicemodel1-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxenevtchn1"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxenevtchn1-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxenforeignmemory1"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxenforeignmemory1-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxengnttab1"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxengnttab1-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxenmisc4.11"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxenmisc4.11-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxenstore3.0"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxenstore3.0-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxentoolcore1"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxentoolcore1-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxentoollog1"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "libxentoollog1-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-doc"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-hypervisor-4.11-amd64"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-hypervisor-4.11-arm64"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-hypervisor-4.11-armhf"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-hypervisor-4.9-amd64"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-hypervisor-4.9-arm64"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-hypervisor-4.9-armhf"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-hypervisor-common"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-system-amd64"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-system-arm64"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-system-armhf"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-utils-4.11"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-utils-4.11-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-utils-common"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xen-utils-common-dbgsym"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xenstore-utils"
        },
        {
            "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu1",
            "binary_name": "xenstore-utils-dbgsym"
        }
    ]
}