From: Heng Qi <hengqi@linux.alibaba.com>
To: "Michael S. Tsirkin" <mst@redhat.com>,
Jason Wang <jasowang@redhat.com>,
"virtio-comment@lists.oasis-open.org"
<virtio-comment@lists.oasis-open.org>
Cc: Yuri Benditovich <yuri.benditovich@daynix.com>,
Xuan Zhuo <xuanzhuo@linux.alibaba.com>,
"virtio-dev@lists.oasis-open.org"
<virtio-dev@lists.oasis-open.org>
Subject: [virtio-dev] Re: [virtio-comment] Re: [PATCH v5] virtio-net: device does not deliver partially checksummed packet and may validate the checksum
Date: Fri, 15 Dec 2023 17:51:26 +0800 [thread overview]
Message-ID: <fafa078b-14f5-460d-b03e-122afb9156ba@linux.alibaba.com> (raw)
In-Reply-To: <b739d275-3664-4509-8a91-f19690719475@linux.alibaba.com>
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.
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/
---------------------------------------------------------------------
To unsubscribe, e-mail: virtio-dev-unsubscribe@lists.oasis-open.org
For additional commands, e-mail: virtio-dev-help@lists.oasis-open.org
next parent reply other threads:[~2023-12-15 9:51 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <959e1a7ccdfffaaadd865a627924cf492ce22bfa.1702277523.git.hengqi@linux.alibaba.com>
[not found] ` <20231211110350-mutt-send-email-mst@kernel.org>
[not found] ` <a8ba676e-de43-45ae-a6a8-a67d0dd41c1f@linux.alibaba.com>
[not found] ` <20231212032713-mutt-send-email-mst@kernel.org>
[not found] ` <bfd25f86-4292-45d2-a7a2-fe61bde0edb4@linux.alibaba.com>
[not found] ` <b739d275-3664-4509-8a91-f19690719475@linux.alibaba.com>
2023-12-15 9:51 ` Heng Qi [this message]
2023-12-18 3:10 ` [virtio-dev] Re: [virtio-comment] Re: [PATCH v5] virtio-net: device does not deliver partially checksummed packet and may validate the checksum Jason Wang
2023-12-18 4:54 ` Heng Qi
2023-12-19 7:53 ` Jason Wang
2023-12-19 16:06 ` Heng Qi
2023-12-20 5:48 ` Jason Wang
2023-12-20 6:30 ` Heng Qi
2023-12-20 6:59 ` Jason Wang
2023-12-20 7:42 ` [virtio-dev] Re: [virtio-comment] " Heng Qi
2023-12-21 1:34 ` Jason Wang
2023-12-21 3:43 ` Heng Qi
2023-12-21 4:04 ` Jason Wang
2023-12-20 9:54 ` Heng Qi
2023-12-20 7:35 ` Michael S. Tsirkin
2023-12-20 9:31 ` [virtio-dev] Re: [virtio-comment] " Heng Qi
2023-12-21 1:41 ` Jason Wang
2023-12-21 1:50 ` Jason Wang
2023-12-21 3:51 ` Heng Qi
2023-12-21 4:04 ` Jason Wang
2023-12-21 1:34 ` Jason Wang
2023-12-21 3:45 ` [virtio-dev] Re: [virtio-comment] " Heng Qi
2023-12-21 3:51 ` Jason Wang
2023-12-19 18:41 ` Michael S. Tsirkin
2023-12-20 5:52 ` Jason Wang
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=fafa078b-14f5-460d-b03e-122afb9156ba@linux.alibaba.com \
--to=hengqi@linux.alibaba.com \
--cc=jasowang@redhat.com \
--cc=mst@redhat.com \
--cc=virtio-comment@lists.oasis-open.org \
--cc=virtio-dev@lists.oasis-open.org \
--cc=xuanzhuo@linux.alibaba.com \
--cc=yuri.benditovich@daynix.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox