> -----Original Message----- > From: Michael Kelley (LINUX) <mikelley@xxxxxxxxxxxxx> > Sent: Thursday, December 9, 2021 2:54 PM > To: Haiyang Zhang <haiyangz@xxxxxxxxxxxxx>; Tianyu Lan <ltykernel@xxxxxxxxx>; KY > Srinivasan <kys@xxxxxxxxxxxxx>; Stephen Hemminger <sthemmin@xxxxxxxxxxxxx>; > wei.liu@xxxxxxxxxx; Dexuan Cui <decui@xxxxxxxxxxxxx>; tglx@xxxxxxxxxxxxx; mingo@xxxxxxxxxx; > bp@xxxxxxxxx; dave.hansen@xxxxxxxxxxxxxxx; x86@xxxxxxxxxx; hpa@xxxxxxxxx; > davem@xxxxxxxxxxxxx; kuba@xxxxxxxxxx; jejb@xxxxxxxxxxxxx; martin.petersen@xxxxxxxxxx; > arnd@xxxxxxxx; hch@xxxxxxxxxxxxx; m.szyprowski@xxxxxxxxxxx; robin.murphy@xxxxxxx; Tianyu > Lan <Tianyu.Lan@xxxxxxxxxxxxx>; thomas.lendacky@xxxxxxx > Cc: iommu@xxxxxxxxxxxxxxxxxxxxxxxxxx; linux-arch@xxxxxxxxxxxxxxx; linux- > hyperv@xxxxxxxxxxxxxxx; linux-kernel@xxxxxxxxxxxxxxx; linux-scsi@xxxxxxxxxxxxxxx; > netdev@xxxxxxxxxxxxxxx; vkuznets <vkuznets@xxxxxxxxxx>; brijesh.singh@xxxxxxx; > konrad.wilk@xxxxxxxxxx; hch@xxxxxx; joro@xxxxxxxxxx; parri.andrea@xxxxxxxxx; > dave.hansen@xxxxxxxxx > Subject: RE: [PATCH V6 5/5] net: netvsc: Add Isolation VM support for netvsc driver > > From: Haiyang Zhang <haiyangz@xxxxxxxxxxxxx> Sent: Wednesday, December 8, 2021 12:14 PM > > > From: Tianyu Lan <ltykernel@xxxxxxxxx> > > > Sent: Tuesday, December 7, 2021 2:56 AM > > [snip] > > > > static inline int netvsc_send_pkt( > > > struct hv_device *device, > > > struct hv_netvsc_packet *packet, > > > @@ -986,14 +1105,24 @@ static inline int netvsc_send_pkt( > > > > > > trace_nvsp_send_pkt(ndev, out_channel, rpkt); > > > > > > + packet->dma_range = NULL; > > > if (packet->page_buf_cnt) { > > > if (packet->cp_partial) > > > pb += packet->rmsg_pgcnt; > > > > > > + ret = netvsc_dma_map(ndev_ctx->device_ctx, packet, pb); > > > + if (ret) { > > > + ret = -EAGAIN; > > > + goto exit; > > > + } > > > > Returning EAGAIN will let the upper network layer busy retry, > > which may make things worse. > > I suggest to return ENOSPC here like another place in this > > function, which will just drop the packet, and let the network > > protocol/app layer decide how to recover. > > > > Thanks, > > - Haiyang > > I made the original suggestion to return -EAGAIN here. A > DMA mapping failure should occur only if swiotlb bounce > buffer space is unavailable, which is a transient condition. > The existing code already stops the queue and returns > -EAGAIN when the ring buffer is full, which is also a transient > condition. My sense is that the two conditions should be > handled the same way. Or is there a reason why a ring > buffer full condition should stop the queue and retry, while > a mapping failure should drop the packet? The netvsc_dma_map() fails in these two places. The dma_map_single() is doing the maping with swiotlb bounce buffer, correct? And it will become successful after the previous packets are unmapped? + packet->dma_range = kcalloc(page_count, + sizeof(*packet->dma_range), + GFP_KERNEL); + dma = dma_map_single(&hv_dev->device, src, len, + DMA_TO_DEVICE); I recalled your previous suggestion now, and agree with you that we can treat it the same way (return -EAGAIN) in this case. And the existing code will stop the queue temporarily. Thanks, - Haiyang