Packet header field extraction

US12040976B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-12040976-B2
Application numberUS-202217859722-A
CountryUS
Kind codeB2
Filing dateJul 7, 2022
Priority dateAug 26, 2015
Publication dateJul 16, 2024
Grant dateJul 16, 2024

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.

Some embodiments provide a method for processing a packet for a pipeline of a hardware switch. The pipeline, in some embodiments, includes several different stages that match against packet header fields and modify packet header fields. The method receives a packet that includes a set of packet headers. The method then populates, for each packet header in the set of packet headers, (i) a first set of registers with packet header field values of the packet header that are used in the pipeline, and (ii) a second set of registers with packet header field values of the packet header that are not used in the pipeline.

First claim

Opening claim text (preview).

What is claimed is: 1. At least one non-transitory machine readable medium storing program instructions for being executed by at least one machine, the program instructions being for use in association with generation of configuration data for use in programming, at least in part, at least one packet processing pipeline for use in association with a network switch, the network switch comprising hardware, the at least one packet processing pipeline comprising at least one parser stage, at least one match-action stage, and at least one other stage, the network switch, when in operation, being to receive at least one ingress packet, the at least one packet processing pipeline being to process the at least one ingress packet to generate at least one egress packet for being output via the network switch, the program instructions, when executed by the at least one machine, resulting in the at least one machine being configured for performing operations comprising: generating the configuration data based upon compilation of programming language code, the programming language code being user-generated, at least in part, the programming language code describing, at least in part: header field parsing, by the at least one parser stage, of the at least one ingress packet; and header field matching and/or header field modifying, at least in part, by the at least one match-action stage, of the at least one ingress packet; wherein: when the network switch is in the operation, the network switch is to associate respective subsets of header fields of the at least one ingress packet with each other in respective sets of memory locations; the respective sets of memory locations are for use by the at least one match-action stage and the at least one other stage, respectively; the network switch is configurable for use with both ternary content addressable memory (TCAM) and other memory; the TCAM and the other memory are to store match-action table data to be used by the at least one match-action stage in the header field matching and/or header field modifying, at least in part; the match-action table data is configurable, based upon the configuration data, to indicate GRE and/or GENEVE tunneling encapsulation-related operations; and the at least one other stage is to generate, at least in part, the at least one egress packet based upon (1) at least one unmodified header field of the at least one ingress packet as parsed by the at least one parser stage and (2) at least one other header field generated, at least in part, by the at least one match-action stage as a result of the header field modifying. 2. The at least one non-transitory machine readable medium of claim 1 , wherein: the operations further comprise compiling the programming language code to produce the compilation; the at least one other stage is to generate, at least in part, the at least one egress packet; and the at least one match-action stage comprises a plurality of match-action stages. 3. The at least one non-transitory machine readable medium of claim 2 , wherein: a chip comprises the network switch; and the configuration data defines, at least in part, the match-action table data. 4. The at least one non-transitory machine readable medium of claim 3 , wherein: the at least one ingress packet comprises packet headers; and the programming language code describes, at least in part, at least one parse graph that indicates, at least in part, manner in which the at least one parser stage is (1) to parse, at least in part, the packet headers and (2) to identify from the packet headers the respective subsets of header fields. 5. A method implemented, at least in part, using program instructions for being executed by at least one machine, the program instructions being for use in association with generation of configuration data for use in programming, at least in part, at least one packet processing pipeline for use in association with a network switch, the network switch comprising hardware, the at least one packet processing pipeline comprising at least one parser stage, at least one match-action stage, and at least one other stage, the network switch, when in operation, being to receive at least one ingress packet, the at least one packet processing pipeline being to process the at least one ingress packet to generate at least one egress packet for being output via the network switch, the method comprising: executing, by the at least one machine, the program instructions, the program instructions, when executed by the at least one machine, permitting generation of the configuration data based upon compilation of programming language code, the programming language code being user-generated, at least in part, the programming language code describing, at least in part: header field parsing, by the at least one parser stage, of the at least one ingress packet; and header field matching and/or header field modifying, at least in part, by the at least one match-action stage, of the at least one ingress packet; wherein: when the network switch is in the operation, the network switch is to associate respective subsets of header fields of the at least one ingress packet with each other in respective sets of memory locations; the respective sets of memory locations are for use by the at least one match-action stage and the at least one other stage, respectively; the network switch is configurable for use with both ternary content addressable memory (TCAM) and other memory; the TCAM and the other memory are to store match-action table data to be used by the at least one match-action stage in the header field matching and/or header field modifying, at least in part; the match-action table data is configurable, based upon the configuration data, to indicate GRE and/or GENEVE tunneling encapsulation-related operations; and the at least one other stage is to generate, at least in part, the at least one egress packet based upon (1) at least one unmodified header field of the at least one ingress packet as parsed by the at least one parser stage and (2) at least one other header field generated, at least in part, by the at least one match-action stage as a result of the header field modifying. 6. The method of claim 5 , wherein: the method further comprises compiling the programming language code to produce the compilation; the at least one other stage is to generate, at least in part, the at least one egress packet; and the at least one match-action stage comprises a plurality of match-action stages. 7. The method of claim 6 , wherein: a chip comprises the network switch; and the configuration data defines, at least in part, the match-action table data. 8. The method of claim 7 , wherein: the at least one ingress packet comprises packet headers; and the programming language code describes, at least in part, at least one parse graph that indicates, at least in part, manner in which the at least one parser stage is (1) to parse, at least in part, the packet headers and (2) to identify from the packet headers the respective subsets of header fields. 9. At least one packet processing pipeline for use in association with a network switch, the network switch comprising hardware, the network switch, when in operation, being to receive at least one ingress packet, the at least one packet processing pipeline comprising: at least one parser stage; at least one match-action stage; and at least one other stage; wherein: the at least one packet processing pipeline is programmable, at least in part, via configuration data; the at least one packet processing pipeline is to process the at least one ingress packet to generate at least one egress packet for being outpu

Assignees

Inventors

Classifications

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 US12040976B2 cover?
Some embodiments provide a method for processing a packet for a pipeline of a hardware switch. The pipeline, in some embodiments, includes several different stages that match against packet header fields and modify packet header fields. The method receives a packet that includes a set of packet headers. The method then populates, for each packet header in the set of packet headers, (i) a first …
Who is the assignee on this patent?
Barefoot Networks Inc
What technology area does this patent fall under?
Primary CPC classification H04L45/64. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Jul 16 2024 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 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).