Xen Project 4.8 Series

Categories

Xen Project 4.8.0

Release Information

The Xen Project 4.8 release incorporates many new features and improvements to existing features.

Documentation

For Xen Project 4.8 documentation see

Contribution Acknowledgements

For a breakdown of contributions to Xen 4.8 check out the Xen Project 4.8 Acknowledgements.

Xen Project 4.8.1

We are pleased to announce the release of Xen 4.8.1. This is available immediately from its git repository 

https://xenbits.xenproject.org/gitweb/?p=xen.git;a=shortlog;h=refs/heads/stable-4.8 (tag RELEASE-4.8.1) or from this download page

This release contains the following bug-fixes and improvements in the Xen Project hypervisor:

  • 5ebb4de: update Xen version to 4.8.1 [Jan Beulich]
  • e1c62cd: oxenstored: trim history in the frequent_ops function [Thomas Sanders]
  • 336afa8: oxenstored transaction conflicts: improve logging [Thomas Sanders]
  • 3ee0d82: oxenstored: don't wake to issue no conflict-credit [Thomas Sanders]
  • 84ee808: oxenstored: do not commit read-only transactions [Thomas Sanders]
  • cb778de: oxenstored: allow self-conflicts [Thomas Sanders]
  • fa0b2b9: oxenstored: blame the connection that caused a transaction conflict [Jonathan Davies]
  • 9ea5032: oxenstored: track commit history [Jonathan Davies]
  • c682760: oxenstored: discard old commit-history on txn end [Thomas Sanders]
  • 9a2c5b4: oxenstored: only record operations with side-effects in history [Jonathan Davies]
  • 567051b: oxenstored: support commit history tracking [Jonathan Davies]
  • 4f4596a: oxenstored: add transaction info relevant to history-tracking [Jonathan Davies]
  • b795db0: oxenstored: ignore domains with no conflict-credit [Thomas Sanders]
  • 6636c70: oxenstored: handling of domain conflict-credit [Thomas Sanders]
  • f2c7ab1: oxenstored: comments explaining some variables [Thomas Sanders]
  • f3b7100: xenstored: Log when the write transaction rate limit bites [Ian Jackson]
  • 4cd02a2: xenstored: apply a write transaction rate limit [Ian Jackson]
  • e0354e6: tools/libxenctrl: fix error check after opening libxenforeignmemory [Paul Durrant]
  • a085f0c: libxl: correct xenstore entry for empty cdrom [Juergen Gross]
  • ec7f9e1: x86: use 64 bit mask when masking away mfn bits [Juergen Gross]
  • 06403aa: memory: properly check guest memory ranges in XENMEM_exchange handling [Jan Beulich]
  • f3623bd: xen: sched: don't call hooks of the wrong scheduler via VCPU2OP [Dario Faggioli]
  • c95bad9: x86/EFI: avoid Xen image when looking for module/kexec position [Jan Beulich]
  • 4ec1cb0: x86/EFI: avoid IOMMU faults on [_end,__2M_rwdata_end) [Jan Beulich]
  • 093a1f1: x86/EFI: avoid overrunning mb_modules[] [Jan Beulich]
  • 47501b6: build/clang: fix XSM dummy policy when using clang 4.0 [Roger Pau Monné]
  • 2859b25: x86: drop unneeded __packed attributes [Roger Pau Monné]
  • ca41491: arm: xen_size should be paddr_t for consistency [Stefano Stabellini]
  • 26dec7a: xen/arm: alternative: Register re-mapped Xen area as a temporary virtual region [Wei Chen]
  • eca97a4: QEMU_TAG update [Ian Jackson]
  • c75fe64: arm: read/write rank->vcpu atomically [Stefano Stabellini]
  • af18ca9: xen/arm: p2m: Perform local TLB invalidation on vCPU migration [Julien Grall]
  • 30c2dd7: xen/arm: Introduce INVALID_VCPU_ID [Julien Grall]
  • 1780ea7: xen/arm: Set nr_cpu_ids to available number of cpus [Vijaya Kumar K]
  • 42290f0: xen/arm: acpi: Relax hw domain mapping attributes to p2m_mmio_direct_c [Edgar E. Iglesias]
  • bd684c2: Revert "xen/arm: Map mmio-sram nodes as un-cached memory" [Edgar E. Iglesias]
  • 783b670: xen/arm: dt: Relax hw domain mapping attributes to p2m_mmio_direct_c [Edgar E. Iglesias]
  • 07f9ddf: xen/arm: flush icache as well when XEN_DOMCTL_cacheflush is issued [Tamas K Lengyel]
  • d31d0cd: xen/arm: fix GIC_INVALID_LR [Stefano Stabellini]
  • b2e678e: fix out of bound access to mode_strings [Stefano Stabellini]
  • 05946b5: missing vgic_unlock_rank in gic_remove_irq_from_guest [Stefano Stabellini]
  • e020ff3: xen/arm: Fix macro for ARM Jazelle CPU feature identification [Artem Mygaiev]
  • 308c646: xen/arm: traps: Emulate ICC_SRE_EL1 as RAZ/WI [Julien Grall]
  • fceae91: xen/arm: Fix misplaced parentheses for PSCI version check [Artem Mygaiev]
  • f667393: arm/irq: Reorder check when the IRQ is already used by someone [Oleksandr Tyshchenko]
  • 768b250: Don't clear HCR_VM bit when updating VTTBR. [Jun Sun]
  • 049b13d: x86/emul: Correct the decoding of mov to/from cr/dr [Andrew Cooper]
  • e26a2a0: x86emul: correct decoding of vzero{all,upper} [Jan Beulich]
  • 866f363: xen: credit2: don't miss accounting while doing a credit reset. [Dario Faggioli]
  • 354c3e4: xen: credit2: always mark a tickled pCPU as... tickled! [Dario Faggioli]
  • 8c2da8f: x86/layout: Correct Xen's idea of its own memory layout [Andrew Cooper]
  • 6289c3b: x86/vmx: Don't leak host syscall MSR state into HVM guests [Andrew Cooper]
  • 2e68fda: xen/arm: fix affected memory range by dcache clean functions [Stefano Stabellini]
  • f85fc97: xen/arm: introduce vwfi parameter [Stefano Stabellini]
  • 9967251: arm/p2m: remove the page from p2m->pages list before freeing it [Julien Grall]
  • 34305da: QEMU_TAG update [Ian Jackson]
  • 437a8e6: VMX: fix VMCS race on context-switch paths [Jan Beulich]
  • 9028ba8: xen/p2m: Fix p2m_flush_table for non-nested cases [George Dunlap]
  • 1c28394: x86/ept: allow write-combining on !mfn_valid() MMIO mappings again [David Woodhouse]
  • c246296: IOMMU: always call teardown callback [Oleksandr Tyshchenko]
  • 10baa19: x86/emulate: don't assume that addr_size == 32 implies protected mode [George Dunlap]
  • 4582c2b: xen: credit2: fix shutdown/suspend when playing with cpupools. [Dario Faggioli]
  • a20300b: xen: credit2: never consider CPUs outside of our cpupool. [Dario Faggioli]
  • 23e3303: xen: credit2: use the correct scratch cpumask. [Dario Faggioli]
  • 95f1f99: x86/hvm: do not set msr_tsc_adjust on hvm_set_guest_tsc_fixed [Joao Martins]
  • 9b0e6d3: x86emul: correct FPU stub asm() constraints [Jan Beulich]
  • b843de7: x86: segment attribute handling adjustments [Jan Beulich]
  • ba7e250: x86emul: LOCK check adjustments [Jan Beulich]
  • 6240d92: x86emul: VEX.B is ignored in compatibility mode [Jan Beulich]
  • b378b1f: x86/xstate: Fix array overrun on hardware with LWP [Andrew Cooper]
  • b29aed8: arm/p2m: Fix regression during domain shutdown with active mem_access [Tamas K Lengyel]
  • e1cefed: libxl: fix libxl_set_memory_target [Wei Liu]
  • 53c3a73: xen/arm: gic-v3: Make sure read from ICC_IAR1_EL1 is visible on the redistributor [Julien Grall]
  • daf491d: x86/cpu: Don't update this_cpu for get_cpu_vendor(, gcv_guest) [Andrew Cooper]
  • a654228: x86/emul: Correct the return value handling of VMFUNC [Andrew Cooper]
  • c581ead: x86/boot: fix build with certain older gcc versions [Jan Beulich]
  • 67e9679: x86emul: CMPXCHG16B requires an aligned operand [Jan Beulich]
  • 080a31b: VT-d: correct dma_msi_set_affinity() [Jan Beulich]
  • 1febe8d: x86emul: ignore most segment bases for 64-bit mode in is_aligned() [Jan Beulich]
  • 7713ee2: x86emul: MOVNTI does not allow REP prefixes [Jan Beulich]
  • b76a796: x86/VPMU: clear the overflow status of which counter happened to overflow [Luwei Kang]
  • e298344: x86/hvm: don't unconditionally create a default ioreq server [Paul Durrant]
  • 6933092: libelf: section index 0 is special [Jan Beulich]
  • af6534e: x86emul: CMPXCHG{8,16}B ignore prefixes [Jan Beulich]
  • 297cf3d: xen: Fix determining when domain creation is complete [Andrew Cooper]
  • 3e902dd: x86emul: correct PUSHF/POPF [Jan Beulich]
  • c5efe95: init/FreeBSD: fix incorrect usage of $rc_pids in xendriverdomain [Roger Pau Monne]
  • 63c68c7: init/FreeBSD: add rc control variables [Roger Pau Monne]
  • 3667bc0: init/FreeBSD: fix xencommons so it can only be launched by Dom0 [Roger Pau Monne]
  • 86e54be: init/FreeBSD: remove xendriverdomain_precmd [Roger Pau Monne]
  • e7ad85e: init/FreeBSD: set correct PATH for xl devd [Roger Pau Monne]
  • bdbfca0: xsm: allow relevant permission during migrate and gpu-passthrough. [Anshul Makkar]
  • 443264e: libxl: init_acpi_config should return rc in exit path, and set to 0 on success [Wei Liu]
  • d575902: x86/emul: add likely()/unlikely() to test harness [Andrew Cooper]
  • 24ccfc3: x86/HVM: add missing NULL check before using VMFUNC hook [Jan Beulich]
  • 7628c7e: x86: force EFLAGS.IF on when exiting to PV guests [Jan Beulich]
  • b996efb: x86/emul: Correct the handling of eflags with SYSCALL [Andrew Cooper]
  • 7967daf: QEMU_TAG update [Ian Jackson]
  • 1f4ea16: update Xen version to 4.8.1-pre [Jan Beulich]

