Method and apparatus for a packet classifier
First Claim
1. A method for efficiently classifying packets for a multi-processor/mutli-thread environment, comprising:
- receiving a packet;
extracting header information from the received packet;
calculating a first hash value;
determining a field of interest in a lookup table from the first hash value;
calculating a second hash value;
comparing the second hash value to stored hash values in the field of interest of the lookup table to determine a match between the second hash value and one of the values in the field of interest of the lookup table; and
if there is a match, transmitting the received packet to a processor corresponding to the one of the values in the row location of the lookup table.
3 Assignments
0 Petitions
Accused Products
Abstract
In one embodiment, a method for efficiently classifying packets for a multi-processor/mutli-thread environment is provided. The method initiates with receiving a packet. Then, header information is extracted form the received packet. Next, a first hash value is calculated. Then, a field of interest in a lookup table is determined from the first hash value. Next, a second hash value is calculated. Then, the second hash value is compared to stored hash values in the field of interest of the lookup table to determine a match between the second hash value and one of the values in the field of interest of the lookup table. If there is a match, the received packet is transmitted to a processor corresponding to the one of the values in the row location of the lookup table. A network interface card and a system for efficiently classifying packets in a multicore/multithread environment are also provided.
-
Citations
20 Claims
-
1. A method for efficiently classifying packets for a multi-processor/mutli-thread environment, comprising:
-
receiving a packet;
extracting header information from the received packet;
calculating a first hash value;
determining a field of interest in a lookup table from the first hash value;
calculating a second hash value;
comparing the second hash value to stored hash values in the field of interest of the lookup table to determine a match between the second hash value and one of the values in the field of interest of the lookup table; and
if there is a match, transmitting the received packet to a processor corresponding to the one of the values in the row location of the lookup table. - View Dependent Claims (2, 3, 4, 5, 6, 7)
-
-
8. A method for performing optimistic hash matching, comprising:
-
defining a lookup table having a plurality of values stored therein, each of the plurality of values being associated with at least one processor;
receiving a packet;
extracting a key from the packet;
calculating a first hash value and a second hash value from the key;
identifying a field of interest within the lookup table corresponding to the first hash value;
comparing the second hash value to values within the field of interest to identify a match between the second hash value and one of the values within the field of interest; and
sending the received packet to a processor corresponding to the one of the values within the field of interest. - View Dependent Claims (9, 10, 11, 12, 13)
-
-
14. A network interface card, comprising:
-
circuitry for receiving a packet;
packet classifier circuitry, the packet classifier circuitry configured to calculate a first hash value and a second hash value from fields of a packet header of the received packet, the first hash value indicating a field of interest associated with a lookup table in communication with the network interface card, the second hash value matching a value within the field of interest to identify a processor assigned to the packet; and
circuitry for transmitting the packet to a queue associated with the processor assigned to the packet. - View Dependent Claims (15, 16)
-
-
17. A system for efficiently classifying packets in a multicore/multithread environment, comprising:
a multi-processor chip in communication with the semiconductor chip capable of storing data, the multi-processor chip including, a plurality of processor cores;
a network interface card (NIC) for receiving a packet from a network;
the NIC having packet classifier circuitry, the packet classifier circuitry configured to calculate a first hash value and a second hash value from a packet header of the packet, the first hash value indicating a field of interest in a table, the second hash value identifying data at a location in the field of interest, the data indicating one of the plurality of processor cores for the packet to be sent to; and
a semiconductor chip configured to store data associated with the table, the semiconductor chip in communication with the multi-processor chip. - View Dependent Claims (18, 19, 20)
Specification