Recent x86 CPUs offer functionality named Control-flow Enforcement Technology (CET). A sub-feature of this are Shadow Stacks (CET-SS). CET-SS is a hardware feature designed to protect against Return Oriented Programming attacks. When enabled, traditional stacks holding both data and return addresses are accompanied by so called "shadow stacks", holding little more than return addresses. Shadow stacks aren't writable by normal instructions, and upon function returns their contents are used to check for possible manipulation of a return address coming from the traditional stack. In particular certain memory accesses need intercepting by Xen. In various cases the necessary emulation involves kind of replaying of the instruction. Such replaying typically involves filling and then invoking of a stub. Such a replayed instruction may raise an exceptions, which is expected and dealt with accordingly. Unfortunately the interaction of both of the above wasn't right: Recovery involves removal of a call frame from the (traditional) stack. The counterpart of this operation for the shadow stack was missing.
{ "binaries": [ { "binary_version": "4.16.0-1~ubuntu2.1", "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" } ] }
{ "binaries": [ { "binary_version": "4.17.3+10-g091466ba55-1.1ubuntu3", "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" } ] }
{ "binaries": [ { "binary_version": "4.20.0-1ubuntu1", "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" } ] }
{ "binaries": [ { "binary_version": "4.6.5-0ubuntu1.4", "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" } ] }
{ "binaries": [ { "binary_version": "4.9.2-0ubuntu1", "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" } ] }
{ "binaries": [ { "binary_version": "4.11.3+24-g14b62ab3e5-1ubuntu2.3", "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" } ] }