[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]
Subject: Re: [virtio-comment] Re: [PATCH v5] virtio-net: device does not deliver partially checksummed packet and may validate the checksum
On Tue, Dec 19, 2023 at 03:53:14PM +0800, Jason Wang wrote: > On Mon, Dec 18, 2023 at 12:54âPM Heng Qi <hengqi@linux.alibaba.com> wrote: > > > > > > > > å 2023/12/18 äå11:10, Jason Wang åé: > > > On Fri, Dec 15, 2023 at 5:51âPM Heng Qi <hengqi@linux.alibaba.com> wrote: > > >> Hi all! > > >> > > >> I would like to ask if anyone has any comments on this version, if so > > >> please let me know! > > >> If not, I will collect Michael's comments and publish a new version next > > >> Monday. > > > I have a dumb question. (And sorry if I asked it before) > > > > > > Looking at the spec and code. It looks to me DATA_VALID could be set > > > without GUEST_CSUM. > > > > I don't see that in the spec. > > Am I missing something? [1][2] > > > > [1] If the VIRTIO_NET_F_GUEST_CSUM feature was negotiated, the > > VIRTIO_NET_HDR_F_DATA_VALID bit in flags can be set: if so, device has > > validated the packet checksum. In case of multiple encapsulated > > protocols, one level of checksums has been validated. > > Additionally, VIRTIO_NET_F_GUEST_CSUM, TSO4, TSO6, UDP and ECN features > > *enable receive checksum*, large receive offload and ECN support which > > are the input equivalents of the transmit checksum, transmit > > segmentation *offloading* and ECN features, as described in 5.1.6.2. > > > > [2] If VIRTIO_NET_F_GUEST_CSUM is not negotiated, the device *MUST set > > flags to zero* and SHOULD supply a fully checksummed packet to the driver. > > So this is kind of ambiguous and seems not what I wanted when I wrote > the code for DATA_VALID in 2011. > > NEEDS_CSUM maps to CHECKSUM_PARTIAL which means the packet checksum is > correct. So spec had > > """ > If neither VIRTIO_NET_HDR_F_NEEDS_CSUM nor VIRTIO_NET_HDR_F_DATA_VALID > is set, the driver MUST NOT rely on the packet checksum being correct. > """ > > For DATA_VALID, it maps to CHECKSUM_UNNECESSARY which is mutually > exclusive with CHECKSUM_PARTAIL. And this is what Linux did right now: > > For tun_put_user(): > > if (skb->ip_summed == CHECKSUM_PARTIAL) { > ... > } else if (has_data_valid && > skb->ip_summed == CHECKSUM_UNNECESSARY) { > hdr->flags = VIRTIO_NET_HDR_F_DATA_VALID; > } /* else everything is zero */ > > This CHECKSUM_UNNECESSARY will work even if GUEST_CSUM is disabled if > I was not wrong. > > And in receive_buf(): > > if (hdr->hdr.flags & VIRTIO_NET_HDR_F_DATA_VALID) > skb->ip_summed = CHECKSUM_UNNECESSARY; > > I think we can fix this by safely removing "*MUST set flags to zero*" > in [2] from the spec. > > Thanks I don't get why you want to remove this. I think this text refers to when no offloads are negotiated. Why would device then set any flags? > > > > > I think the reason why the feature bit is not checked in the code is > > because the check is omitted because it is on a per-packet basis, > > just like the reason why supported_valid_types is not needed as > > discussed in the v4 version threads. It is not unnecessary. > > > > Thanks! > > > > > > > > If yes, why do we need to bother here? If we disable GUEST_CSUM, the > > > packet will contain checksum. And if the device sets DATA_VALID, it > > > means the checksum is validated. > > > > > > Thanks > > > > > > > > > > > >> Since Christmas is coming, I think this feature may be in danger of > > >> following the pace of > > >> our hw version releases, so I sincerely request that you please review > > >> it as soon as possible. > > >> > > >> Thanks! > > >> > > >> å 2023/12/12 äå5:30, Heng Qi åé: > > >>> > > >>> å 2023/12/12 äå5:23, Heng Qi åé: > > >>>> > > >>>> å 2023/12/12 äå4:44, Michael S. Tsirkin åé: > > >>>>> On Tue, Dec 12, 2023 at 11:28:21AM +0800, Heng Qi wrote: > > >>>>>> å 2023/12/12 äå12:35, Michael S. Tsirkin åé: > > >>>>>>> On Mon, Dec 11, 2023 at 05:11:59PM +0800, Heng Qi wrote: > > >>>>>>>> virtio-net works in a virtualized system and is somewhat > > >>>>>>>> different from > > >>>>>>>> physical nics. One of the differences is that to save virtio device > > >>>>>>>> resources, rx may receive partially checksummed packets. However, > > >>>>>>>> XDP may > > >>>>>>>> cause partially checksummed packets to be dropped. > > >>>>>>>> So XDP loading currently conflicts with the feature > > >>>>>>>> VIRTIO_NET_F_GUEST_CSUM. > > >>>>>>>> > > >>>>>>>> This patch lets the device to supply fully checksummed packets to > > >>>>>>>> the driver. > > >>>>>>>> Then XDP can coexist with VIRTIO_NET_F_GUEST_CSUM to enjoy the > > >>>>>>>> benefits of > > >>>>>>>> device validation checksum. > > >>>>>>>> > > >>>>>>>> In addition, implementation of some performant devices always do > > >>>>>>>> not generate > > >>>>>>>> partially checksummed packets, but the standard driver still need > > >>>>>>>> to clear > > >>>>>>>> VIRTIO_NET_F_GUEST_CSUM when XDP is there. > > >>>>>>>> A new feature VIRTIO_NET_F_GUEST_FULLY_CSUM is added to solve the > > >>>>>>>> above > > >>>>>>>> situation, which provides the driver with configurable offload. > > >>>>>>>> If the offload is enabled, then the device must deliver fully > > >>>>>>>> checksummed packets to the driver and may validate the checksum. > > >>>>>>>> > > >>>>>>>> Use case example: > > >>>>>>>> If VIRTIO_NET_F_GUEST_FULLY_CSUM is negotiated and the offload is > > >>>>>>>> enabled, > > >>>>>>>> after XDP processes a fully checksummed packet, the > > >>>>>>>> VIRTIO_NET_HDR_F_DATA_VALID bit > > >>>>>>>> is retained if the device has validated its checksum, resulting > > >>>>>>>> in the guest > > >>>>>>>> not needing to validate the checksum again. This is useful for > > >>>>>>>> guests: > > >>>>>>>> 1. Bring the driver advantages such as cpu savings. > > >>>>>>>> 2. For devices that do not generate partially checksummed > > >>>>>>>> packets themselves, > > >>>>>>>> XDP can be loaded in the driver without modifying the > > >>>>>>>> hardware behavior. > > >>>>>>>> > > >>>>>>>> Several solutions have been discussed in the previous proposal[1]. > > >>>>>>>> After historical discussion, we have tried the method proposed by > > >>>>>>>> Jason[2], > > >>>>>>>> but some complex scenarios and challenges are difficult to deal > > >>>>>>>> with. > > >>>>>>>> We now return to the method suggested in [1]. > > >>>>>>>> > > >>>>>>>> [1] > > >>>>>>>> https://lists.oasis-open.org/archives/virtio-dev/202305/msg00291.html > > >>>>>>>> > > >>>>>>>> [2] > > >>>>>>>> https://lore.kernel.org/all/20230628030506.2213-1-hengqi@linux.alibaba.com/ > > >>>>>>>> > > >>>>>>>> Signed-off-by: Heng Qi <hengqi@linux.alibaba.com> > > >>>>>>>> Reviewed-by: Xuan Zhuo <xuanzhuo@linux.alibaba.com> > > >>>>>>>> --- > > >>>>>>>> v4->v5: > > >>>>>>>> - Remove the modification to the GUEST_CSUM. > > >>>>>>>> - The description of this feature has been reorganized for > > >>>>>>>> greater clarity. > > >>>>>>>> > > >>>>>>>> v3->v4: > > >>>>>>>> - Streamline some repetitive descriptions. @Jason > > >>>>>>>> - Add how features should work, when to be enabled, and overhead. > > >>>>>>>> @Jason @Michael > > >>>>>>>> > > >>>>>>>> v2->v3: > > >>>>>>>> - Add a section named "Driver Handles Fully Checksummed Packets" > > >>>>>>>> and more descriptions. @Michael > > >>>>>>>> > > >>>>>>>> v1->v2: > > >>>>>>>> - Modify full checksum functionality as a configurable offload > > >>>>>>>> that is initially turned off. @Jason > > >>>>>>>> > > >>>>>>>> device-types/net/description.tex | 74 > > >>>>>>>> +++++++++++++++++++++++-- > > >>>>>>>> device-types/net/device-conformance.tex | 1 + > > >>>>>>>> device-types/net/driver-conformance.tex | 1 + > > >>>>>>>> introduction.tex | 3 + > > >>>>>>>> 4 files changed, 73 insertions(+), 6 deletions(-) > > >>>>>>>> > > >>>>>>>> diff --git a/device-types/net/description.tex > > >>>>>>>> b/device-types/net/description.tex > > >>>>>>>> index aff5e08..ab6c13d 100644 > > >>>>>>>> --- a/device-types/net/description.tex > > >>>>>>>> +++ b/device-types/net/description.tex > > >>>>>>>> @@ -122,6 +122,9 @@ \subsection{Feature bits}\label{sec:Device > > >>>>>>>> Types / Network Device / Feature bits > > >>>>>>>> device with the same MAC address. > > >>>>>>>> \item[VIRTIO_NET_F_SPEED_DUPLEX(63)] Device reports speed and > > >>>>>>>> duplex. > > >>>>>>>> + > > >>>>>>>> +\item[VIRTIO_NET_F_GUEST_FULLY_CSUM (64)] Device delivers fully > > >>>>>>>> checksummed packets > > >>>>>>>> + to the driver and may validate the checksum. > > >>>>>>>> \end{description} > > >>>>>>> I propose > > >>>>>>> VIRTIO_NET_F_GUEST_CSUM_COMPLETE > > >>>>>>> instead. > > >>>>>> Can I ask here if *complete* in VIRTIO_NET_F_GUEST_CSUM_COMPLETE and > > >>>>>> CHECKSUM_COMPLETE mean the same thing? > > >>>>>> > > >>>>>> If so, it seems that it's no longer the same as the description of > > >>>>>> this > > >>>>>> patch. > > >>>>> Oh. I thought it is. Then I guess I misunderstand what this patch is > > >>>>> supposed to be doing, again. > > >>>> Here's some context: > > >>>> > > >>>> From the perspective of the Linux kernel, the GUEST_CSUM feature is > > >>>> negotiated to support > > >>>> (1) CHECKSUM_NONE, (2) CHECKSUM_UNNECESSARY, (3) CHECKSUM_PARTIAL, > > >>>> which > > >>>> respectively correspond to (1) the device does not validate the > > >>>> packet checksum (may not have > > >>>> the ability to validate some protocols or does not recognize the > > >>>> packet); (2) the device has verified > > >>>> the data packet, then sets DATA_VALID bit in flags; (3) In order to > > >>>> save device resources, VMs > > >>>> on the same host deliver partially checksummed packets, and > > >>>> NEEDS_CSUM bit is set in flags. > > >>>> > > >>>> GUEST_FULLY_CSUM did not change the above result. > > >>> Sorry, GUEST_FULLY_CSUM prohibits the third(3) action. > > >>> > > >>>>> > > >>>>>>>> \subsubsection{Feature bit requirements}\label{sec:Device > > >>>>>>>> Types / Network Device / Feature bits / Feature bit requirements} > > >>>>>>>> @@ -136,6 +139,7 @@ \subsubsection{Feature bit > > >>>>>>>> requirements}\label{sec:Device Types / Network Device > > >>>>>>>> \item[VIRTIO_NET_F_GUEST_UFO] Requires VIRTIO_NET_F_GUEST_CSUM. > > >>>>>>>> \item[VIRTIO_NET_F_GUEST_USO4] Requires VIRTIO_NET_F_GUEST_CSUM. > > >>>>>>>> \item[VIRTIO_NET_F_GUEST_USO6] Requires VIRTIO_NET_F_GUEST_CSUM. > > >>>>>>>> +\item[VIRTIO_NET_F_GUEST_FULLY_CSUM] Requires > > >>>>>>>> VIRTIO_NET_F_GUEST_CSUM and VIRTIO_NET_F_CTRL_GUEST_OFFLOADS. > > >>>>>>> > > >>>>>>>> \item[VIRTIO_NET_F_HOST_TSO4] Requires VIRTIO_NET_F_CSUM. > > >>>>>>>> \item[VIRTIO_NET_F_HOST_TSO6] Requires VIRTIO_NET_F_CSUM. > > >>>>>>>> @@ -398,6 +402,58 @@ \subsection{Device > > >>>>>>>> Initialization}\label{sec:Device Types / Network Device / Dev > > >>>>>>>> A truly minimal driver would only accept VIRTIO_NET_F_MAC and > > >>>>>>>> ignore > > >>>>>>>> everything else. > > >>>>>>>> +\subsubsection{Device Delivers Fully Checksummed > > >>>>>>>> Packets}\label{sec:Device Types / Network Device / Device > > >>>>>>>> Initialization / Device Delivers Fully Checksummed Packets} > > >>>>>>>> + > > >>>>>>>> +If the feature VIRTIO_NET_F_GUEST_FULLY_CSUM is negotiated, the > > >>>>>>>> driver can > > >>>>>>>> +benefit from the device's ability to calculate and validate the > > >>>>>>>> checksum. > > >>>>>>>> + > > >>>>>>>> +If the feature VIRTIO_NET_F_GUEST_FULLY_CSUM is negotiated, > > >>>>>>>> +the device behaves as follows: > > >>>>>>>> +\begin{itemize} > > >>>>>>>> + \item The device delivers a fully checksummed packet to the > > >>>>>>>> driver rather than a partially checksummed packet. > > >>>>>>> where does "partially checksummed packet" come from? > > >>>>>>> I think it comes from: > > >>>>>> Yes, you are right. > > >>>>>> > > >>>>>>> The VIRTIO_NET_F_GUEST_CSUM feature indicates that partially > > >>>>>>> checksummed packets can be received, and if it can do that then > > >>>>>>> the VIRTIO_NET_F_GUEST_TSO4, VIRTIO_NET_F_GUEST_TSO6, > > >>>>>>> VIRTIO_NET_F_GUEST_UFO, VIRTIO_NET_F_GUEST_ECN, > > >>>>>>> VIRTIO_NET_F_GUEST_USO4 > > >>>>>>> and VIRTIO_NET_F_GUEST_USO6 are the input equivalents of the > > >>>>>>> features described above. > > >>>>>>> See \ref{sec:Device Types / Network Device / Device Operation / > > >>>>>>> > > >>>>>>> > > >>>>>>> so that one needs to be updated too. > > >>>>>> Will update this. > > >>>>>> > > >>>>>>>> +Partially checksummed packets come from TCP/UDP protocols > > >>>>>>>> \ref{devicenormative:Device Types / Network Device / Device > > >>>>>>>> Operation / Processing of Packets}. > > >>>>>>>> + \item The device may validate the packet checksum before > > >>>>>>>> delivering it. > > >>>>>>>> +If the packet checksum has been verified, the > > >>>>>>>> VIRTIO_NET_HDR_F_DATA_VALID bit > > >>>>>>>> +in \field{flags} is set: in case of multiple encapsulated > > >>>>>>>> protocols, one > > >>>>>>>> +level of checksums has been validated (Just like > > >>>>>>>> VIRTIO_NET_F_GUEST_CSUM does.). > > >>>>>>>> + \item The device can not set the VIRTIO_NET_HDR_F_NEEDS_CSUM > > >>>>>>>> bit in \field{flags}. > > >>>>>>>> +\end{itemize} > > >>>>>>>> + > > >>>>>>>> +Note that packet types that the driver or device can recognize > > >>>>>>>> and the device > > >>>>>>>> +may verify will not change due to the additional negotiated > > >>>>>>>> VIRTIO_NET_F_GUEST_FULLY_CSUM. > > >>>>>>>> +These remain consistent with VIRTIO_NET_F_GUEST_CSUM. > > >>>>>>> This part is confusing. "change" and "remain" makes no sense for > > >>>>>>> someone reading > > >>>>>>> the spec text as opposed to reviewing the patch. > > >>>>>>> also it does not matter whether VIRTIO_NET_F_GUEST_FULLY_CSUM > > >>>>>>> is negotiated right? it only matters whether it is enabled. > > >>>>>> Right! And following your suggestion, I plan to rewrite it as follows: > > >>>>>> > > >>>>>> Note that if VIRTIO_NET_F_GUEST_FULLY_CSUM is additionally > > >>>>>> negotiated and > > >>>>>> its offload is enabled, packet types that the driver or device can > > >>>>>> recognize > > >>>>>> and the > > >>>>>> device may verify are consistent with when VIRTIO_NET_F_GUEST_CSUM is > > >>>>>> negotiated. > > >>>>> This doesn't really clarify. If you'd like it put more simply: Never > > >>>>> imagine yourself not to be otherwise than what it might appear to > > >>>>> others > > >>>>> that what you were or might have been was not otherwise than what you > > >>>>> had been would have appeared to them to be otherwise. > > >>>> Sorry, I'm not a native speaker and didn't quite understand this long > > >>>> sentence. > > >>>> But I think you suggest that I should not explain something from the > > >>>> perspective > > >>>> of someone who is already familiar with it, but should try to explain > > >>>> it clearly > > >>>> for readers who are not familiar with it. > > >>>> > > >>>> I'll try to explain it more clearly. > > >>>> > > >>>>>>>> +Specific transport protocols that may have > > >>>>>>>> VIRTIO_NET_HDR_F_DATA_VALID set > > >>>>>>>> +in \field{flags} include TCP, UDP, GRE (Generic Routing > > >>>>>>>> Encapsulation), > > >>>>>>>> +and SCTP (Stream Control Transmission Protocol). > > >>>>>>>> +A fully checksummed packet's checksum field for each of the > > >>>>>>>> above protocols > > >>>>>>>> +is set to a calculated value that covers the transport header > > >>>>>>>> and payload > > >>>>>>>> +(TCP or UDP involves the additional pseudo header) of the packet. > > >>>>>>>> + > > >>>>>>>> +Delivering fully checksummed packets rather than partially > > >>>>>>>> +checksummed packets incurs additional overhead for the device. > > >>>>>>>> +The overhead varies from device to device, for example the > > >>>>>>>> overhead of > > >>>>>>>> +calculating and validating the packet checksum is a few > > >>>>>>>> microseconds > > >>>>>>>> +for a hardware device. > > >>>>>>> wow really is that standard? There are devices that deliver the whole > > >>>>>>> packet in a few microseconds. Maybe "for some hardware devices"? > > >>>>>> Ok, I think it's more accurate. > > >>>>>> > > >>>>>>>> + > > >>>>>>>> +The feature VIRTIO_NET_F_GUEST_FULLY_CSUM has a corresponding > > >>>>>>>> offload \ref{sec:Device Types / Network Device / Device Operation > > >>>>>>>> / Control Virtqueue / Offloads State Configuration}, > > >>>>>>>> +which when enabled means that the device delivers fully > > >>>>>>>> checksummed packets > > >>>>>>>> +to the driver and may validate the checksum. > > >>>>>>>> +The offload is disabled by default. > > >>>>>>> This is unusual, unlike any other offload. So needs to be stressed > > >>>>>>> more. And what does "default" mean here? > > >>>>>>> E.g. "Note: unlike other offloads, this offloads is disabled > > >>>>>>> even after VIRTIO_NET_F_GUEST_FULLY_CSUM has been negotiation. > > >>>>>> Ok. Will rewrite this following your example. > > >>>>>> > > >>>>>>> The offload has to be enabled ... " > > >>>>>>> > > >>>>>>> > > >>>>>>>> + > > >>>>>>>> +The driver can enable the offload by sending the > > >>>>>>>> +VIRTIO_NET_CTRL_GUEST_OFFLOADS_SET command with the > > >>>>>>>> +VIRTIO_NET_F_GUEST_FULLY_CSUM bit set when, for example, > > >>>>>>>> +eXpress Data Path (XDP) \hyperref[intro:xdp]{[XDP]} is functioning. > > >>>>>>> It is not worth adding a spec link just to provide an example. > > >>>>>>> If you really want to provide it: > > >>>>>>> "eXpress Data Path (XDP) in Linux is active". > > >>>>>>> > > >>>>>>> But this is the problem this patch does not solve in my opinion. > > >>>>>>> A device might actually provide a full checksum > > >>>>>>> at negligeable extra cost and driver will still keep it off by > > >>>>>>> default. > > >>>>>>> So it slows device down - when does it make sense to enable this > > >>>>>>> feature? > > >>>>>>> Just giving an example of XDP is not sufficient. > > >>>>>> First of all, I think the core purpose of this patch is to support XDP > > >>>>>> loading. > > >>>>>> Otherwise, I think GUEST_CSUM works just fine. > > >>>>>> > > >>>>>> 1. The device is performant, even if only GUEST_CSUM is negotiated, > > >>>>>> the > > >>>>>> device only provide fully checksummed packets. > > >>>>>> If the offload of GUEST_FULLY_CSUM is disabled, it is equivalent to > > >>>>>> only > > >>>>>> GUEST_CSUM working, and the device still > > >>>>>> provides fully checksummed packets. This will not slow the device > > >>>>>> down. > > >>>>>> > > >>>>>> 2. For example a sw device. If the device only negotiates > > >>>>>> GUEST_CSUM, it may > > >>>>>> provide partially checksummed packets. > > >>>>>> In the absence of XDP loading requirements, the driver does not > > >>>>>> need to > > >>>>>> enable GUEST_FULLY_CSUM offload. > > >>>>> Well first of all I am no longer even sure what this GUEST_FULLY_CSUM > > >>>>> does. I thought it is CHECKSUM_COMPLETE. > > >>>>> But more generally, is there an assumption driver will not > > >>>>> enable this new checksum typically then? Unless what? If we never > > >>>>> tell drivers they should not enable it they will, the > > >>>>> fact that it's off by default seems to be a hint that it > > >>>>> is typically a bad idea to enable it. But when is it a good idea? > > >>>> I think the core difference between GUEST_FULLY_CSUM and GUEST_CSUM > > >>>> is that > > >>>> GUEST_CSUM may generate partially checksummed TCP/UDP packets, > > >>>> causing xdp to fail to load. > > >>>> GUEST_FULLY_CSUM forces fully checksummed TCP/UDP packets to be > > >>>> generated so xdp can load. > > >>>> For the rest, I guess there is no difference between GUEST_FULLY_CSUM > > >>>> and GUEST_CSUM. > > >>>> > > >>>> As for when the driver enables the offload, I think I have already > > >>>> mentioned: > > >>>> Enable this offload in the interface where XDP is loaded, > > >>>> Disable this offload in the interfaces where XDP is unloaded. > > >>>> > > >>>> Thanksï > > >>>> > > >>>>> > > >>>>>>> > > >>>>>>>> + > > >>>>>>>> +\drivernormative{\subsubsection}{Device Delivers Fully > > >>>>>>>> Checksummed Packets}{sec:Device Types / Network Device / Device > > >>>>>>>> Initialization / Device Delivers Fully Checksummed Packets} > > >>>>>>>> + > > >>>>>>>> +The driver MUST NOT enable the offload for which > > >>>>>>>> VIRTIO_NET_F_GUEST_FULLY_CSUM has not been negotiated. > > >>>>>>> what does "the offload for which" mean here? > > >>>>>> VIRTIO_NET_F_GUEST_FULLY_CSUM's offload > > >>>>>> > > >>>>>>> and how is this special for VIRTIO_NET_F_GUEST_FULLY_CSUM? > > >>>>>> Well, I think this sentence seems a bit redundant and I'll probably > > >>>>>> remove > > >>>>>> this. > > >>>>>> > > >>>>>>>> +\devicenormative{\subsubsection}{Device Delivers Fully > > >>>>>>>> Checksummed Packets}{sec:Device Types / Network Device / Device > > >>>>>>>> Initialization / Device Delivers Fully Checksummed Packets} > > >>>>>>>> + > > >>>>>>>> +Upon the device reset, the device MUST disable the offload. > > >>>>>>>> + > > >>>>>>> reset has nothing to do with it I think. it's about feature > > >>>>>>> negotiation. > > >>>>>> Will modify this. > > >>>>>> > > >>>>>> Thanks a lot! > > >>>>>> > > >>>>>>>> \subsection{Device Operation}\label{sec:Device Types / Network > > >>>>>>>> Device / Device Operation} > > >>>>>>>> Packets are transmitted by placing them in the > > >>>>>>>> @@ -723,7 +779,8 @@ \subsubsection{Processing of Incoming > > >>>>>>>> Packets}\label{sec:Device Types / Network > > >>>>>>>> \field{num_buffers} is one, then the entire packet will be > > >>>>>>>> contained within this buffer, immediately following the struct > > >>>>>>>> virtio_net_hdr. > > >>>>>>>> -\item If the VIRTIO_NET_F_GUEST_CSUM feature was negotiated, the > > >>>>>>>> +\item If the VIRTIO_NET_F_GUEST_CSUM feature (regardless of whether > > >>>>>>>> + VIRTIO_NET_F_GUEST_FULLY_CSUM was negotiated) was negotiated, the > > >>>>>>>> VIRTIO_NET_HDR_F_DATA_VALID bit in \field{flags} can be > > >>>>>>>> set: if so, device has validated the packet checksum. > > >>>>>>>> In case of multiple encapsulated protocols, one level of > > >>>>>>>> checksums > > >>>>>>>> @@ -747,7 +804,8 @@ \subsubsection{Processing of Incoming > > >>>>>>>> Packets}\label{sec:Device Types / Network > > >>>>>>>> number of coalesced TCP segments in \field{csum_start} field > > >>>>>>>> and > > >>>>>>>> number of duplicated ACK segments in \field{csum_offset} field > > >>>>>>>> and sets bit VIRTIO_NET_HDR_F_RSC_INFO in \field{flags}. > > >>>>>>>> -\item If the VIRTIO_NET_F_GUEST_CSUM feature was negotiated, the > > >>>>>>>> +\item If the VIRTIO_NET_F_GUEST_CSUM feature was negotiated but the > > >>>>>>>> + VIRTIO_NET_F_GUEST_FULLY_CSUM feature was not negotiated, the > > >>>>>>>> VIRTIO_NET_HDR_F_NEEDS_CSUM bit in \field{flags} can be > > >>>>>>>> set: if so, the packet checksum at offset \field{csum_offset} > > >>>>>>>> from \field{csum_start} and any preceding checksums > > >>>>>>>> @@ -805,8 +863,9 @@ \subsubsection{Processing of Incoming > > >>>>>>>> Packets}\label{sec:Device Types / Network > > >>>>>>>> device MUST set the VIRTIO_NET_HDR_GSO_ECN bit in > > >>>>>>>> \field{gso_type}. > > >>>>>>>> -If the VIRTIO_NET_F_GUEST_CSUM feature has been negotiated, the > > >>>>>>>> -device MAY set the VIRTIO_NET_HDR_F_NEEDS_CSUM bit in > > >>>>>>>> +If the VIRTIO_NET_F_GUEST_CSUM feature has been negotiated but > > >>>>>>>> +the VIRTIO_NET_F_GUEST_FULLY_CSUM feature has not been negotiated, > > >>>>>>>> +the device MAY set the VIRTIO_NET_HDR_F_NEEDS_CSUM bit in > > >>>>>>>> \field{flags}, if so: > > >>>>>>>> \begin{enumerate} > > >>>>>>>> \item the device MUST validate the packet checksum at > > >>>>>>>> @@ -826,7 +885,8 @@ \subsubsection{Processing of Incoming > > >>>>>>>> Packets}\label{sec:Device Types / Network > > >>>>>>>> been negotiated, the device MUST set \field{gso_type} to > > >>>>>>>> VIRTIO_NET_HDR_GSO_NONE. > > >>>>>>>> -If \field{gso_type} differs from VIRTIO_NET_HDR_GSO_NONE, then > > >>>>>>>> +If the VIRTIO_NET_F_GUEST_FULLY_CSUM feature has not been > > >>>>>>>> negotiated and > > >>>>>>>> +\field{gso_type} differs from VIRTIO_NET_HDR_GSO_NONE, then > > >>>>>>>> the device MUST also set the VIRTIO_NET_HDR_F_NEEDS_CSUM bit in > > >>>>>>>> \field{flags} MUST set \field{gso_size} to indicate the > > >>>>>>>> desired MSS. > > >>>>>>>> If VIRTIO_NET_F_RSC_EXT was negotiated, the device MUST also > > >>>>>>>> @@ -842,7 +902,8 @@ \subsubsection{Processing of Incoming > > >>>>>>>> Packets}\label{sec:Device Types / Network > > >>>>>>>> not less than the length of the headers, including the transport > > >>>>>>>> header. > > >>>>>>>> -If the VIRTIO_NET_F_GUEST_CSUM feature has been negotiated, the > > >>>>>>>> +If the VIRTIO_NET_F_GUEST_CSUM feature (regardless of whether > > >>>>>>>> +VIRTIO_NET_F_GUEST_FULLY_CSUM has been negotiated) has been > > >>>>>>>> negotiated, the > > >>>>>>>> device MAY set the VIRTIO_NET_HDR_F_DATA_VALID bit in > > >>>>>>>> \field{flags}, if so, the device MUST validate the packet > > >>>>>>>> checksum (in case of multiple encapsulated protocols, one level > > >>>>>>>> @@ -1633,6 +1694,7 @@ \subsubsection{Control > > >>>>>>>> Virtqueue}\label{sec:Device Types / Network Device / Devi > > >>>>>>>> #define VIRTIO_NET_F_GUEST_UFO 10 > > >>>>>>>> #define VIRTIO_NET_F_GUEST_USO4 54 > > >>>>>>>> #define VIRTIO_NET_F_GUEST_USO6 55 > > >>>>>>>> +#define VIRTIO_NET_F_GUEST_FULLY_CSUM 64 > > >>>>>>>> #define VIRTIO_NET_CTRL_GUEST_OFFLOADS 5 > > >>>>>>>> #define VIRTIO_NET_CTRL_GUEST_OFFLOADS_SET 0 > > >>>>>>>> diff --git a/device-types/net/device-conformance.tex > > >>>>>>>> b/device-types/net/device-conformance.tex > > >>>>>>>> index 52526e4..43b3921 100644 > > >>>>>>>> --- a/device-types/net/device-conformance.tex > > >>>>>>>> +++ b/device-types/net/device-conformance.tex > > >>>>>>>> @@ -16,4 +16,5 @@ > > >>>>>>>> \item \ref{devicenormative:Device Types / Network Device / > > >>>>>>>> Device Operation / Control Virtqueue / Notifications Coalescing} > > >>>>>>>> \item \ref{devicenormative:Device Types / Network Device / > > >>>>>>>> Device Operation / Control Virtqueue / Inner Header Hash} > > >>>>>>>> \item \ref{devicenormative:Device Types / Network Device / > > >>>>>>>> Device Operation / Control Virtqueue / Device Statistics} > > >>>>>>>> +\item \ref{devicenormative:Device Types / Network Device / > > >>>>>>>> Device Initialization / Device Delivers Fully Checksummed Packets} > > >>>>>>>> \end{itemize} > > >>>>>>>> diff --git a/device-types/net/driver-conformance.tex > > >>>>>>>> b/device-types/net/driver-conformance.tex > > >>>>>>>> index c693c4f..c9b6d1b 100644 > > >>>>>>>> --- a/device-types/net/driver-conformance.tex > > >>>>>>>> +++ b/device-types/net/driver-conformance.tex > > >>>>>>>> @@ -16,4 +16,5 @@ > > >>>>>>>> \item \ref{drivernormative:Device Types / Network Device / > > >>>>>>>> Device Operation / Control Virtqueue / Notifications Coalescing} > > >>>>>>>> \item \ref{drivernormative:Device Types / Network Device / > > >>>>>>>> Device Operation / Control Virtqueue / Inner Header Hash} > > >>>>>>>> \item \ref{drivernormative:Device Types / Network Device / > > >>>>>>>> Device Operation / Control Virtqueue / Device Statistics} > > >>>>>>>> +\item \ref{drivernormative:Device Types / Network Device / > > >>>>>>>> Device Initialization / Device Delivers Fully Checksummed Packets} > > >>>>>>>> \end{itemize} > > >>>>>>>> diff --git a/introduction.tex b/introduction.tex > > >>>>>>>> index cfa6633..fc99597 100644 > > >>>>>>>> --- a/introduction.tex > > >>>>>>>> +++ b/introduction.tex > > >>>>>>>> @@ -145,6 +145,9 @@ \section{Normative > > >>>>>>>> References}\label{sec:Normative References} > > >>>>>>>> Leiba, B., "Ambiguity of Uppercase vs Lowercase in RFC > > >>>>>>>> 2119 Key Words", BCP > > >>>>>>>> 14, RFC 8174, DOI 10.17487/RFC8174, May 2017 > > >>>>>>>> \newline\url{http://www.ietf.org/rfc/rfc8174.txt}\\ > > >>>>>>>> + \phantomsection\label{intro:xdp}\textbf{[XDP]} & > > >>>>>>>> + eXpress Data Path(XDP) provides a high performance, > > >>>>>>>> programmable network data path in the Linux kernel. > > >>>>>>>> + > > >>>>>>>> \newline\url{https://prototype-kernel.readthedocs.io/en/latest/networking/XDP/}\\ > > >>>>>>>> \end{longtable} > > >>>>>>>> \section{Non-Normative References} > > >>>>>>>> -- > > >>>>>>>> 2.19.1.6.gb485710b > > >>>>> This publicly archived list offers a means to provide input to the > > >>>>> OASIS Virtual I/O Device (VIRTIO) TC. > > >>>>> > > >>>>> In order to verify user consent to the Feedback License terms and > > >>>>> to minimize spam in the list archive, subscription is required > > >>>>> before posting. > > >>>>> > > >>>>> Subscribe: virtio-comment-subscribe@lists.oasis-open.org > > >>>>> Unsubscribe: virtio-comment-unsubscribe@lists.oasis-open.org > > >>>>> List help: virtio-comment-help@lists.oasis-open.org > > >>>>> List archive: https://lists.oasis-open.org/archives/virtio-comment/ > > >>>>> Feedback License: > > >>>>> https://www.oasis-open.org/who/ipr/feedback_license.pdf > > >>>>> List Guidelines: > > >>>>> https://www.oasis-open.org/policies-guidelines/mailing-lists > > >>>>> Committee: https://www.oasis-open.org/committees/virtio/ > > >>>>> Join OASIS: https://www.oasis-open.org/join/ > > >>>> > > >>>> This publicly archived list offers a means to provide input to the > > >>>> OASIS Virtual I/O Device (VIRTIO) TC. > > >>>> > > >>>> In order to verify user consent to the Feedback License terms and > > >>>> to minimize spam in the list archive, subscription is required > > >>>> before posting. > > >>>> > > >>>> Subscribe: virtio-comment-subscribe@lists.oasis-open.org > > >>>> Unsubscribe: virtio-comment-unsubscribe@lists.oasis-open.org > > >>>> List help: virtio-comment-help@lists.oasis-open.org > > >>>> List archive: https://lists.oasis-open.org/archives/virtio-comment/ > > >>>> Feedback License: > > >>>> https://www.oasis-open.org/who/ipr/feedback_license.pdf > > >>>> List Guidelines: > > >>>> https://www.oasis-open.org/policies-guidelines/mailing-lists > > >>>> Committee: https://www.oasis-open.org/committees/virtio/ > > >>>> Join OASIS: https://www.oasis-open.org/join/ > > >>> > > >>> This publicly archived list offers a means to provide input to the > > >>> OASIS Virtual I/O Device (VIRTIO) TC. > > >>> > > >>> In order to verify user consent to the Feedback License terms and > > >>> to minimize spam in the list archive, subscription is required > > >>> before posting. > > >>> > > >>> Subscribe: virtio-comment-subscribe@lists.oasis-open.org > > >>> Unsubscribe: virtio-comment-unsubscribe@lists.oasis-open.org > > >>> List help: virtio-comment-help@lists.oasis-open.org > > >>> List archive: https://lists.oasis-open.org/archives/virtio-comment/ > > >>> Feedback License: https://www.oasis-open.org/who/ipr/feedback_license.pdf > > >>> List Guidelines: > > >>> https://www.oasis-open.org/policies-guidelines/mailing-lists > > >>> Committee: https://www.oasis-open.org/committees/virtio/ > > >>> Join OASIS: https://www.oasis-open.org/join/ > > > > > > This publicly archived list offers a means to provide input to the > > > OASIS Virtual I/O Device (VIRTIO) TC. > > > > > > In order to verify user consent to the Feedback License terms and > > > to minimize spam in the list archive, subscription is required > > > before posting. > > > > > > Subscribe: virtio-comment-subscribe@lists.oasis-open.org > > > Unsubscribe: virtio-comment-unsubscribe@lists.oasis-open.org > > > List help: virtio-comment-help@lists.oasis-open.org > > > List archive: https://lists.oasis-open.org/archives/virtio-comment/ > > > Feedback License: https://www.oasis-open.org/who/ipr/feedback_license.pdf > > > List Guidelines: https://www.oasis-open.org/policies-guidelines/mailing-lists > > > Committee: https://www.oasis-open.org/committees/virtio/ > > > Join OASIS: https://www.oasis-open.org/join/ > >
[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]