In addition, this release also contains the following fixes to qemu-traditional:

  • 3bed93d: cirrus/vnc: zap drop bitblit support from console code. [Gerd Hoffmann]
  • b77d58b: cirrus: add blit_is_unsafe call to cirrus_bitblt_cputovideo [Gerd Hoffmann]
  • a1d57bb: cirrus: fix oob access issue (CVE-2017-2615) [Li Qiang]
  • 095261a: qemu: ioport_read, ioport_write: be defensive about 32-bit addresses [Ian Jackson]

This release also contains changes to qemu-upstream, whose changelogs we do not list here as it contains many changes that are not directly releated to the Xen Project Hypervisor and thus this release. However, you can check https://xenbits.xenproject.org/gitweb/?p=qemu-xen.git;a=shortlog (between tags qemu-xen-4.8.0 and qemu-xen-4.8.1).

This release, which includes source code for qemu-traditional and qemu-upstream, contains the following security fixes. 

XSA Xen qemu-traditional qemu-upstream 
XSA-199 N/A Applied N/A
XSA-200 N/A (Xen 4.8 not affected) ... ...
XSA-201 N/A (Applied on master before 4.8 branch was created) ... ...
XSA-202 Applied N/A N/A
XSA-203 Applied N/A N/A
XSA-204 Applied N/A N/A
XSA-205 N/A (Unassigned number) ... ...
XSA-206 Applied N/A N/A
XSA-207 Applied N/A N/A
XSA-208 N/A Applied Applied
XSA-209 N/A Applied Applied
XSA-210 Applied N/A N/A
XSA-211 N/A Applied Applied
XSA-212 Applied N/A N/A


See https://xenbits.xenproject.org/xsa/ for details related to Xen Project security advisories.

We recommend all users of the 4.8 stable series to update to this latest point release.

Xen Project 4.8.2

We are pleased to announce the release of Xen 4.8.2. This is available immediately from its git repository 

https://xenbits.xenproject.org/gitweb/?p=xen.git;a=shortlog;h=refs/heads/stable-4.8 (tag RELEASE-4.8.2) or from this download page

