diff options
author | Michael Kelley <mikelley@microsoft.com> | 2023-01-30 19:33:06 -0800 |
---|---|---|
committer | Paolo Abeni <pabeni@redhat.com> | 2023-02-02 09:15:30 +0100 |
commit | 99f1c46011cc0feb47d4f4f7bee70a0341442d14 (patch) | |
tree | 4d7c52e00b3aa9199dda31fe7c18c22c492de488 /usr | |
parent | 917d5e04d4dd2bbbf36fc6976ba442e284ccc42d (diff) | |
download | linux-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