Xen.org security team
2013-Sep-10 10:56 UTC
Xen Security Advisory 61 - libxl partially sets up HVM passthrough even with disabled iommu
-----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 Xen Security Advisory XSA-61 libxl partially sets up HVM passthrough even with disabled iommu ISSUE DESCRIPTION ================ With HVM domains, libxl''s setup of PCI passthrough devices does the IOMMU setup after giving (via the device model) the guest access to the hardware and advertising it to the guest. If the IOMMU is disabled the overall setup fails, but after the device has been made available to the guest; subsequent DMA instructions from the guest to the device will cause wild DMA. IMPACT ===== A HVM domain, given access to a device which bus mastering capable in the absence of a functioning IOMMU, can mount a privilege escalation or denial of service attack affecting the whole system. VULNERABLE SYSTEMS ================= 1. Only systems which pass busmastering-capable PCI devices through to untrusted guests are vulnerable. (Most PCI devices are busmastering-capable.) 2. Only systems which use libxl as part of the toolstack are vulnerable. The major consumer of libxl functionality is the xl toolstack which became the default in Xen 4.2. In addition to this libvirt can optionally make use of libxl. This can be queried with # virsh version which will report "xenlight" if libxl is in use. libvirt currently prefers the xend backend if xend is running. The xend and xapi toolstacks do not currently use libxl. 3. Only Xen versions 4.0.x through 4.2.x are vulnerable. 4. Only HVM domains can take advantage of this vulnerability. 5. Systems which have a functioning IOMMU are NOT vulnerable. MITIGATION ========= This issue can be avoided by not assigning PCI devices to HVM guests when there is no functioning IOMMU. NOTE REGARDING LACK OF EMBARGO ============================= This issue was disclosed publicly on xen-devel; the person reporting it did not appreciate that it was a security issue. Additionally the patch to fix the issue was already applied to the respective branches (in particular resulting in Xen 4.3 not being vulnerable). Under the circumstances the Xen.org security team do not consider that this advisory should be embargoed. Also, we apologise for the delay to this advisory message, which was due to an oversight by us. CREDITS ====== George Dunlap found the issue as a bug, which on examination by the Xenproject.org Security Team turned out to be a security problem. RESOLUTION ========= Applying the appropriate attached patch resolves this issue. xsa61-4.1.patch Xen 4.1.x xsa61-4.2-unstable.patch Xen 4.2.x, xen-unstable $ sha256sum xsa61*.patch 19caa5f1ce91ebc908c899b8be216034dc67c3e890f59597f659caed41d468f6 xsa61-4.1.patch 5898926de86dd6a27f8e34a2c103e3d0c6267b1d7d947434f294423ed3b0eefd xsa61-4.2-unstable.patch $ -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.12 (GNU/Linux) iQEcBAEBAgAGBQJSLvrIAAoJEIP+FMlX6CvZDy4H/09N5lJYfQBEjYtFKsYTRRL3 hQC2SyH5oXeRguHpCEYLy5EXJ5k0+lrrQ/Kpgf8yP9xUlfkZ19e+Zm20XpcTzRDL yi0VTLv12lNF02Iraml7OfK15FJbCk5BkwgL9aKdiNJX/42IeC49/LOWgAHpuen1 YUEC7fTtwrbr5AER45jVNCcw94OccBzXOiEPA56nJBYzSFPD/iWjrNWTuto5BTOg nzf9JFtvoX40LyXy/p5qMmgu1veIiwUvVuMl8UUudwH0h03hDm1v2hRGtT1/BbQB bJRzaw1a/x6HmpkbHqWC2jq63S6FIrigpv+f9HmiRGmNxpm8DR6aCFMa4OquXiY=Ag3V -----END PGP SIGNATURE----- _______________________________________________ Xen-devel mailing list Xen-devel@lists.xen.org http://lists.xen.org/xen-devel