This release contains the following bug-fixes and improvements in the Xen Project hypervisor:

  • 5e4598106e: update Xen version to 4.8.2 [Jan Beulich]
  • ffb73c1406: gnttab: avoid spurious maptrack handle allocation failures [Jan Beulich]
  • 300529d6b5: cpufreq: only stop ondemand governor if already started [Christopher Clark]
  • c1751e204a: VT-d PI: disable VT-d PI when CPU-side PI isn't enabled [Chao Gao]
  • f914884320: VT-d: don't panic/warn on iommu=no-igfx [Rusty Bird]
  • ed6e5d5bab: docs: replace xm with xl in xen-tscmode [Olaf Hering]
  • 7818599594: x86/hvm: Fixes to hvmemul_insn_fetch() [Andrew Cooper]
  • ecb701f38c: rombios: prevent building with PIC/PIE [Olaf Hering]
  • 3ef997c8be: xen/livepatch: Don't crash on encountering STN_UNDEF relocations [Andrew Cooper]
  • 68c4ef23e9: xen/livepatch: Use zeroed memory allocations for arrays [Andrew Cooper]
  • df8c4fa0e0: arm/mm: release grant lock on xenmem_add_to_physmap_one() error paths [Jan Beulich]
  • c3c2df8d32: travis: install ghostscript [Wei Liu]
  • 236263f459: gnttab: fix "don't use possibly unbounded tail calls" [Jan Beulich]
  • 5c10e0e4b0: gnttab: fix transitive grant handling [Jan Beulich]
  • 5afb94cac0: gnttab: don't use possibly unbounded tail calls [Jan Beulich]
  • f5211ce758: gnttab: correct pin status fixup for copy [Jan Beulich]
  • 877591cc28: gnttab: split maptrack lock to make it fulfill its purpose again [Jan Beulich]
  • 460cd3b117: x86/grant: disallow misaligned PTEs [Andrew Cooper]
  • 1e6c88fafc: arm: p2m: Prevent redundant icache flushes [Punit Agrawal]
  • 55cf609c40: Allow control of icache invalidations when calling flush_page_to_ram() [Punit Agrawal]
  • 079550e0a0: xen/arm: Properly map the FDT in the boot page table [Julien Grall]
  • f6f543fee9: xen/arm: Check if the FDT passed by the bootloader is valid [Julien Grall]
  • a332ac1f5b: xen/arm: Move the code to map FDT in the boot tables from assembly to C [Julien Grall]
  • 1a147b5359: xen/arm: mm: Move create_mappings function earlier in the file [Julien Grall]
  • 86529087ab: memory: don't suppress P2M update in populate_physmap() [Jan Beulich]
  • 1e40f87dbb: livepatch: Wrong usage of spinlock on debug console. [Konrad Rzeszutek Wilk]
  • 7dd85eb372: Revert "x86/hvm: disable pkeys for guests in non-paging mode" [Andrew Cooper]
  • 24809e04e7: x86/pv: Fix the handling of `int $x` for vectors which alias exceptions [Andrew Cooper]
  • 8d3dafb43f: xen/test/Makefile: Fix clean target, broken by pattern rule [Ian Jackson]
  • aedaa82c2f: x86: avoid leaking PKRU and BND* between vCPU-s [Jan Beulich]
  • a75d7ad053: xen/arm: vgic: Sanitize target mask used to send SGI [Julien Grall]
  • 125a3a9d6a: gnttab: __gnttab_unmap_common_complete() is all-or-nothing [Jan Beulich]
  • b859653b7c: gnttab: correct logic to get page references during map requests [George Dunlap]
  • 429ad0d3f2: gnttab: never create host mapping unless asked to [Jan Beulich]
  • 1959b49f35: gnttab: fix handling of dev_bus_addr during unmap [George Dunlap]
  • 670bb9dd9e: arm: vgic: Don't update the LR when the IRQ is not enabled [Julien Grall]
  • 270b9f8f64: guest_physmap_remove_page() needs its return value checked [Jan Beulich]
  • 50ee10e22c: memory: fix return value handing of guest_remove_page() [Andrew Cooper]
  • e5da3ccafd: evtchn: avoid NULL derefs [Jan Beulich]
  • 982d477b56: x86/shadow: hold references for the duration of emulated writes [Andrew Cooper]
  • ca71eb31d6: gnttab: correct maptrack table accesses [Jan Beulich]
  • c7dab25933: gnttab: Avoid potential double-put of maptrack entry [George Dunlap]
  • ca974091c8: gnttab: fix unmap pin accounting race [Jan Beulich]
  • a4bca7c309: x86/mm: disallow page stealing from HVM domains [Jan Beulich]
  • fe5bbfda64: Makefile: Provide way to ship livepatch test files [Ian Jackson]
  • cb99078ef9: xen/test/livepatch: Add xen_nop.livepatch to .gitignore [Ian Jackson]
  • e1bcfb12d7: xen/test/livepatch: Regularise Makefiles [Ian Jackson]
  • 2d37e90cc7: xen/test/livepatch/Makefile: Install in DESTDIR/usr/lib/debug/xen-livepatch [Ian Jackson]
  • c427a81dee: xen/arm: p2m: Fix incorrect mapping of superpages [Julien Grall]
  • 125e4d4a8d: vgic: refuse irq migration when one is already in progress [Stefano Stabellini]
  • 9e6b2ddf33: arm: remove irq from inflight, then change physical affinity [Stefano Stabellini]
  • 52d83809fa: xen/arm: Survive unknown traps from guests [Julien Grall]
  • 5026eb5ed0: xen/arm: do_trap_hypervisor: Separate hypervisor and guest traps [Julien Grall]
  • e5ec23efcf: xen/arm: Save ESR_EL2 to avoid using mismatched value in syndrome check [Wei Chen]
  • 79d2d5c343: stop_machine: fill fn_result only in case of error [Gregory Herrero]
  • b7d2c0f2f5: hvmloader: avoid tests when they would clobber used memory [Jan Beulich]
  • d5841446b9: arm: fix build with gcc 7 [Jan Beulich]
  • d721af1f6e: x86: fix build with gcc 7 [Jan Beulich]
  • 72808a8717: x86/mm: fix incorrect unmapping of 2MB and 1GB pages [Igor Druzhinin]
  • 173eb93195: x86/pv: Align %rsp before pushing the failsafe stack frame [Andrew Cooper]
  • d29cb493e0: x86/pv: Fix bugs with the handling of int80_bounce [Andrew Cooper]
  • 98cefccaee: x86/vpmu_intel: fix hypervisor crash by masking PC bit in MSR_P6_EVNTSEL [Mohit Gambhir]
  • e91a24cf64: hvm: fix hypervisor crash in hvm_save_one() [Jan Beulich]
  • de1318bb00: x86/32on64: properly honor add-to-physmap-batch's size [Jan Beulich]
  • 4057c6ea80: tools: ocaml: In configure, check for ocamlopt [Ian Jackson]
  • 834ea870c5: tools/libxc: Tolerate specific zero-content records in migration v2 streams [Andrew Cooper]
  • efd2ff999d: libxc: fix segfault on uninitialized xch->fmem [Seraphime Kirkovski]
  • 19ad7c08a8: x86/mce: always re-initialize 'severity_cpu' in mcheck_cmn_handler() [Haozhong Zhang]
  • 1780c265f7: x86/mce: make 'severity_cpu' private to its users [Haozhong Zhang]
  • 8f6d1f9abf: memory: don't hand MFN info to translated guests [Jan Beulich]
  • 957dc0e249: memory: exit early from memory_exchange() upon write-back error [Jan Beulich]
  • 12b1425fdc: kexec: clear kexec_image slot when unloading kexec image [Bhavesh Davda]
  • a782d9d421: update Xen version to 4.8.2-pre [Jan Beulich]
  • 16ed8dd289: x86: discard type information when stealing pages [Jan Beulich]
  • 17051bdb86: multicall: deal with early exit conditions [Jan Beulich]
  • 98e05a3abc: Merge branch 'staging-4.8' of xenbits.xen.org:/home/xen/git/xen into staging-4.8 [Jan Beulich]
  • c2a541500d: setup vwfi correctly on cpu0 [Stefano Stabellini]

This release contains no fixes to qemu-traditional.

This release also contains changes to qemu-upstream, whose changelogs we do not list here as it contains many changes that are not directly releated to the Xen Project Hypervisor and thus this release. However, you can check https://xenbits.xenproject.org/gitweb/?p=qemu-xen.git;a=shortlog (between tags qemu-xen-4.8.1 and qemu-xen-4.8.2).

This release, which includes source code for qemu-traditional and qemu-upstream, contains the following security fixes. 

