Mishandling of guest SSBD selection on AMD hardware The current logic to set SSBD on AMD Family 17h and Hygon Family 18h processors requires that the setting of SSBD is coordinated at a core level, as the setting is shared between threads. Logic was introduced to keep track of how many threads require SSBD active in order to coordinate it, such logic relies on using a per-core counter of threads that have SSBD active. When running on the mentioned hardware, it's possible for a guest to under or overflow the thread counter, because each write to VIRTSPECCTRL.SSBD by the guest gets propagated to the helper that does the per-core active accounting. Underflowing the counter causes the value to get saturated, and thus attempts for guests running on the same core to set SSBD won't have effect because the hypervisor assumes it's already active.
{
    "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"
        }
    ]
}