Flow distribution algorithm for aggregated links in an ethernet switch

US9438447B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9438447-B2
Application numberUS-201213718479-A
CountryUS
Kind codeB2
Filing dateDec 18, 2012
Priority dateDec 18, 2012
Publication dateSep 6, 2016
Grant dateSep 6, 2016

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.

Link aggregation is a practice that uses multiple Ethernet links between two end points in order to obtain higher bandwidth and resiliency than possible with a single link. A flow distribution technique is provided to distribute traffic between the two end points equally across all links in the group and achieve greater efficiency. The flow distribution technique generates and sub-divides a hash value based on received packet flow. The divided portions of the hash value are used in a hierarchical fashion to select a link to use for this packet.

First claim

Opening claim text (preview).

What is claimed is: 1. A computer-readable storage medium having computer-readable program code embodied therewith, the computer-readable program code comprising: computer-readable program code configured to generate a hash value based on routing information of a data frame; computer-readable program code configured to split the hash value into a plurality of chunks, wherein values of the plurality of chunks correspond to a plurality of links associated with a link aggregation group; computer-readable program code configured to modify each of the plurality of chunks based on a number of the plurality of links; computer-readable program code configured to determine a selected link having an up state from the plurality of links based on a hierarchical order of the plurality of chunks; and computer-readable program code configured to forward the data frame to the selected link. 2. The computer-readable storage medium of claim 1 , wherein the computer-readable program code configured to modify a chunk further comprises computer-readable program code configured to reduce a most significant bit of the chunk based on the number of the plurality of links. 3. The computer-readable storage medium of claim 1 , wherein the computer-readable program code configured to determine the selected link having an up state based on the hierarchical order of the plurality of chunks further comprises: computer-readable program code configured to, responsive to determining a first chunk of the plurality of chunks is within range of a number of the plurality of links and the first chunk corresponds to a first link having an up state, select the first link. 4. The computer-readable storage medium of claim 3 , further comprising: computer-readable program code configured to, responsive to determining the first chunk of the plurality of chunks is not within range of a number of the plurality of links or the first chunk does not correspond to a link having an up state, determine a second chunk of the plurality of chunks is within range of the number of the plurality of links and the second chunk corresponds to a second link having an up state; and computer-readable program code configured to select the second link. 5. The computer-readable storage medium of claim 3 , further comprising: computer-readable program code configured to determine the first chunk of the plurality of chunks is not within range of a number of the plurality of links or the first chunk does not correspond to a link having an up state; computer-readable program code configured to modify a second chunk of the plurality of chunks to be within range of the number of the plurality of links; and computer-readable program code configured to, responsive to determining the second chunk corresponds to a second link having an up state, select the second link. 6. The computer-readable storage medium of claim 1 , wherein the computer-readable program code configured to determine the selected link having an up state based on the hierarchical order of the plurality of chunks further comprises: computer-readable program code configured to, responsive to determining none of the plurality of chunks are within range of a number of the plurality of links and are corresponding to a link having an up state, select a first available link relative to a down link corresponding to a first chunk of the plurality of chunks. 7. The computer-readable storage medium of claim 6 , wherein the computer-readable program code configured to select the first available link further comprises: computer-readable program code configured to generate a rotated link state pattern based on link state information of the plurality of links and based on the first chunk; and computer-readable program code configured to select the first available link based on the generated rotated link state pattern. 8. A system for forwarding a data frame through a distributed network switch, comprising: one or more computer processors; and a memory containing a program which, when executed by the one or more computer processors, is configured to perform an operation comprising: generating, by operation of the one or more computer processors, a hash value based on routing information of a data frame; splitting the hash value into a plurality of chunks, wherein values of the plurality of chunks correspond to a plurality of links associated with a link aggregation group; modifying each of the plurality of chunks based on a number of the plurality of links; determining a selected link having an up state from the plurality of links based on a hierarchical order of the plurality of chunks; and forwarding the data frame to the selected link. 9. The system of claim 8 , wherein the modifying a chunk further comprises reducing a most significant bit of the chunk based on the number of the plurality of links. 10. The system of claim 8 , wherein the determining the selected link having an up state based on the hierarchical order of the plurality of chunks further comprises: responsive to determining a first chunk of the plurality of chunks is within range of a number of the plurality of links and the first chunk corresponds to a first link having an up state, selecting the first link. 11. The system of claim 10 , wherein the operation further comprises: responsive to determining the first chunk of the plurality of chunks is not within range of a number of the plurality of links or the first chunk does not correspond to a link having an up state, determining a second chunk of the plurality of chunks is within range of the number of the plurality of links and the second chunk corresponds to a second link having an up state; and selecting the second link. 12. The system of claim 10 , wherein the operation further comprises: determining the first chunk of the plurality of chunks is not within range of a number of the plurality of links or the first chunk does not correspond to a link having an up state; modifying a second chunk of the plurality of chunks to be within range of the number of the plurality of links; and responsive to determining the second chunk corresponds to a second link having an up state, selecting the second link. 13. The system of claim 8 , wherein the determining the selected link having an up state based on the hierarchical order of the plurality of chunks further comprises: responsive to determining none of the plurality of chunks are within range of a number of the plurality of links and are corresponding to a link having an up state, selecting a first available link relative to a down link corresponding to a first chunk of the plurality of chunks. 14. The system of claim 13 , wherein the selecting the first available link further comprises: generating a rotated link state pattern based on link state information of the plurality of links and based on the first chunk; and selecting the first available link based on the generated rotated link state pattern.

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 US9438447B2 cover?
Link aggregation is a practice that uses multiple Ethernet links between two end points in order to obtain higher bandwidth and resiliency than possible with a single link. A flow distribution technique is provided to distribute traffic between the two end points equally across all links in the group and achieve greater efficiency. The flow distribution technique generates and sub-divides a has…
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification H04L45/7453. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue Sep 06 2016 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 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).