XSA Xen qemu-traditional qemu-upstream 
XSA-213 Applied N/A N/A
XSA-214 Applied N/A N/A
XSA-215 N/A (Xen 4.8 not affected) ... ...
XSA-216 N/A N/A Applied
XSA-217 Applied N/A N/A
XSA-218 Applied N/A N/A
XSA-219 Applied N/A N/A
XSA-220 Applied N/A N/A
XSA-221 Applied N/A N/A
XSA-222 Applied N/A N/A
XSA-223 Applied N/A N/A
XSA-224 Applied N/A N/A
XSA-225 Applied N/A N/A
XSA-226 Applied (fix, not work-around, via xsa226-4.9/*.patch) N/A N/A
XSA-227 Applied N/A N/A
XSA-228 Applied N/A N/A
XSA-229 N/A (Linux only) ... ...
XSA-230 Applied N/A N/A
XSA-231 N/A (Pre-released, but embargoed, at the time of this release) ... ...
XSA-232 N/A (Pre-released, but embargoed, at the time of this release) ... ...
XSA-233 N/A (Pre-released, but embargoed, at the time of this release) ... ...
XSA-234 N/A (Pre-released, but embargoed, at the time of this release) ... ...
XSA-235 Applied N/A N/A


See https://xenbits.xenproject.org/xsa/ for details related to Xen Project security advisories.

We recommend all users of the 4.8 stable series to update to this latest point release.

Xen Project 4.8.3

We are pleased to announce the release of Xen 4.8.3. This is available immediately from its git repository 

https://xenbits.xenproject.org/gitweb/?p=xen.git;a=shortlog;h=refs/heads/stable-4.8 (tag RELEASE-4.8.3) or from this download page

This release contains the following bug-fixes and improvements in the Xen Project hypervisor:

  • 4507bb6ae2: update Xen version to 4.8.3 [Jan Beulich]
  • 31d38d633a: x86: allow Meltdown band-aid to be disabled [Jan Beulich]
  • 1ba477bde7: x86: Meltdown band-aid against malicious 64-bit PV guests [Jan Beulich]
  • 049e2f45bf: x86/mm: Always set _PAGE_ACCESSED on L4e updates [Andrew Cooper]
  • 49a44f089c: x86: Don't use potentially incorrect CPUID values for topology information [Jan H. Schönherr]
  • a7cf0a3b81: x86/entry: Remove support for partial cpu_user_regs frames [Andrew Cooper]
  • 40c02dd27a: x86/upcall: inject a spurious event after setting upcall vector [Roger Pau Monné]
  • 8631e6af5a: x86/E820: don't overrun array [Jan Beulich]
  • eb77163343: x86/IRQ: conditionally preserve access permission on map error paths [Jan Beulich]
  • 9c6993b7b9: xen/arm: fix smpboot barriers [Stefano Stabellini]
  • ee24b2f7f0: xen/arm: vgic: Check for vgic handler to be initialized before dereferencing it [Oleksandr Tyshchenko]
  • 579c927c2d: xen/arm: p2m: Check for p2m->domain to be initialized before releasing resources [Oleksandr Tyshchenko]
  • f709287d35: arm: configure interrupts to be in non-secure group1 [Stefano Stabellini]
  • 6ee114f034: xen/arm: bootfdt: Use proper default for #address-cells and #size-cells [Julien Grall]
  • 15e40427d0: xen/arm: gic-v3: Bail out if gicv3_cpu_init fail [Julien Grall]
  • 8ab43f785a: xen/efi: Fix build with clang-5.0 [Andrew Cooper]
  • 24e2cfc0a9: x86/microcode: Add support for fam17h microcode loading [Tom Lendacky]
  • ed7765ae03: gnttab: improve GNTTABOP_cache_flush locking [Jan Beulich]
  • ba28eac093: gnttab: correct GNTTABOP_cache_flush empty batch handling [Jan Beulich]
  • 3f94881ceb: x86/vvmx: don't enable vmcs shadowing for nested guests [Sergey Dyasli]
  • adc494bff2: xen/pv: Construct d0v0's GDT properly [Andrew Cooper]
  • 97546b5e5c: x86/hvm: fix interaction between internal and external emulation [Paul Durrant]
  • ae3aac94ff: improve XENMEM_add_to_physmap_batch address checking [Jan Beulich]
  • e9558bee74: x86: check paging mode earlier in xenmem_add_to_physmap_one() [Jan Beulich]
  • 3effd96e4a: x86: replace bad ASSERT() in xenmem_add_to_physmap_one() [Jan Beulich]
  • 472d596042: sync CPU state upon final domain destruction [Jan Beulich]
  • 1eae46441b: x86/hvm: Don't corrupt the HVM context stream when writing the MSR record [Andrew Cooper]
  • 7ae2229e3c: x86/hvm: Fix altp2m_vcpu_enable_notify error handling [Adrian Pop]
  • 6353c349a5: common/gnttab: Correct error handling for gnttab_setup_table() [Andrew Cooper]
  • 6fc1f55e7d: x86/paging: don't unconditionally BUG() on finding SHARED_M2P_ENTRY [Jan Beulich]
  • 68db69443f: x86/shadow: fix ref-counting error handling [Jan Beulich]
  • 5069fdde82: x86/shadow: fix refcount overflow check [Jan Beulich]
  • a66b8147e9: x86/mm: don't wrongly set page ownership [Jan Beulich]
  • d60d469671: x86: don't wrongly trigger linear page table assertion (2) [Jan Beulich]
  • e54bc7e99b: p2m: Check return value of p2m_set_entry() when decreasing reservation [George Dunlap]
  • fcc60bc5ad: p2m: Always check to see if removing a p2m entry actually worked [George Dunlap]
  • 60e86f35f9: x86/pod: prevent infinite loop when shattering large pages [Julien Grall]
  • 9ba6783e47: x86/shadow: correct SH_LINEAR mapping detection in sh_guess_wrmap() [Andrew Cooper]
  • bc244b70fe: x86: don't wrongly trigger linear page table assertion [Jan Beulich]
  • 13eb73f0f0: x86/mm: fix race condition in modify_xen_mappings() [Yu Zhang]
  • 6183d537ce: x86/mm: fix race conditions in map_pages_to_xen() [Min He]
  • 1ac3ab78cf: x86/hvm: do not register hpet mmio during s3 cycle [Eric Chanudet]
  • e1fa1c6ee1: x86/mm: Make PV linear pagetables optional [George Dunlap]
  • 96e76d8b66: x86: fix asm() constraint for GS selector update [Jan Beulich]
  • 651d839afa: x86: don't latch wrong (stale) GS base addresses [Jan Beulich]
  • 14826e327b: x86: also show FS/GS base addresses when dumping registers [Jan Beulich]
  • 814e065d66: x86: fix GS-base-dirty determination [Jan Beulich]
  • 03af24c35e: x86emul: handle address wrapping [Jan Beulich]
  • 4a3c5e119a: VMX: PLATFORM_INFO MSR is r/o [Jan Beulich]
  • 2956a3fdd9: x86: avoid #GP for PV guest MSR accesses [Jan Beulich]
  • 3cd9d8440b: x86/vvmx: Fix WRMSR interception of VMX MSRs [Andrew Cooper]
  • ffb294731d: x86: fix do_update_va_mapping_otherdomain() wrt translated domains [Jan Beulich]
  • f457a229bc: x86: request page table page-in for the correct domain [Jan Beulich]
  • 011a612fa2: xen/domctl: Fix Xen heap leak via XEN_DOMCTL_getvcpucontext [Andrew Cooper]
  • 5b37b5cf0a: x86/PV: fix/generalize guest nul selector handling [Jan Beulich]
  • 379213ca25: x86/msr: Correct the definition of MSR_IA32_APICBASE_BASE [Andrew Cooper]
  • f3b2080a55: x86/svm: Fix a livelock when trying to run shadowed unpaged guests [Andrew Cooper]
  • fcbbd0faee: gnttab: fix pin count / page reference race [Jan Beulich]
  • 0c647de4db: tools/libxc/xc_dom_arm: add missing variable initialization [Bernd Kuhls]
  • bdc2ae68e2: x86/cpu: Fix IST handling during PCPU bringup [Andrew Cooper]
  • 96e6364b5f: x86/shadow: Don't create self-linear shadow mappings for 4-level translated guests [Andrew Cooper]
  • 1a8ad09dd1: x86: don't allow page_unlock() to drop the last type reference [Jan Beulich]
  • df8919786f: x86: don't store possibly stale TLB flush time stamp [Jan Beulich]
  • c4f969d254: x86: limit linear page table use to a single level [Jan Beulich]
  • b1f3f1dde1: x86/HVM: prefill partially used variable on emulation paths [Jan Beulich]
  • 7251c06540: x86/ioreq server: correctly handle bogus XEN_DMOP_{,un}map_io_range_to_ioreq_server arguments [Vitaly Kuznetsov]
  • 1960ca8220: x86/FLASK: fix unmap-domain-IRQ XSM hook [Jan Beulich]
  • 866cfa1575: x86/IRQ: conditionally preserve irq pirq mapping on map error paths [Jan Beulich]
  • ddd6e415b1: x86/MSI: disallow redundant enabling [Jan Beulich]
  • 370cc9aa49: x86: enforce proper privilege when (un)mapping pIRQ-s [Jan Beulich]
  • 39e3024360: x86: don't allow MSI pIRQ mapping on unowned device [Jan Beulich]
  • 9f092f57d2: xen/arm: p2m: Read *_mapped_gfn with the p2m lock taken [Julien Grall]
  • 667f70e658: xen/arm: Fix the issue in cmp_mmio_handler used in find_mmio_handler [Bhupinder Thakur]
  • 2116fec45d: xen/arm: Correctly report the memory region in the dummy NUMA helpers [Julien Grall]
  • 1a535c3614: xen/page_alloc: Cover memory unreserved after boot in first_valid_mfn [Julien Grall]
  • ee3fc24177: x86: introduce and use setup_force_cpu_cap() [Jan Beulich]
  • d623d820c8: x86/emul: Fix the handling of unimplemented Grp7 instructions [Andrew Cooper]
  • dda458cbd4: VT-d: use correct BDF for VF to search VT-d unit [Chao Gao]
  • c642b12321: hvmloader: use base instead of pci_mem_start for find_next_rmrr() [Xiong Zhang]
  • 80d7ef34e9: x86/efi: don't write relocations in efi_arch_relocate_image() first pass [David Woodhouse]
  • ff4f60a5c5: x86: check for allocation errors in modify_xen_mappings() [Jan Beulich]
  • 36898eb125: gnttab: also validate PTE permissions upon destroy/replace [Jan Beulich]
  • 4d7ccae751: tools/xenstore: dont unlink connection object twice [Juergen Gross]
  • e574046987: grant_table: fix GNTTABOP_cache_flush handling [Andrew Cooper]
  • 90dafa46ea: xen/mm: make sure node is less than MAX_NUMNODES [George Dunlap]
  • c020cf2ec0: update Xen version to 4.8.3-pre [Jan Beulich]

This release contains no fixes to qemu-traditional:

This release also contains changes to qemu-upstream, whose changelogs we do not list here as it contains many changes that are not directly releated to the Xen Project Hypervisor and thus this release. However, you can check https://xenbits.xenproject.org/gitweb/?p=qemu-xen.git;a=shortlog (between tags qemu-xen-4.8.2 and qemu-xen-4.8.3).

This release, which includes source code for qemu-traditional and qemu-upstream, contains the following security fixes. 

XSA Xen qemu-traditional qemu-upstream 
XSA-231 Applied N/A N/A
XSA-232 Applied N/A N/A
XSA-233 Applied N/A N/A
XSA-234 Applied N/A N/A
XSA-235 Fixed in 4.8.2 ... ...
XSA-236 Applied N/A N/A
XSA-237 Applied N/A N/A
XSA-238 Applied N/A N/A
XSA-239 Applied N/A N/A
XSA-240 Applied N/A N/A
XSA-241 Applied N/A N/A
XSA-242 Applied N/A N/A
XSA-243 Applied N/A N/A
XSA-244 Applied N/A N/A
XSA-245 Applied N/A N/A
XSA-246 Applied N/A N/A
XSA-247 Applied N/A N/A
XSA-248 Applied N/A N/A
XSA-249 Applied N/A N/A
XSA-250 Applied N/A N/A
XSA-251 Applied N/A N/A
XSA-252 Reserved Number ... ...
XSA-253 Xen 4.8 not affected ... ...
XSA-254 Partly fixed, see [1] N/A N/A


[1] Notes on Meltdown and Spectre:

  • Xen  4.8.3 contains the XPTI "stage 1" substantial mitigation for Meltdown, and is enabled by default on Intel hardware. This does come with performance/scalability differences which are workload dependent. Explicit choice to enable or disable XPTI can be expressed via `xpti=` on the hypervisor command line. Other earlier Meltdown mitigations are available from specific temporary branches. 
  • Note that Xen 4.8.3 does not yet contain migitations for the Spectre CPU bug variant 2. These are still under review and in any case depend on microcode updates which are not presently available.
  • For more detailed information see XSA-254 or our Spectre/Meltdown FAQ.

See https://xenbits.xenproject.org/xsa/ for details related to Xen Project security advisories.

We recommend all users of the 4.8 stable series to update to this latest point release. Users who need Spectre Variant 2 mitigation and prefer to reduce update frequency should consider deferring the deployment of 4.8.3 until a Spectre Variant 2 mitigation is available.

Xen Project 4.8.4

We are pleased to announce the release of Xen 4.8.4. This is available immediately from its git repository 

https://xenbits.xenproject.org/gitweb/?p=xen.git;a=shortlog;h=refs/heads/stable-4.8 (tag RELEASE-4.8.4) or from this download page

This release contains the following bug-fixes and improvements in the Xen Project hypervisor:

  • 4801bf528c: update Xen version to 4.8.4 [Jan Beulich]
  • e39ff386f6: x86/HVM: don't cause #NM to be raised in Xen [Jan Beulich]
  • 321254a107: libxl: restore passing "readonly=" to qemu for SCSI disks [Ian Jackson]
  • 500d567b08: libxl: qemu_disk_scsi_drive_string: Break out common parts of disk config [Ian Jackson]
  • 5fd28d27d3: x86: Refine checks in #DB handler for faulting conditions [Andrew Cooper]
  • d6154125d7: x86/mm: don't bypass preemption checks [Jan Beulich]
  • 9a7fa685f9: x86/EFI: further correct FPU state handling around runtime calls [Jan Beulich]
  • b736afdea4: x86/EFI: fix FPU state handling around runtime calls [Jan Beulich]
  • b9b9d9ed1d: x86: correct default_xen_spec_ctrl calculation [Jan Beulich]
  • 028656f042: libxc/x86/PV: don't hand through CPUID leaf 0x80000008 as is [Jan Beulich]
  • c1aaad5627: x86/spec-ctrl: Mitigations for LazyFPU [Andrew Cooper]
  • c5a56920e8: x86: Support fully eager FPU context switching [Andrew Cooper]
  • 1522a81ace: x86: don't enable XPTI on idle domain [Jan Beulich]
  • 37b3dfdeef: x86: re-enable XPTI/PCID as needed in switch_native() [Jan Beulich]
  • f8a489fca1: xen/x86: use PCID feature [Juergen Gross]
  • 0954b1107d: xen/x86: add some cr3 helpers [Juergen Gross]
  • 266d5118ae: xen/x86: convert pv_guest_cr4_to_real_cr4() to a function [Juergen Gross]
  • 2d97baac10: xen/x86: use flag byte for decision whether xen_cr3 is valid [Juergen Gross]
  • 61fc6a4ec4: xen/x86: disable global pages for domains with XPTI active [Juergen Gross]
  • 73b68d2f50: xen/x86: use invpcid for flushing the TLB [Juergen Gross]
  • 811c1686b4: xen/x86: support per-domain flag for xpti [Juergen Gross]
  • eef72b8c50: xen/x86: add a function for modifying cr3 [Juergen Gross]
  • ae0a87e113: x86/xpti: avoid copying L4 page table contents when possible [Juergen Gross]
  • b494c139a2: x86: invpcid support [Wei Liu]
  • c36aaca821: x86: move invocations of hvm_flush_guest_tlbs() [Jan Beulich]
  • 1afb8947fe: x86/XPTI: fix S3 resume (and CPU offlining in general) [Jan Beulich]
  • 845d2b63e6: x86/msr: Virtualise MSR_SPEC_CTRL.SSBD for guests to use [Andrew Cooper]
  • 9d7358638d: x86/Intel: Mitigations for GPZ SP4 - Speculative Store Bypass [Andrew Cooper]
  • 7f4ae1612a: x86/AMD: Mitigations for GPZ SP4 - Speculative Store Bypass [Andrew Cooper]
  • 05b41f25d0: x86/spec_ctrl: Introduce a new `spec-ctrl=` command line argument to replace `bti=` [Andrew Cooper]
  • 618a96ea32: x86/cpuid: Improvements to guest policies for speculative sidechannel features [Andrew Cooper]
  • 455a429dd4: x86/spec_ctrl: Explicitly set Xen's default MSR_SPEC_CTRL value [Andrew Cooper]
  • 1fd1973f94: x86/spec_ctrl: Split X86_FEATURE_SC_MSR into PV and HVM variants [Andrew Cooper]
  • ef14d39d4f: x86/spec_ctrl: Elide MSR_SPEC_CTRL handling in idle context when possible [Andrew Cooper]
  • c696ef0f39: x86/spec_ctrl: Rename bits of infrastructure to avoid NATIVE and VMEXIT [Andrew Cooper]
  • 68d02a7628: x86/spec_ctrl: Fold the XEN_IBRS_{SET,CLEAR} ALTERNATIVES together [Andrew Cooper]
  • b0ea18ed5b: x86/spec_ctrl: Merge bti_ist_info and use_shadow_spec_ctrl into spec_ctrl_flags [Andrew Cooper]
  • e60a287bf8: x86/spec_ctrl: Express Xen's choice of MSR_SPEC_CTRL value as a variable [Andrew Cooper]
  • 9419337e44: x86/spec_ctrl: Read MSR_ARCH_CAPABILITIES only once [Andrew Cooper]
  • cc0bb3b484: x86: Fix "x86: further CPUID handling adjustments" [Andrew Cooper]
  • 197e605e03: libacpi: fixes for iasl >= 20180427 [Roger Pau Monné]
  • eaa9d0a9ae: xen/schedule: Fix races in vcpu migration [George Dunlap]
  • d66898a15d: xen: Introduce vcpu_sleep_nosync_locked() [George Dunlap]
  • f2837b5f11: x86/cpuidle: don't init stats lock more than once [Jan Beulich]
  • 0f475fedfc: x86/SVM: Fix intercepted {RD,WR}MSR for the SYS{CALL,ENTER} MSRs [Andrew Cooper]
  • 210bd51a2e: xpti: fix bug in double fault handling [Juergen Gross]
  • b4ad8a6f15: x86/HVM: never retain emulated insn cache when exiting back to guest [Jan Beulich]
  • 4cdd4cc106: x86/HPET: fix race triggering ASSERT(cpu < nr_cpu_ids) [David Wang]
  • 193130f53f: x86/spec_ctrl: Updates to retpoline-safety decision making [Andrew Cooper]
  • 7f2959f8f6: x86: suppress BTI mitigations around S3 suspend/resume [Jan Beulich]
  • 9cba9aeb4d: x86: correct ordering of operations during S3 resume [Jan Beulich]
  • f99bc153d2: x86/cpuid: fix raw FEATURESET_7d0 reporting [Sergey Dyasli]
  • 44c709e630: x86/emul: Fix emulator test harness build following a backport of 7c508612 [Andrew Cooper]
  • c10ddc1ff9: x86/emul: Fix emulator test harness build following a91b2ec337a [Andrew Cooper]
  • 2bef7bf7f3: x86/HVM: guard against emulator driving ioreq state in weird ways [Jan Beulich]
  • 326d25fcc7: x86/vpt: add support for IO-APIC routed interrupts [Xen Project Security Team]
  • 3f59d0b8bc: x86/traps: Fix handling of #DB exceptions in hypervisor context [Andrew Cooper]
  • a89390bd6a: x86/traps: Use an Interrupt Stack Table for #DB [Andrew Cooper]
  • 40c4ab8a20: x86/pv: Move exception injection into {,compat_}test_all_events() [Andrew Cooper]
  • 90676b7df3: x86/traps: Fix %dr6 handing in #DB handler [Andrew Cooper]
  • 1052a2168e: x86: fix slow int80 path after XPTI additions [Jan Beulich]
  • a2f02dfdcb: libxl: Specify format of inserted cdrom [Anthony PERARD]
  • 501718a68c: x86/msr: Correct the emulation behaviour of MSR_PRED_CMD [Andrew Cooper]
  • 957ff3006e: x86/VT-x: Fix determination of EFER.LMA in vmcs_dump_vcpu() [Andrew Cooper]
  • 1e9ac23c93: x86/HVM: suppress I/O completion for port output [Jan Beulich]
  • 95befc64f1: x86/pv: Fix up erroneous segments for 32bit syscall entry [Andrew Cooper]
  • 372583c2dd: x86/XPTI: reduce .text.entry [Jan Beulich]
  • 202aaf8a58: x86: log XPTI enabled status [Jan Beulich]
  • e4e96320fc: x86: disable XPTI when RDCL_NO [Jan Beulich]
  • a753be1b4c: x86/pv: Fix the handing of writes to %dr7 [Andrew Cooper]
  • 8f9846f791: x86: further CPUID handling adjustments [Jan Beulich]
  • 0864795226: x86/emul: Fix backport of "x86/emul: Fix the decoding of segment overrides in 64bit mode" [Andrew Cooper]
  • 866dedabb3: x86/PV: also cover Dom0 in SPEC_CTRL / PRED_CMD emulation [Jan Beulich]
  • c67e19f030: x86: Move microcode loading earlier [Ross Lagerwall]
  • bc6414f735: x86/vlapic: clear TMR bit upon acceptance of edge-triggered interrupt to IRR [Liran Alon]
  • 883c8db61c: cpufreq/ondemand: fix race while offlining CPU [Jan Beulich]
  • 7db1c43a36: x86: remove CR reads from exit-to-guest path [Jan Beulich]
  • 813fe211f2: x86: slightly reduce Meltdown band-aid overhead [Jan Beulich]
  • 3cadc8bb84: x86/xpti: don't map stack guard pages [Jan Beulich]
  • f7bf4d230a: x86/xpti: Hide almost all of .text and all .data/.rodata/.bss mappings [Andrew Cooper]
  • 14217cba9d: x86/apicv: fix wrong IPI suppression during posted interrupt delivery [Quan Xu]
  • ce185fbce2: x86: ignore guest microcode loading attempts [Jan Beulich]
  • a2700ca14e: libxl/arm: Fix build on arm64 + acpi [Daniel Sabogal]
  • b19b20690d: x86/HVM: don't give the wrong impression of WRMSR succeeding [Jan Beulich]
  • a442d40e9b: x86/PV: fix off-by-one in I/O bitmap limit check [Jan Beulich]
  • 1901f62539: grant: Release domain lock on 'map' path in cache_flush [George Dunlap]
  • 1581910431: x86/pv: Avoid leaking other guests' MSR_TSC_AUX values into PV context [Andrew Cooper]
  • 15f57b8612: x86/nmi: start NMI watchdog on CPU0 after SMP bootstrap [Igor Druzhinin]
  • 7ef31c0955: x86/srat: fix end calculation in nodes_cover_memory() [Jan Beulich]
  • bc8aa42842: x86/entry: Use 32bit xors rater than 64bit xors for clearing GPRs [Andrew Cooper]
  • 30a153d6db: x86/emul: Fix the decoding of segment overrides in 64bit mode [Andrew Cooper]
  • da9266448c: x86/spec_ctrl: Fix several bugs in SPEC_CTRL_ENTRY_FROM_INTR_IST [Andrew Cooper]
  • 6b08396e0b: x86/srat: fix the end pfn check in valid_numa_range() [Haozhong Zhang]
  • f6ae9c0398: x86: reduce Meltdown band-aid IPI overhead [Jan Beulich]
  • ad9ddc3ad1: x86/NMI: invert condition in nmi_show_execution_state() [Jan Beulich]
  • 22d2146e9b: x86/emul: Fix the emulation of invlpga [Andrew Cooper]
  • f9adc122b6: xen/arm: Flush TLBs before turning on the MMU to avoid stale entries [Julien Grall]
  • e27fd5c081: xen/arm: vgic: Make sure the number of SPIs is a multiple of 32 [Julien Grall]
  • 03f947472f: tools/libxc: Fix restoration of PV MSRs after migrate [Andrew Cooper]
  • c31070f350: tools/libxc: Avoid generating inappropriate zero-content records [Andrew Cooper]
  • 1093876034: x86/hvm: Disallow the creation of HVM domains without Local APIC emulation [Andrew Cooper]
  • 141be845d9: gnttab: don't blindly free status pages upon version change [Jan Beulich]
  • bb49733646: gnttab/ARM: don't corrupt shared GFN array [Jan Beulich]
  • 48faa5045d: memory: don't implicitly unpin for decrease-reservation [Jan Beulich]
  • 5938aa17b4: x86/PV: correctly count MSRs to migrate [Jan Beulich]
  • d11783c992: xen/arm: cpuerrata: Actually check errata on non-boot CPUs [Julien Grall]
  • 8e1e3c7337: tools/kdd: don't use a pointer to an unaligned field. [Tim Deegan]
  • 99ed7863b2: x86/idle: Clear SPEC_CTRL while idle [Andrew Cooper]
  • 76bdfe894a: x86/cpuid: Offer Indirect Branch Controls to guests [Andrew Cooper]
  • fee4689c5c: x86/ctxt: Issue a speculation barrier between vcpu contexts [Andrew Cooper]
  • c0bfde68cc: x86/boot: Calculate the most appropriate BTI mitigation to use [Andrew Cooper]
  • 64c1742b20: x86/entry: Avoid using alternatives in NMI/#MC paths [Andrew Cooper]
  • 86153856f8: x86/entry: Organise the clobbering of the RSB/RAS on entry to Xen [Andrew Cooper]
  • e09a5c2917: x86/entry: Organise the use of MSR_SPEC_CTRL at each entry/exit point [Andrew Cooper]
  • ff570a3ee0: x86/hvm: Permit guests direct access to MSR_{SPEC_CTRL,PRED_CMD} [Andrew Cooper]
  • e6bcb416a5: x86/migrate: Move MSR_SPEC_CTRL on migrate [Andrew Cooper]
  • 29e7171e9d: x86/msr: Emulation of MSR_{SPEC_CTRL,PRED_CMD} for guests [Andrew Cooper]
  • c3d195cd91: x86/cpuid: Handling of IBRS/IBPB, STIBP and IBRS for guests [Andrew Cooper]
  • 2cd189eb55: x86: fix GET_STACK_END [Wei Liu]
  • afdad6a958: x86/acpi: process softirqs while printing CPU ACPI data [Roger Pau Monné]
  • 532ccf4fd5: x86/cmdline: Introduce a command line option to disable IBRS/IBPB, STIBP and IBPB [Andrew Cooper]
  • da49e518d7: x86/feature: Definitions for Indirect Branch Controls [Andrew Cooper]
  • ca9583d9e7: x86: Introduce alternative indirect thunks [Andrew Cooper]
  • 479b879a7d: x86/amd: Try to set lfence as being Dispatch Serialising [Andrew Cooper]
  • 2eefd926bb: x86/boot: Report details of speculative mitigations [Andrew Cooper]
  • 60c50f2b0b: x86: Support indirect thunks from assembly code [Andrew Cooper]
  • 1838e21521: x86: Support compiling with indirect branch thunks [Andrew Cooper]
  • 5732a8ef28: common/wait: Clarifications to wait infrastructure [Andrew Cooper]
  • 987b08d56c: x86/entry: Erase guest GPR state on entry to Xen [Andrew Cooper]
  • eadcd8318c: x86/hvm: Use SAVE_ALL to construct the cpu_user_regs frame after VMExit [Andrew Cooper]
  • ef2464c56e: x86/entry: Rearrange RESTORE_ALL to restore register in stack order [Andrew Cooper]
  • 17bfbc8289: x86: Introduce a common cpuid_policy_updated() [Andrew Cooper]
  • 499391b50b: x86/hvm: Rename update_guest_vendor() callback to cpuid_policy_changed() [Andrew Cooper]
  • 87cb0e2090: x86/alt: Introduce ALTERNATIVE{,_2} macros [Andrew Cooper]
  • 393de92181: update Xen version to 4.8.4-pre [Jan Beulich]
  • 3efcd7fb40: x86/alt: Break out alternative-asm into a separate header file [Andrew Cooper]
  • 2aff8d5e73: x86: Avoid corruption on migrate for vcpus using CPUID Faulting [Andrew Cooper]
  • 11875b7d57: xen/arm32: entry: Document the purpose of r11 in the traps handler [Julien Grall]
  • 1105f3a92d: xen/arm32: Invalidate icache on guest exist for Cortex-A15 [Julien Grall]
  • 754345c019: xen/arm32: Invalidate BTB on guest exit for Cortex A17 and 12 [Julien Grall]
  • 7336d0d2a7: xen/arm32: Add skeleton to harden branch predictor aliasing attacks [Julien Grall]
  • cf95bba7b7: xen/arm32: entry: Add missing trap_reset entry [Julien Grall]
  • a586cbd9f0: xen/arm32: Add missing MIDR values for Cortex-A17 and A12 [Julien Grall]
  • 6082e3ba89: xen/arm32: entry: Consolidate DEFINE_TRAP_ENTRY_* macros [Julien Grall]
  • 6f6786ef0d: xen/arm64: Implement branch predictor hardening for affected Cortex-A CPUs [Julien Grall]
  • 44139fed7c: xen/arm64: Add skeleton to harden the branch predictor aliasing attacks [Julien Grall]
  • cf0b584c8c: xen/arm: cpuerrata: Add MIDR_ALL_VERSIONS [Julien Grall]
  • 85990bf53a: xen/arm64: Add missing MIDR values for Cortex-A72, A73 and A75 [Julien Grall]
  • 946dd2eefa: xen/arm: Introduce enable callback to enable a capabilities on each online CPU [Julien Grall]

This release contains no fixes to fixes to qemu-traditional or qemu-upstream.

This release, which includes source code for qemu-traditional and qemu-upstream, contains the following security fixes. 

<

XSA Xen qemu-traditional qemu-upstream 
XSA-252 Applied N/A N/A
XSA-253 Xen 4.8 not affected ... ...
XSA-254 Applied (XPTI for Variant 3) N/A N/A
XSA-255 Applied N/A N/A
XSA-256 Applied N/A N/A
XSA-257 Unused XSA number ... ...
XSA-258 Applied N/A N/A
XSA-259 Applied N/A N/A
XSA-260 Applied N/A N/A
XSA-261 Applied N/A N/A
XSA-262 Applied N/A N/A
XSA-263 Applied N/A N/A
XSA-264 Applied N/A N/A
XSA-265 Applied N/A N/A
XSA-266 Applied N/A N/A
XSA-267 Applied N/A N/A


See https://xenbits.xenproject.org/xsa/ for details related to Xen Project security advisories.

We recommend all users of the 4.8 stable series to update to this latest point release.

Xen Project 4.8.5

We are pleased to announce the release of Xen 4.8.5. This is available immediately from its git repository 

https://xenbits.xenproject.org/gitweb/?p=xen.git;a=shortlog;h=refs/heads/stable-4.8 (tag RELEASE-4.8.5) or from this download page

This release contains the following bug-fixes and improvements in the Xen Project hypervisor:

  • 908e768fae: update Xen version to 4.8.5 [Jan Beulich]
  • 090d47c927: VMX: allow migration of guests with SSBD enabled [Jan Beulich]
  • 70294dbe2a: x86/dom0: Fix shadowing of PV guests with 2M superpages [Andrew Cooper]
  • 88d77da676: x86/dom0: Avoid using 1G superpages if shadowing may be necessary [Andrew Cooper]
  • 92f31182e0: x86/shadow: shrink struct page_info's shadow_flags to 16 bits [Jan Beulich]
  • 4be61c4d9b: x86/shadow: move OOS flag bit positions [Jan Beulich]
  • 538c7c754a: x86/mm: Don't perform flush after failing to update a guests L1e [Andrew Cooper]
  • 14854d08a8: AMD/IOMMU: suppress PTE merging after initial table creation [Jan Beulich]
  • f030ad0753: amd/iommu: fix flush checks [Roger Pau Monné]
  • d6798ce357: stubdom/vtpm: fix memcmp in TPM_ChangeAuthAsymFinish [Olaf Hering]
  • d792e577dc: x86: work around HLE host lockup erratum [Jan Beulich]
  • ba4eb85319: x86: extend get_platform_badpages() interface [Jan Beulich]
  • 88b5e368ce: tools/dombuilder: Initialise vcpu debug registers correctly [Andrew Cooper]
  • 64fd42fbcb: x86/domain: Initialise vcpu debug registers correctly [Andrew Cooper]
  • 86cba9b023: x86/boot: Initialise the debug registers correctly [Andrew Cooper]
  • 49f74ea609: x86/boot: enable NMIs after traps init [Sergey Dyasli]
  • 5b6fb33d8f: vtd: add missing check for shared EPT... [Paul Durrant]
  • 8d1afd1cef: x86: fix "xpti=" and "pv-l1tf=" yet again [Jan Beulich]
  • 0dbe6acef0: x86: split opt_pv_l1tf [Jan Beulich]
  • 38a7dded19: x86: split opt_xpti [Jan Beulich]
  • bd89569fb5: x86: silence false log messages for plain "xpti" / "pv-l1tf" [Jan Beulich]
  • dee5937802: stubdom/grub.patches: Drop docs changes, for licensing reasons [Ian Jackson]
  • 5670039606: x86/hvm/emulate: make sure rep I/O emulation does not cross GFN boundaries [Paul Durrant]
  • 53dfcb0f6e: x86/shutdown: use ACPI reboot method for Dell PowerEdge R540 [Ross Lagerwall]
  • d4f07fb1a8: x86/shutdown: use ACPI reboot method for Dell PowerEdge R740 [Ross Lagerwall]
  • 005df911f6: x86: assorted array_index_nospec() insertions [Jan Beulich]
  • 8bfab2b5b6: VT-d/dmar: iommu mem leak fix [Zhenzhong Duan]
  • dc814e1920: rangeset: make inquiry functions tolerate NULL inputs [Jan Beulich]
  • 5e8697735b: x86/setup: Avoid OoB E820 lookup when calculating the L1TF safe address [Andrew Cooper]
  • d1a5936d63: x86/hvm/ioreq: MMIO range checking completely ignores direction flag [Paul Durrant]
  • c9fc6b388e: x86/vlapic: Bugfixes and improvements to vlapic_{read,write}() [Andrew Cooper]
  • 21ac6c8e44: x86/vmx: Avoid hitting BUG_ON() after EPTP-related domain_crash() [Andrew Cooper]
  • e52ec4b787: x86: write to correct variable in parse_pv_l1tf() [Jan Beulich]
  • d95b5bb31e: xl.conf: Add global affinity masks [Wei Liu]
  • 565de91ac7: x86: Make "spec-ctrl=no" a global disable of all mitigations [Jan Beulich]
  • 1c6c2def1c: x86/spec-ctrl: Introduce an option to control L1D_FLUSH for HVM HAP guests [Andrew Cooper]
  • 1f56fba486: x86/msr: Virtualise MSR_FLUSH_CMD for guests [Andrew Cooper]
  • 5464d5f0c9: x86/spec-ctrl: CPUID/MSR definitions for L1D_FLUSH [Andrew Cooper]
  • 9e7d5e266a: x86/pv: Force a guest into shadow mode when it writes an L1TF-vulnerable PTE [Juergen Gross]
  • 7849d13d45: x86/mm: Plumbing to allow any PTE update to fail with -ERESTART [Andrew Cooper]
  • e819108a41: x86/shadow: Infrastructure to force a PV guest into shadow mode [Juergen Gross]
  • fe78829480: x86/spec-ctrl: Introduce an option to control L1TF mitigation for PV guests [Andrew Cooper]
  • 28fc483f3d: x86/spec-ctrl: Calculate safe PTE addresses for L1TF mitigations [Andrew Cooper]
  • 712082daee: tools/oxenstored: Make evaluation order explicit [Christian Lindig]
  • ed6fcdb902: x86/vtx: Fix the checking for unknown/invalid MSR_DEBUGCTL bits [Andrew Cooper]
  • 04061641b6: ARM: disable grant table v2 [Stefano Stabellini]
  • e3d0ce38c2: common/gnttab: Introduce command line feature controls [Andrew Cooper]
  • c00fabcd79: VMX: fix vmx_{find,del}_msr() build [Jan Beulich]
  • 3478439f98: x86/vmx: Support load-only guest MSR list entries [Andrew Cooper]
  • b81b74aa1b: x86/vmx: Pass an MSR value into vmx_msr_add() [Andrew Cooper]
  • b289403527: x86/vmx: Improvements to LBR MSR handling [Andrew Cooper]
  • 47fbc6e025: x86/vmx: Support remote access to the MSR lists [Andrew Cooper]
  • ee7bceaf20: x86/vmx: Factor locate_msr_entry() out of vmx_find_msr() and vmx_add_msr() [Andrew Cooper]
  • df5bbf7a4a: x86/vmx: Internal cleanup for MSR load/save infrastructure [Andrew Cooper]
  • d96893fe44: x86/vmx: API improvements for MSR load/save infrastructure [Andrew Cooper]
  • 15508b33a5: x86/vmx: Defer vmx_vmcs_exit() as long as possible in construct_vmcs() [Andrew Cooper]
  • 790ed1521e: x86/vmx: Fix handing of MSR_DEBUGCTL on VMExit [Andrew Cooper]
  • d8389572d4: x86/spec-ctrl: Yet more fixes for xpti= parsing [Andrew Cooper]
  • aa450153f2: x86/spec-ctrl: Fix the parsing of xpti= on fixed Intel hardware [Andrew Cooper]
  • b149b06b1e: x86/hvm: Disallow unknown MSR_EFER bits [Andrew Cooper]
  • c117d09fe3: x86/xstate: Make errors in xstate calculations more obvious by crashing the domain [Andrew Cooper]
  • e343ee80be: x86/xstate: Use a guests CPUID policy, rather than allowing all features [Andrew Cooper]
  • 5566272d5a: x86/vmx: Don't clobber %dr6 while debugging state is lazy [Andrew Cooper]
  • f049cd67a9: x86: command line option to avoid use of secondary hyper-threads [Jan Beulich]
  • 6dc0bc5881: x86: possibly bring up all CPUs even if not all are supposed to be used [Jan Beulich]
  • 37a1b4aa4c: x86: distinguish CPU offlining from CPU removal [Jan Beulich]
  • f6a31ed471: x86/AMD: distinguish compute units from hyper-threads [Jan Beulich]
  • 08eda978c2: cpupools: fix state when downing a CPU failed [Jan Beulich]
  • 96bf2dbc8d: allow cpu_down() to be called earlier [Jan Beulich]
  • 23975f5137: xen: oprofile/nmi_int.c: Drop unwanted sexual reference [Ian Jackson]
  • f3b0cdb49f: x86/spec-ctrl: command line handling adjustments [Jan Beulich]
  • f5ef10dd01: x86: correctly set nonlazy_xstate_used when loading full state [Jan Beulich]
  • de172b0ff6: xen: Port the array_index_nospec() infrastructure from Linux [Andrew Cooper]
  • 3686d0963e: cmdline: fix parse_boolean() for NULL incoming end pointer [Jan Beulich]
  • 4aec0c7ff5: update Xen version to 4.8.5-pre [Jan Beulich]

This release also contains NO fixes to qemu-traditional.

This release also contains changes to qemu-upstream, whose changelogs we do not list here as it contains many changes that are not directly releated to the Xen Project Hypervisor and thus this release. However, you can check https://xenbits.xenproject.org/gitweb/?p=qemu-xen.git;a=shortlog (between tags qemu-xen-4.8.4 and qemu-xen-4.8.5).

This release, which includes source code for qemu-traditional and qemu-upstream, contains the following security fixes. 

XSA Xen qemu-traditional qemu-upstream 
XSA-268 Applied Applied Applied
XSA-269 Applied Applied Applied
XSA-270 N/A (Linux only) ... ...
XSA-271 N/A (XAPI only) ... ...
XSA-272 Applied Applied Applied
XSA-273 Applied Applied Applied
XSA-274 N/A (Linux only) ... ...
XSA-275 Applied Applied Applied
XSA-276 N/A (Xen 4.11+ only) ... ...
XSA-277 N/A (Xen 4.11+ only) ... ...
XSA-278 Applied Applied Applied
XSA-279 Applied Applied Applied
XSA-280 Applied Applied Applied
XSA-281 N/A (Unused number) ... ...
XSA-282 Applied Applied Applied


See https://xenbits.xenproject.org/xsa/ for details related to Xen Project security advisories.

We recommend all users of the 4.8 stable series to update to this latest point release.