An issue was discovered in Xen through 4.13.x, allowing guest OS users to cause a denial of service or possibly gain privileges because of missing memory barriers in read-write unlock paths. The read-write unlock paths don't contain a memory barrier. On Arm, this means a processor is allowed to re-order the memory access with the preceding ones. In other words, the unlock may be seen by another processor before all the memory accesses within the "critical" section. As a consequence, it may be possible to have a writer executing a critical section at the same time as readers or another writer. In other words, many of the assumptions (e.g., a variable cannot be modified after a check) in the critical sections are not safe anymore. The read-write locks are used in hypercalls (such as grant-table ones), so a malicious guest could exploit the race. For instance, there is a small window where Xen can leak memory if XENMAPSPACEgranttable is used concurrently. A malicious guest may be able to leak memory, or cause a hypervisor crash resulting in a Denial of Service (DoS). Information leak and privilege escalation cannot be excluded.
{ "availability": "No subscription required", "ubuntu_priority": "medium", "binaries": [ { "xen-doc": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxengnttab1": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxendevicemodel1-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-hypervisor-4.11-armhf": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-hypervisor-4.9-armhf": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxenevtchn1-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxentoolcore1-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxentoollog1-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-hypervisor-common": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-hypervisor-4.9-arm64": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxenforeignmemory1": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxencall1": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-utils-common-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-utils-4.11-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxenmisc4.11-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-system-arm64": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xenstore-utils-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxenstore3.0": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-hypervisor-4.11-arm64": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxengnttab1-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxenstore3.0-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-hypervisor-4.9-amd64": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxenforeignmemory1-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxendevicemodel1": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxen-dev": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-system-amd64": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxentoolcore1": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxencall1-dbgsym": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xenstore-utils": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxenevtchn1": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-utils-common": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-system-armhf": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxentoollog1": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-hypervisor-4.11-amd64": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "xen-utils-4.11": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "libxenmisc4.11": "4.11.3+24-g14b62ab3e5-1ubuntu2.3" } ] }