]> git.baikalelectronics.ru Git - kernel.git/commit
ptp: Fix ptp_kvm_getcrosststamp issue for x86 ptp_kvm
authorZelin Deng <zelin.deng@linux.alibaba.com>
Wed, 29 Sep 2021 05:13:49 +0000 (13:13 +0800)
committerPaolo Bonzini <pbonzini@redhat.com>
Thu, 30 Sep 2021 08:08:15 +0000 (04:08 -0400)
commitd07204c4c12c1e1595be6894f11952c77f8beb66
tree21f02e8fab3cd99d60b240830e0b7e2897ada3df
parent28db5de8be10325d9427c6da332be5690cd0f12a
ptp: Fix ptp_kvm_getcrosststamp issue for x86 ptp_kvm

hv_clock is preallocated to have only HVC_BOOT_ARRAY_SIZE (64) elements;
if the PTP_SYS_OFFSET_PRECISE ioctl is executed on vCPUs whose index is
64 of higher, retrieving the struct pvclock_vcpu_time_info pointer with
"src = &hv_clock[cpu].pvti" will result in an out-of-bounds access and
a wild pointer.  Change it to "this_cpu_pvti()" which is guaranteed to
be valid.

Fixes: 32d9cd7c0bf0 ("Switch kvmclock data to a PER_CPU variable")
Signed-off-by: Zelin Deng <zelin.deng@linux.alibaba.com>
Cc: <stable@vger.kernel.org>
Message-Id: <1632892429-101194-3-git-send-email-zelin.deng@linux.alibaba.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
drivers/ptp/ptp_kvm_x86.c