The current setup of the quarantine page tables assumes that the quarantine domain (domio) has been initialized with an address width of DEFAULTDOMAINADDRESSWIDTH (48) and hence 4 page table levels. However domio being a PV domain gets the AMD-Vi IOMMU page tables levels based on the maximum (hot pluggable) RAM address, and hence on systems with no RAM above the 512GB mark only 3 page-table levels are configured in the IOMMU. On systems without RAM above the 512GB boundary amdiommuquarantineinit() will setup page tables for the scratch page with 4 levels, while the IOMMU will be configured to use 3 levels only, resulting in the last page table directory (PDE) effectively becoming a page table entry (PTE), and hence a device in quarantine mode gaining write access to the page destined to be a PDE. Due to this page table level mismatch, the sink page the device gets read/write access to is no longer cleared between device assignment, possibly leading to data leaks.
{
"binaries": [
{
"binary_name": "libxen-4.6",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "libxen-dev",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "libxenstore3.0",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.4-amd64",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.4-arm64",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.4-armhf",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.5-amd64",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.5-arm64",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.5-armhf",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.6-amd64",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.6-arm64",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-hypervisor-4.6-armhf",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-system-amd64",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-system-arm64",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-system-armhf",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-utils-4.6",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xen-utils-common",
"binary_version": "4.6.5-0ubuntu1.4"
},
{
"binary_name": "xenstore-utils",
"binary_version": "4.6.5-0ubuntu1.4"
}
]
}{
"binaries": [
{
"binary_name": "libxen-4.9",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "libxen-dev",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "libxenstore3.0",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.6-amd64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.6-arm64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.6-armhf",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.7-amd64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.7-arm64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.7-armhf",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.8-amd64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.8-arm64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.8-armhf",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.9-amd64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.9-arm64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.9-armhf",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-system-amd64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-system-arm64",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-system-armhf",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-utils-4.9",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xen-utils-common",
"binary_version": "4.9.2-0ubuntu1"
},
{
"binary_name": "xenstore-utils",
"binary_version": "4.9.2-0ubuntu1"
}
]
}{
"binaries": [
{
"binary_name": "libxen-dev",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxencall1",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxendevicemodel1",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxenevtchn1",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxenforeignmemory1",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxengnttab1",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxenmisc4.11",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxenstore3.0",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxentoolcore1",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "libxentoollog1",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-hypervisor-4.11-amd64",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-hypervisor-4.11-arm64",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-hypervisor-4.11-armhf",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-hypervisor-4.9-amd64",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-hypervisor-4.9-arm64",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-hypervisor-4.9-armhf",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-hypervisor-common",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-system-amd64",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-system-arm64",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-system-armhf",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-utils-4.11",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xen-utils-common",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
},
{
"binary_name": "xenstore-utils",
"binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3"
}
]
}{
"binaries": [
{
"binary_name": "libxen-dev",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxencall1",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxendevicemodel1",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxenevtchn1",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxenforeignmemory1",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxengnttab1",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxenhypfs1",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxenmisc4.16",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxenstore4",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxentoolcore1",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "libxentoollog1",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-hypervisor-4.16-amd64",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-hypervisor-4.16-arm64",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-hypervisor-4.16-armhf",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-hypervisor-common",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-system-amd64",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-system-arm64",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-system-armhf",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-utils-4.16",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xen-utils-common",
"binary_version": "4.16.0-1~ubuntu2.1"
},
{
"binary_name": "xenstore-utils",
"binary_version": "4.16.0-1~ubuntu2.1"
}
]
}{
"binaries": [
{
"binary_name": "libxen-dev",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxencall1t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxendevicemodel1t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxenevtchn1t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxenforeignmemory1t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxengnttab1t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxenhypfs1t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxenmisc4.17t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxenstore4t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxentoolcore1t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "libxentoollog1t64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-hypervisor-4.17-amd64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-hypervisor-4.17-arm64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-hypervisor-4.17-armhf",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-hypervisor-common",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-system-amd64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-system-arm64",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-system-armhf",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-utils-4.17",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xen-utils-common",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
},
{
"binary_name": "xenstore-utils",
"binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3"
}
]
}{
"binaries": [
{
"binary_name": "libxen-dev",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxencall1",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxendevicemodel1",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxenevtchn1",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxenforeignmemory1",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxengnttab1",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxenhypfs1",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxenmisc4.20",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxenstore4",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxentoolcore1",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "libxentoollog1",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.20-amd64",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "xen-hypervisor-4.20-arm64",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "xen-hypervisor-common",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "xen-system-amd64",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "xen-system-arm64",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "xen-utils-4.20",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "xen-utils-common",
"binary_version": "4.20.0-1ubuntu1"
},
{
"binary_name": "xenstore-utils",
"binary_version": "4.20.0-1ubuntu1"
}
]
}{
"binaries": [
{
"binary_name": "libxen-dev",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxencall1",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxendevicemodel1",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxenevtchn1",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxenforeignmemory1",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxengnttab1",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxenhypfs1",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxenmisc4.20",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxenstore4",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxentoolcore1",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "libxentoollog1",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "xen-hypervisor-4.20-amd64",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "xen-hypervisor-4.20-arm64",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "xen-hypervisor-common",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "xen-system-amd64",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "xen-system-arm64",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "xen-utils-4.20",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "xen-utils-common",
"binary_version": "4.20.0+68-g35cb38b222-1"
},
{
"binary_name": "xenstore-utils",
"binary_version": "4.20.0+68-g35cb38b222-1"
}
]
}