Chaining virtual network function services via remote memory sharing

US11178254B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11178254-B2
Application numberUS-201816163961-A
CountryUS
Kind codeB2
Filing dateOct 18, 2018
Priority dateDec 11, 2015
Publication dateNov 16, 2021
Grant dateNov 16, 2021

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

Chaining virtual network functions is provided using a remote direct memory access in software-defined data centers in order to minimize latency. A data packet is processed using a virtual network function of the computer. The data packet is inserted into a shared memory pool for processing via remote direct memory access by a remote computer according to a network function of the remote computer that corresponds to the network function of the computer. The data packet is sent to a target destination device via a network in response to the remote computer marking the data packet as processed in the shared memory pool.

First claim

Opening claim text (preview).

What is claimed is: 1. A computer-implemented method for chaining virtual network functions, the computer-implemented method comprising: processing, by a computer, a data packet received from a source client device using a network function of the computer; inserting, by the computer, the data packet into a shared memory pool for processing via remote direct memory access by a remote computer according to a network function of the remote computer that corresponds to the network function of the computer; sending, by the computer, the data packet to a target destination device via a network in response to the remote computer marking the data packet as processed in the shared memory pool by the remote computer; and establishing, by the computer, a ring buffer in the shared memory pool to share data between the computer and the remote computer via the remote direct memory access, wherein the remote computer polls the ring buffer in the shared memory pool of the computer via the network using the remote direct memory access for the data packet processed by the network function of the computer. 2. The computer-implemented method of claim 1 further comprising: allocating, by the computer, space in memory of the computer for the shared memory pool. 3. The computer-implemented method of claim 1 further comprising: exposing, by the computer, the shared memory pool to the remote direct memory access by the remote computer in order to share processing state and metadata between the network function of the computer and the network function of the remote computer using the shared memory pool. 4. The computer-implemented method of claim 1 , wherein the remote computer utilizes data packet location information included in the shared memory pool to locate the data packet in the ring buffer. 5. The computer-implemented method of claim 1 further comprising: starting, by the computer, a virtual machine corresponding to the network function of the computer; exposing, by the computer, the shared memory pool to the virtual machine corresponding to the network function performed by the computer; and processing, by the computer, the data packet using the virtual machine that corresponds to the network function of the computer. 6. The computer-implemented method of claim 1 further comprising: receiving, by the computer, via the network the data packet corresponding to the network function from the source client device sending the data packet to the target destination device via the network. 7. The computer-implemented method of claim 1 , wherein the computer and the remote computer are coupled together by one of a software-defined cloud or a software-defined network. 8. The computer-implemented method of claim 1 , wherein the network function of the computer is one of a plurality of different network functions performed by the computer. 9. The computer-implemented method of claim 1 , wherein the network function of the computer is a router function that routes the data packet to the target destination device via the network. 10. The computer-implemented method of claim 1 , wherein the network function of the remote computer that corresponds to the network function of the computer is a deep packet inspection function that identifies denial-of-service attacks on the target destination device. 11. A computer system for chaining virtual network functions, the computer system comprising: a bus system; a storage device connected to the bus system, wherein the storage device stores program instructions; and a processor connected to the bus system, wherein the processor executes the program instructions to: process a data packet received from a source client device using a network function of the computer system; insert the data packet into a shared memory pool for processing via remote direct memory access by a remote computer system according to a network function of the remote computer system that corresponds to the network function of the computer system; send the data packet to a target destination device via a network in response to the remote computer system marking the data packet as processed in the shared memory pool by the remote computer; and establish a ring buffer in the shared memory pool to share data between the computer and the remote computer via the remote direct memory access, wherein the remote computer polls the ring buffer in the shared memory pool of the computer via the network using the remote direct memory access for the data packet processed by the network function of the computer. 12. The computer system of claim 11 , wherein the processor further executes the program instructions to: expose the shared memory pool to the remote direct memory access by the remote computer system in order to share processing state and metadata between the network function of the computer and the network function of the remote computer using the shared memory pool. 13. A computer program product for chaining virtual network functions, the computer program product comprising a non-transitory computer readable storage medium having program instructions embodied therewith, the program instructions executable by a computer to cause the computer to perform a method comprising: processing, by the computer, a data packet received from a source client device using a network function of the computer; inserting, by the computer, the data packet into a shared memory pool for processing via remote direct memory access by a remote computer according to a network function of the remote computer that corresponds to the network function of the computer; sending, by the computer, the data packet to a target destination device via a network in response to the remote computer marking the data packet as processed in the shared memory pool by the remote computer; and establishing, by the computer, a ring buffer in the shared memory pool to share data between the computer and the remote computer via the remote direct memory access, wherein the remote computer polls the ring buffer in the shared memory pool of the computer via the network using the remote direct memory access for the data packet processed by the network function of the computer. 14. The computer program product of claim 13 further comprising: allocating, by the computer, space in memory of the computer for the shared memory pool. 15. The computer program product of claim 13 further comprising: exposing, by the computer, the shared memory pool to the remote direct memory access by the remote computer in order to share processing state and metadata between the network function of the computer and the network function of the remote computer using the shared memory pool.

Assignees

Inventors

Classifications

  • Protocols · CPC title

  • for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS] · CPC title

  • in which an application is distributed across nodes in the network (software deployment G06F8/60; multiprogramming arrangements G06F9/46) · CPC title

  • H04L67/42Primary

    Electricity · mapped topic

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US11178254B2 cover?
Chaining virtual network functions is provided using a remote direct memory access in software-defined data centers in order to minimize latency. A data packet is processed using a virtual network function of the computer. The data packet is inserted into a shared memory pool for processing via remote direct memory access by a remote computer according to a network function of the remote comput…
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification H04L67/1097. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Nov 16 2021 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 5 related publications on this page (citations in our corpus or others sharing the same primary CPC).