Flexible command and control in content centric networks
US-2016380945-A1 · Dec 29, 2016 · US
US9774710B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-9774710-B2 |
| Application number | US-201615250602-A |
| Country | US |
| Kind code | B2 |
| Filing date | Aug 29, 2016 |
| Priority date | Aug 4, 2014 |
| Publication date | Sep 26, 2017 |
| Grant date | Sep 26, 2017 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
Official abstract text for this publication.
An embodiment method of network protocol offloading for a packet traveling along a path having a plurality of hops in a virtual network includes checking, for each of the plurality of hops, that a virtual receiver node is safe for network protocol offloading and, when safe, deferring a network protocol processing task, forwarding the packet to a next hop among the plurality of hops, executing the network protocol processing task at a first earliest hop along the path where the virtual receiver node is unsafe for network protocol offloading, and executing the network protocol processing task at a second earliest hop along the path where the virtual receiver node includes a physical network interface that is safe for network protocol offloading.
Opening claim text (preview).
What is claimed is: 1. A method of network protocol offloading for a packet traveling along a path having a plurality of hops in a virtual network, the method comprising: checking, for each of the plurality of hops, that a virtual receiver node is safe for network protocol offloading and determining, for each hop of the plurality of hops that has a virtual receiver node, whether it is safe or unsafe to defer a network protocol processing task at the virtual receiver node; forwarding the packet to a next hop among the plurality of hops; performing the network protocol processing task at a first earliest hop along the path relative to the next hop where the virtual receiver node of the first earliest hop is unsafe for network protocol offloading; and performing the network protocol processing task at a second earliest hop along the path relative to the next hop where the virtual receiver node of the second earliest hop includes a physical network interface that is safe for network protocol offloading. 2. The method of claim 1 wherein executing the network protocol processing task includes processing an internet protocol (IP) stack for the packet. 3. The method of claim 1 wherein the checking includes determining whether respective virtual receiver nodes for the plurality of hops are executing network protocol offloading compatible software. 4. The method of claim 1 wherein the checking includes determining whether respective virtual receiver nodes for the plurality of hops include network protocol offloading compatible hardware. 5. The method of claim 1 wherein all respective virtual receiver nodes for the plurality of hops are safe for network protocol offloading. 6. The method of claim 5 wherein deferring the network protocol processing task comprises omitting the network protocol processing task for the packet. 7. A virtual node in a network, the virtual node comprising: a non-transitory memory storage comprising instructions; and one or more processors in communication with the memory, wherein the one or more processors execute the instructions for: checking, for each of a plurality of hops along a path traveled by a packet through the network, that a virtual receiver node is safe for network protocol offloading and determining, for each hop of the plurality of hops that has a virtual receiver node, whether it is safe or unsafe to defer a network protocol processing task at the virtual receiver node; forwarding the packet to a next hop among the plurality of hops; performing the network protocol processing task at a first earliest hop along the path relative to the next hop where the virtual receiver node of the first earliest hop is unsafe for network protocol offloading; and performing the network protocol processing task at a second earliest hop along the path relative to the next hop where the virtual receiver node of the second earliest hop includes a physical network interface that is safe for network protocol offloading. 8. The virtual node of claim 7 wherein executing the network protocol processing task includes processing an internet protocol (IP) stack for the packet. 9. The virtual node of claim 7 wherein the checking includes determining whether respective virtual receiver nodes for the plurality of hops are executing network protocol offloading compatible software. 10. The virtual node of claim 7 wherein the checking includes determining whether respective virtual receiver nodes for the plurality of hops include network protocol offloading compatible hardware. 11. The virtual node of claim 7 wherein all respective virtual receiver nodes for the plurality of hops are safe for network protocol offloading. 12. The virtual node of claim 11 wherein deferring the network protocol processing task comprises omitting the network protocol processing task for the packet. 13. A computing system for a virtual network, comprising: a physical network interface coupled to a physical network over which packets are transmittable and receivable, and configured to execute network protocol processing tasks for the packets; a non-transitory memory coupled to the physical network interface and configured to store the packets; and a processor coupled to the physical network interface and the non-transitory memory, and having a virtual switch module configured to: check, for each of a plurality of hops along a path traveled by a packet through the virtual network, that a virtual receiver node is safe for network protocol offloading and determining, for each hop of the plurality of hops that has a virtual receiver node, whether it is safe or unsafe to defer a network protocol processing task at the virtual receiver node; forward the packet to a next hop among the plurality of hops; perform the network protocol processing task at a first earliest hop along the path relative to the next hop where the virtual receiver node of the first earliest hop is unsafe for network protocol offloading; and execute the network protocol processing task at a second earliest hop along the path relative to the next hop where the virtual receiver node of the second earliest hop includes a physical network interface that is safe for network protocol offloading. 14. The computing system of claim 13 wherein executing the network protocol processing task includes processing an internet protocol (IP) stack for the packet. 15. The computing system of claim 13 wherein the checking includes determining whether respective virtual receiver nodes for the plurality of hops are executing network protocol offloading compatible software. 16. The computing system of claim 13 wherein the checking includes determining whether respective virtual receiver nodes for the plurality of hops include network protocol offloading compatible hardware. 17. The computing system of claim 13 wherein all respective virtual receiver nodes for the plurality of hops are safe for network protocol offloading. 18. The computing system of claim 17 wherein deferring the network protocol processing task comprises omitting the network protocol processing task for the packet. 19. The computing system of claim 13 wherein the virtual receiver node comprises a virtual network interface card (NIC) having a configuration indicative of the virtual receiver node's compatibility with network protocol offloading. 20. The computing system of claim 13 wherein the processor is configured to execute a plurality of virtual node processes, each having a virtual network interface card (NIC) coupled to the virtual switch module, thereby forming at least a portion of the virtual network.
in which an application is distributed across nodes in the network (software deployment G06F8/60; multiprogramming arrangements G06F9/46) · CPC title
Virtual switches · CPC title
Definitions, standards or architectural aspects of layered protocol stacks · CPC title
Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields · CPC title
Virtual LANs, VLANs, e.g. virtual private networks [VPN] (LAN interconnection over a bridge based backbone H04L12/462; encapsulation techniques H04L12/4633; routing of packets H04L45/00; packet switches H04L49/00; virtual private networks for security H04L63/0272) · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.