summaryrefslogtreecommitdiffstats
path: root/usr
diff options
context:
space:
mode:
authorMichael Kelley <mikelley@microsoft.com>2023-01-30 19:33:06 -0800
committerPaolo Abeni <pabeni@redhat.com>2023-02-02 09:15:30 +0100
commit99f1c46011cc0feb47d4f4f7bee70a0341442d14 (patch)
tree4d7c52e00b3aa9199dda31fe7c18c22c492de488 /usr
parent917d5e04d4dd2bbbf36fc6976ba442e284ccc42d (diff)
downloadlinux-stable-99f1c46011cc0feb47d4f4f7bee70a0341442d14.tar.gz
linux-stable-99f1c46011cc0feb47d4f4f7bee70a0341442d14.tar.bz2
linux-stable-99f1c46011cc0feb47d4f4f7bee70a0341442d14.zip
hv_netvsc: Fix missed pagebuf entries in netvsc_dma_map/unmap()
netvsc_dma_map() and netvsc_dma_unmap() currently check the cp_partial flag and adjust the page_count so that pagebuf entries for the RNDIS portion of the message are skipped when it has already been copied into a send buffer. But this adjustment has already been made by code in netvsc_send(). The duplicate adjustment causes some pagebuf entries to not be mapped. In a normal VM, this doesn't break anything because the mapping doesn’t change the PFN. But in a Confidential VM, dma_map_single() does bounce buffering and provides a different PFN. Failing to do the mapping causes the wrong PFN to be passed to Hyper-V, and various errors ensue. Fix this by removing the duplicate adjustment in netvsc_dma_map() and netvsc_dma_unmap(). Fixes: 846da38de0e8 ("net: netvsc: Add Isolation VM support for netvsc driver") Cc: stable@vger.kernel.org Signed-off-by: Michael Kelley <mikelley@microsoft.com> Reviewed-by: Haiyang Zhang <haiyangz@microsoft.com> Link: https://lore.kernel.org/r/1675135986-254490-1-git-send-email-mikelley@microsoft.com Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Diffstat (limited to 'usr')
0 files changed, 0 insertions, 0 deletions