Embodiments described herein relate generally to a cell-based switch fabric, and, in particular, to transmission of groups of cells via a switch fabric.
Transmission of cells via a switch fabric (e.g., a multi-stage switch fabric) can be, for example, disrupted because of congestion at one or more queues (e.g., an ingress queue, an egress queue) configured to receive the data. In some instances, the disruptions can decrease data transfer rates within the switch fabric and/or can result in the loss of one or more cells due to buffer overflow. These problems can be exacerbated when cells are transmitted via the switch fabric on a cell-by-cell basis based on known switch fabric scheduling strategies and/or when the switch fabric is scaled.
Thus, a need exists for methods and apparatus for transmission of groups of cells via a switch fabric.
In one embodiment, a method can include receiving at an egress schedule module a request to schedule transmission of a group of cells from an ingress queue through a switch fabric of a multi-stage switch. The ingress queue can be associated with an ingress stage of the multi-stage switch. The egress schedule module can be associated with an egress stage of the multi-stage switch. The method can also include determining, in response to the request, that an egress port at the egress stage of the multi-stage switch is available to transmit the group of cells from the multi-stage switch.
Flow of cells (e.g., cells that include one or more portions of one or more data packets such as internet protocol (IP) packets) via a switch fabric can be controlled based on signals transmitted between an ingress schedule module and an egress schedule module. Specifically, the ingress schedule module and the egress schedule module can be configured to coordinate the transmission of groups of cells to one or more egress ports via the switch fabric. For example, the ingress schedule module can be configured to define a group of cells queued at an ingress queue. The ingress schedule module can be configured to send to the egress schedule module a request to schedule transmission of the group of cells to an egress port via the switch fabric. The request can be referred to as a transmission request. If the egress schedule module determines that the egress port is available to receive the group of cells, the egress schedule module can be configured to schedule the transmission of the group of cells via the switch fabric, and the ingress schedule module can be configured to trigger transmission of the group of cells to the egress port via the switch fabric. If the egress schedule module determines that the destination port is unavailable to receive the group of cells, the egress schedule module can be configured to deny the transmission request.
Because the egress schedule module can be configured to authorize (or deny) transmission requests from the ingress schedule module on a group-by-group basis, groups of cells can be transmitted out of the switch fabric (after traversing the switch fabric) with relatively little or no buffering at the egress ports. In some embodiments, the ingress schedule module can be on an ingress side of the switch fabric, included in an ingress line card, and/or can be associated with an ingress stage of the switch fabric. In some embodiments, the egress schedule module can be on an egress side of the switch fabric, included in an egress line card, and/or can be associated with an egress stage of the switch fabric. In some embodiments, the switch fabric can be included in a multi-stage switch or can define at least a core portion of a data center. In some embodiments, the data included within a cell can be referred to as content of the cell.
As shown in
In some embodiments, the ingress queues 110 can be included in one or more ingress line cards (not shown) disposed outside of the ingress stage 102 of the switch fabric 100. In some embodiments, the egress ports 140 can be included in one or more egress line cards (not shown) disposed outside of the egress stage 106 of the switch fabric 100. In some embodiments, one or more of the ingress queues 110 and/or one or more of the egress ports 140 can be included in a one or more stages (e.g., ingress stage 102) of the switch fabric 100. In some embodiments, the egress schedule module 120 can be included in one or more egress line cards and/or the ingress schedule module 130 can be included in one or more ingress line cards. In some embodiments, each line card (e.g., egress line card, ingress line card) associated with the multi-stage switch 190 can include one or more schedule modules (e.g., egress schedule module, ingress schedule module).
In some embodiments, the ingress queues 110 and/or the egress ports 140 can be included in one or more gateway devices (not shown) disposed between the switch fabric 100 and/or other devices (not shown). The gateway device(s), the switch fabric 100 and/or the other devices can collectively define at least a portion of a data center (not shown). In some embodiments, the switch fabric 100 and the other devices can be configured to handle data based on different protocols. For example, the other devices can include, for example, one or more host devices (e.g., host devices configured to execute one or more virtual resources, a web server) that can be configured to communicate based on an Ethernet protocol and the switch fabric 100, which can be a cell-based fabric. In other words, the gateway device(s) can provide the other devices configured to communicate via one protocol with access to the switch fabric 100, which can be configured to communicate via another protocol. In some embodiments, the gateway device(s) can be referred to as an access switch or as a network device. In some embodiments, the gateway device(s) can be configured to function as a router, a network hub device, and/or a network bridge device.
In this embodiment, for example, the ingress schedule module 130 can be configured to define a group of cells A queued at ingress queue Q1 and a group of cells C queued at ingress queue QK-1. The group of cells A is queued at a front portion of the ingress queue Q1 and a group of cells B is queued within the ingress queue Q1 behind the group of cells A. Because ingress queue Q1 is a FIFO type queue, the group of cells B cannot be transmitted via the switch fabric 100 until the group of cells A have been transmitted from the ingress queue Q1. The group of cells C is queued at a front portion of the ingress queue QK-1.
In some embodiments, a portion of the ingress queues 110 can be mapped to (e.g., assigned to) one or more of the egress ports 140. For example, ingress ports Q1 through QK-1 can be mapped to egress port P1 so that all of the queued cells 310 ingress ports Q1 through QK-1 will be scheduled by the ingress schedule module 120 for transmission via the switch fabric 100 to egress port P1. Similarly, ingress port QK can be mapped to egress port P2. The mapping can be stored at a memory (e.g., memory 122) as, for example, a look-up table that can be accessed by ingress schedule module 120 when scheduling (e.g., requesting) transmission of groups of cells.
In some embodiments, one or more of the ingress queues 110 can be associated with a priority value (also can be referred to a transmission priority value). The ingress schedule module 120 can be configured to schedule transmission of cells from the ingress queues 110 based on the priority values. For example, ingress schedule module 120 can be configured to request transmission of group of cells C to egress port P1 before requesting transmission of group of cells A to egress port P1 because ingress queue QK-1 can be associated with a higher priority value than ingress port Q1. The priority values can be defined based on a level of service (e.g., a quality of service (QoS)). For example, in some embodiments, different types of network traffic can be associated with a different level of service (and, thus a different priority). For example, storage traffic (e.g., read and write traffic), inter-processor communication, media signaling, session layer signaling, and so forth each can be associated with at least one level of service. In some embodiments, the priority values can be based on, for example, the Institute of Electrical and Electronics Engineers (IEEE) 802.1qbb protocol, which defines a priority-based flow control strategy.
In some embodiments, one or more of the ingress queues 110 and/or one or more of the egress ports 140 can be paused. In some embodiments, one or more of the ingress queues 110 and/or one or more of the egress ports 140 can be paused so that cells are not dropped. For example, if egress port P1 is temporarily unavailable, transmission of cells from ingress Q1 and/or ingress queue QK-1 can be paused so that cells won't be dropped at egress port P1 because egress port P1 is temporarily unavailable. In some embodiments, one or more of the ingress queues 110 can be associated with a priority value. For example, if egress port P1 is congested, transmission of cells from ingress Q1 to egress port P1 can be paused rather than transmission of cells ingress queue QK-1 to egress port P1 because ingress port QK-1 can be associated with a higher priority value than ingress port Q1.
The ingress schedule module 120 can be configured to exchange signals with (e.g., transmit signals to and receive signals from) the egress schedule module 130 to coordinate the transmission of the group of cells A via the switch fabric 100 to egress port P1, and to coordinate the transmission of group of cells C via the switch fabric 100 to egress port P1. Because the group of cells A is to be transmitted to egress port P1, the egress port P1 can be referred to as a destination port of the group of cells A. Similarly, egress port P1 can be referred to as a destination port of the group of cells B. As shown in
The group of cells A and the group of cells B are defined by the ingress schedule module 120 based on cells 10 that are queued at ingress queue Q1. Specifically, the group of cells A can be defined based on each cell from the group of cells A having a common destination port and having a specified position within the ingress queue Q1. Similarly, the group of cells C can be defined based on each cell from the group of cells C having a common destination port and having a specified position within the ingress queue QK-1. Although not shown, in some embodiments, for example, the cells 10 can include content (e.g., data packets) received at the multi-stage switch 190 from one or more network entities (e.g., a personal computer, a server, a router, a personal digital assistant (PDA)) via one or more networks (e.g., a local area network (LAN), a wide area network (WAN), a virtual network) that can be wired and/or wireless. More details related to defining of groups of cells, such as group of cells A, the group of cells B, and/or the group of cells C, are discussed in connection with
In some embodiments, the transmission request 22 can be queued on an ingress side of the switch fabric 100 before being sent to the egress side of the switch fabric 100. In some embodiments, the transmission request 22 can be queued until the ingress schedule module 120 triggers sending of the transmission request 22 to the egress side of the switch fabric 100. In some embodiments, the ingress schedule module 120 can be configured to hold (or trigger holding of) the transmission request 22 in, for example, an ingress transmission request queue (not shown) because a volume of transmission requests for sending from the ingress side of the switch fabric 100 is higher than a threshold value. The threshold value can be defined based on latency of transmission via the switch fabric 100.
In some embodiments, the transmission request 22 can be queued at an egress queue (not shown) on an egress side of the switch fabric 100. In some embodiments, the egress queue can be included in a line card (not shown), can be disposed within or outside of the switch fabric 100, or can be disposed outside of the multi-stage switch 190. Although not shown, in some embodiments, the transmission request 22 can be queued in an egress queue or a portion of an egress queue associated with a specific ingress queue (e.g., ingress queue Q1). In some embodiments, each of the egress ports 140 can be associated with egress queues that are associated with (e.g., correspond with) priority values of the ingress queues 110. For example, egress port P1 can be associated with an egress queue (or portion of an egress queue) associated with ingress queue Q1 (which can have a specified priority value) and an egress queue (or portion of an egress queue) associated with ingress queue QK (which can have a specified priority value). Accordingly, a transmission request 22, which is queued at ingress queue Q1, can be queued at the egress queue associated with ingress queue Q1. In other words, the transmission request 22 can be queued in an egress queue (on an egress side of the switch fabric 100) associated with a priority value of at least one of the ingress queues 110. Similarly, the transmission request 22 can be queued in an ingress transmission request queue (not shown) or portion of an ingress transmission queue associated with a priority value of the at least one of the ingress queues 110.
If the egress schedule module 130 determines that the destination port of the group of cells A (i.e., egress port P1 shown in
In response to the transmission response 24, the ingress schedule module 120 can be configured to transmit the group of cells A from the ingress side of the switch fabric 100 to the egress side of the switch fabric 100 via the switch fabric 100. In some embodiments, the transmission response 24 can include an instruction to transmit the group of cells A via a particular transmission path (such as transmission path 12 shown in
As shown in
The cell quantity value 30 and the destination identifier 32 can be used by the egress schedule module 130 to schedule the group of cells A for transmission via the switch fabric 100 to egress port P1 (shown in
In some embodiments, if the number of cells included in the group of cells A cannot be handled (e.g., cannot be received) at the destination port of the group of cells A (e.g., egress port P1 shown in
In some embodiments, the availability or unavailability of, for example, egress port P1 (shown in
As shown in
In some embodiments, the queue sequence value 36 can be selected from a range of queue sequence values associated with ingress queue Q1 (shown in
In some embodiments, the range of queue sequence values associated with the ingress queue Q1 can overlap with a range of queue sequence values associated with another of the ingress queues 110 (shown in
In some embodiments, the ingress schedule module 120 can be configured to wait to define a transmission request (not shown) associated with group of cells B. For example, the ingress schedule module 120 can be configured to wait until transmission request 22 is sent or wait until a response (e.g., the transmission response 24, a transmission denial) is received in response to transmission request 22 before defining a transmission request associated with group of cells B.
As shown in
In some embodiments, the egress schedule module 130 can be configured to delay sending the transmission response 24 in response to the transmission request 22. In some embodiments, the egress schedule module 130 can be configured to delay responding if, for example, the destination port of the group of cells A (i.e., egress port P1 shown in
In some embodiments, the egress schedule module 130 can be configured to delay sending the transmission response 24 because the destination port of the group of cells A (i.e., egress port P1 shown in
In some embodiments, the egress schedule module 130 can be configured to delay sending the transmission response 24 because at least a portion of a transmission path (such as transmission path 12 shown in
As shown in
Referring back to
In some embodiments, the group of cells A can be retrieved and transmitted to egress port P1 with a response identifier included with the group of cells A by the ingress schedule module 120 when the group of cells A is transmitted to the egress side of the switch fabric 100. The response identifier can be defined at the egress schedule module 130 and included in the transmission response 24. In some embodiments, if the group of cells A is queued at an egress queue (not shown) associated the destination port of the group of cells A, the response identifier can be used to retrieve the group of cells A from the destination port of the group of cells A so that the group of cells A can be transmitted from the switch fabric 100 via the destination port of the group of cells A. The response identifier can be associated with a location in the egress queue that has been reserved by the egress schedule module 130 for queuing of the group of cells A.
In some embodiments, a group of cells queued at the ingress queues 110 can be moved to the memory 122 when a transmission request (such as transmission request 22 shown in
In some embodiments, the ingress schedule module 120 can be configured to retrieve a group of cells stored in the memory 122 based on a queue identifier and/or a queue sequence value associated with the group of cells. In some embodiments, the location of the group of cells within the memory 122 can be determined based on a look-up table and/or an index value. The group of cells can be retrieved before the group of cells is transmitted from the ingress side of the switch fabric 100 to the egress side of the switch fabric 100. For example, the group of cells D can be associated with a queue identifier and/or a queue sequence value. A location within the memory 122 where the group of cells D is stored can be associated with the queue identifier and/or the queue sequence value. A transmission request defined by the ingress schedule module 120 and sent to the egress schedule module 130 can include the queue identifier and/or the queue sequence value. A transmission response received from the egress schedule module 130 can include the queue identifier and/or the queue sequence value. In response to the transmission response, the ingress schedule module 120 can be configured to retrieve the group of cells D from the memory 122 at the location based on the queue identifier and/or the queue sequence value, and the ingress schedule module 120 can trigger transmission of the group of cells D.
In some embodiments, a number of cells included in a group of cells can be defined based on an amount of space available in the memory 122. For example, the ingress schedule module 120 can be configured to define the number of cells included in the group of cells D based on an amount of available storage space included in the memory 122 at the time that the group of cells D is being defined. In some embodiments, the number of cells included in the group of cells D can be increased if the amount of available storage space included in the memory 122 increased. In some embodiments, the number of cells included in the group of cells D can be increased by the ingress schedule module 120 before and/or after the group of cells D is moved to the memory 122 for storage.
In some embodiments, a number of cells included in a group of cells can be defined based on a latency of transmission across, for example, the switch fabric 100. Specifically, the ingress schedule module 120 can be configured to define the size of a group of cells to facilitate flow across the switch fabric 100 in view of latencies associated with the switch fabric 100. For example, the ingress schedule module 120 can be configured to close a group of cells (e.g., define a size of the group of cells) because the group of cells has reached a threshold size defined based on the latency of the switch fabric 100. In some embodiments, the ingress schedule module 120 can be configured to immediately send a data packet in a group of cells, rather than wait for additional data packets to define a larger group of cells, because the latency across the switch fabric 100 is low.
In some embodiments, the ingress schedule module 120 can be configured to limit the number of transmission requests sent from the ingress side of the switch fabric 100 to the egress side of the switch fabric 100. In some embodiments, the limit can be defined based on a policy stored at the ingress schedule module 120. In some embodiments, a limit can be defined based on a priority value associated with one or more of the ingress queues 110. For example, ingress schedule module 120 can be configured to permit (based on a threshold limit) more transmission requests associated with ingress queue Q1 than from ingress queue QK because ingress queue Q1 has a higher priority value than ingress queue QK.
In some embodiments, one or more portions of the ingress schedule module 120 and/or the egress schedule module 130 can be a hardware-based module (e.g., a digital signal processor (DSP), a field programmable gate array (FPGA)) and/or a software-based module (e.g., a module of computer code, a set of processor-readable instructions that can be executed at a processor). In some embodiments, one or more of the functions associated with the ingress schedule module 120 and/or the egress schedule module 130 can be included in different modules and/or combined into one or more modules. For example, the group of cells A can be defined by a first sub-module within the ingress schedule module 120 and the transmission request 22 (shown in
In some embodiments, the switch fabric 100 can have more or less stages than are shown in
As shown in
Each cell from the queued cells 210 has content queued for transmission to one of four egress ports 270—egress port E, egress port F, egress port G, or egress port H—as indicated by the egress port label (e.g., letter “E”, letter “F”) on each cell from the queued cells 210. The egress port 270 to which a cell is to be transmitted can be referred to as a destination port. The queued cells 210 can each be transmitted to their respective destination port via the switch fabric 200. In some embodiments, the ingress schedule module 240 can be configured to determine the destination port for each cell from the queued cells 210 based on, for example, a look-up table (LUT) such as a routing table. In some embodiments, the destination port of each cell from the queued cells 210 can be determined based on a destination of content (e.g., data) included in the cell. In some embodiments, one or more of the egress ports 270 can be associated with an egress queue where cells can be queued until transmitted via the egress ports 270.
The first group of cells 212 and the second group of cells 216 can be defined by the ingress schedule module 240 based on the destination ports of the queued cells 210. As shown in
The groups of cells (e.g., the first group of cells 212) are defined based on destination port because the groups of cells are transmitted via the switch fabric 200 as a group. For example, if cell1 were included in the first group of cells 212, the first group of cells 212 could not be delivered to a single destination port because cell1 has a different destination port (egress port “F”) than cell2 through cell7 (egress port “E”). Thus, the first group of cells 212 could not be delivered via the switch fabric 200 as a group.
The groups of cells are defined as continuous blocks of cells because the groups of cells are transmitted via the switch fabric 200 as a group and because the ingress queue 220 is a FIFO type queue. For example, cell12, and cell2 through cell7 could not be defined as a group of cells because cell12 cannot be transmitted with the block of cells cell2 through cell7. Cell8 through cell11 are intervening cells that must be transmitted from ingress queue 220 after cell2 through cell7 are transmitted from ingress queue 220, but before cell12 is transmitted from ingress queue 220. In some embodiments, if the ingress queue 220 were not a FIFO type queue, one or more of the queued cells 210 could be transmitted out of order and groups could span intervening cells.
Although not shown, each cell from the queues cells 210 can have a sequence value that can be referred to as a cell sequence value. The cell sequence value can represent an order of, for example, cell2 with respect to cell3. The cell sequence value can be used to re-order the cells at, for example, one or more of the egress ports 270 before the content associated with the cells is transmitted from the egress ports 270. For example, in some embodiments, group of cells 212 can be received at an egress queue (not shown) associated with egress port E and re-ordered based on cell sequence values. In some embodiments, the egress queue can be relatively small (e.g., a shallow egress queue) compared with the ingress queue 220.
In addition, data (e.g., data packets) that is included within the cells can also have a sequence value that can be referred to as a data sequence value. For example, the data sequence value can represent a relative ordering of, for example, a first data packet with respect to a second data packet. The data sequence values can be used to re-order the data packets at, for example, one or more of the egress ports 270 before the data packets are transmitted from the egress ports 270.
As shown in
Each cell from the queued cells 310 has content associated with one or more data packets (e.g., Ethernet data packets). The data packets are represented by the letters “Q” through “Y.” For example, as shown in
The groups of cells (e.g., the first group of cells 312) are defined so that portions of data packets are not associated with different groups of cells. Said differently, the groups of cells are defined so that entire data packets are associated with a single group of cells. The boundaries of the groups of cells are defined based on boundaries of the data packets queued at ingress queue 320 so that the data packets are not included in different groups of cells. Dividing data packets into different groups of cells could result in undesirable consequences such as buffering at the egress side of the switch fabric 300. For example, if a first portion of data packet T (e.g., cell6) was included in the first group of cells 312 and second portion of data packet T (e.g., cell7) was included in the second group of cells 316, the first portion of data packet T would have to be buffered in at least a portion of one or more egress queues (not shown) at the egress side of the switch fabric 300 until the second portion of the data packet T were transmitted to the egress side of the switch fabric 300 so that the entire data packet T could be transmitted from the switch fabric 300 via egress port E2.
In some embodiments, the data packets that are included within the queued cells 310 can also have a sequence value that can be referred to as a data sequence value. The data sequence value can represent a relative ordering of, for example, data packet R with respect to a data packet S. The data sequence values can be used to re-order the data packets at, for example, one or more of the egress ports 370 before the data packets are transmitted from the egress ports 370.
A group of cells that have a common destination are defined from the cells queued at the ingress queue, at 410. The destination of each cell from the group of cells can be determined based on a look-up table. In some embodiments, the destination can be determined based on a policy and/or based on a packet classification algorithm. In some embodiments, the common destination can be a common destination port associated with an ingress portion of the switch fabric.
A request tag is associated with the group of cells, at 420. The request tag can include, for example, one or more of a cell quantity value, a destination identifier, a queue identifier, a queue sequence value, and so forth. The request tag can be associated with the group of cells before the group of cells is transmitted to an ingress side of the switch fabric.
A transmission request that includes the request tag is sent to an egress schedule module, at 430. In some embodiments, the transmission request can include a request to be transmitted at a particular time or via a particular transmission path. In some embodiments, the transmission request can be sent after the group of cells has been stored in a memory associated with an ingress stage of the switch fabric. In some embodiments, the group of cells can be moved to the memory to reduce the probability of congestion at the ingress queue. In other words, the group of cells can be moved to the memory so that other cells queued behind the group of cells can be prepared for transmission (or transmitted) from the ingress queue without waiting for the group of cells to be transmitted from the ingress queue. In some embodiments, the transmission request can be a request to transmit to a specified egress port (e.g., a specified destination port).
A transmission denial that includes a response tag is sent to the ingress scheduling module, at 450 when, in response to the transmission request, transmission via the switch fabric is not authorized at 440. In some embodiments, the transmission request can be denied because the switch fabric is congested, a destination port is unavailable, and so forth. In some embodiments, the transmission request can be denied for a specified period of time. In some embodiments, the response tag can include one or more identifiers that can be used to associate the transmission denial with the group of cells.
If the transmission via the switch fabric is authorized at 440, a transmission response that includes a response tag to the ingress scheduling module is sent, at 460. In some embodiments, the transmission response can be a transmission authorization. In some embodiments, the transmission response can be sent after a destination of the group of cells is ready (or nearly ready) to receive the group of cells.
The group of cells is retrieved based on the response tag, at 470. If the group of cells has been moved to a memory, the group of cells can be retrieved from the memory. If the group of cells is queued at the ingress queue, the group of cells can be retrieved from the ingress queue. The group of cells can be retrieved based on a queue identifier and/or a queue sequence value included in the response tag. The queue identifier and/or the queue sequence value can be from the queue tag.
The group of cells can be transmitted via the switch fabric, at 480. The group of cells can be transmitted via the switch fabric according to an instruction included in the transmission response. In some embodiments, the group of cells can be transmitted at a specified time and/or via a specified transmission path. In some embodiments, the group of cells can be transmitted via the switch fabric to a destination such as an egress port. In some embodiments, after being transmitted via the switch fabric, the group of cells can be queued at an egress queue associated with a destination (e.g., destination port) of the group of cells.
As shown in
The egress schedule module 530 can determine that transmission of a transmission request from ingress schedule module 520 may have failed based on the request sequence values. Specifically, the egress schedule module 530 can determine that a transmission request associated with the request sequence value of 1201 was not received before transmission request 56, which is associated with request sequence value 1202, was received. In some embodiments, the egress schedule module 530 can execute an action with respect to the missing transmission request 54 when a time period between receipt of transmission request 52 and transmission request 56 (shown as time period 540) exceeds a threshold time period. In some embodiments, egress schedule module 530 can request that ingress schedule module 520 retransmit transmission request 54. The egress schedule module 530 can include the missing request sequence value so that the ingress schedule module 520 can identify the transmission request 54 that was not received. In some embodiments, egress schedule module 530 can deny a request for transmission of a group of cells included in transmission request 56. In some embodiments, the egress schedule module 530 can be configured to process and/or respond to transmission requests (such as transmission requests 58) based on queue sequence values in a substantially similar fashion to the methods described in connection with request sequence values.
As shown in
The ingress schedule module 620 can determine that transmission of a transmission response from egress schedule module 630 may have failed based on the response sequence values. Specifically, the ingress schedule module 620 can determine that a transmission response associated with the response sequence value of 1301 was not received before transmission response 66, which is associated with the response sequence value of 1302, was received. In some embodiments, the ingress schedule module 620 can execute an action with respect to the missing transmission response 64 when a time period between receipt of transmission response 62 and transmission response 66 (shown as time period 640) exceeds a threshold time period. In some embodiments, ingress schedule module 620 can request that egress schedule module 630 retransmit transmission response 64. The ingress schedule module 620 can include the missing response sequence value so that the egress schedule module 630 can identify the transmission response 64 that was not received. In some embodiments, ingress schedule module 620 can drop a group of cells when a transmission response associated with a transmission request is not received within a specified period of time.
Some embodiments described herein relate to a computer storage product with a computer-readable medium (also can be referred to as a processor-readable medium) having instructions or computer code thereon for performing various computer-implemented operations. The media and computer code (also can be referred to as code) may be those designed and constructed for the specific purpose or purposes. Examples of computer-readable media include, but are not limited to: magnetic storage media such as hard disks, floppy disks, and magnetic tape; optical storage media such as Compact Disc/Digital Video Discs (CD/DVDs), Compact Disc-Read Only Memories (CD-ROMs), and holographic devices; magneto-optical storage media such as optical disks; carrier wave signal processing modules; and hardware devices that are specially configured to store and execute program code, such as Application-Specific Integrated Circuits (ASICs), Programmable Logic Devices (PLDs), and Read-Only Memory (ROM) and Random-Access Memory (RAM) devices.
Examples of computer code include, but are not limited to, micro-code or micro-instructions, machine instructions, such as produced by a compiler, code used to produce a web service, and files containing higher-level instructions that are executed by a computer using an interpreter. For example, embodiments may be implemented using Java, C++, or other programming languages (e.g., object-oriented programming languages) and development tools. Additional examples of computer code include, but are not limited to, control signals, encrypted code, and compressed code.
While various embodiments have been described above, it should be understood that they have been presented by way of example only, not limitation, and various changes in form and details may be made. Any portion of the apparatus and/or methods described herein may be combined in any combination, except mutually exclusive combinations. The embodiments described herein can include various combinations and/or sub-combinations of the functions, components and/or features of the different embodiments described. For example, the embodiments described herein can be applied in a multi-stage queuing system.
This application claims priority to and is a continuation of U.S. patent application Ser. No. 12/343,728, filed Dec. 24, 2008, and entitled “Methods and Apparatus for Transmission of Groups of Cells via a Switch Fabric,” which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5457687 | Newman | Oct 1995 | A |
5926473 | Gridley | Jul 1999 | A |
5978359 | Caldara et al. | Nov 1999 | A |
5987008 | Simpson et al. | Nov 1999 | A |
5987028 | Yang et al. | Nov 1999 | A |
5991295 | Tout et al. | Nov 1999 | A |
6049546 | Ramakrishnan | Apr 2000 | A |
6073089 | Baker et al. | Jun 2000 | A |
6324165 | Fan et al. | Nov 2001 | B1 |
6370145 | Dally et al. | Apr 2002 | B1 |
6438107 | Somiya et al. | Aug 2002 | B1 |
6512747 | Umeuchi et al. | Jan 2003 | B1 |
6618357 | Geyer et al. | Sep 2003 | B1 |
6621824 | Lauffenburger et al. | Sep 2003 | B1 |
6657962 | Barri et al. | Dec 2003 | B1 |
6856622 | Calamvokis et al. | Feb 2005 | B1 |
6944173 | Jones et al. | Sep 2005 | B1 |
6973032 | Casley et al. | Dec 2005 | B1 |
6986161 | Billhartz | Jan 2006 | B2 |
7027457 | Chiussi et al. | Apr 2006 | B1 |
7046631 | Giroux et al. | May 2006 | B1 |
7061862 | Horiguchi et al. | Jun 2006 | B2 |
7075934 | Chiussi et al. | Jul 2006 | B2 |
7173931 | Chao et al. | Feb 2007 | B2 |
7185368 | Copeland, III | Feb 2007 | B2 |
7230947 | Huber et al. | Jun 2007 | B1 |
7233568 | Goodman et al. | Jun 2007 | B2 |
7234168 | Gupta et al. | Jun 2007 | B2 |
7269666 | Leitner et al. | Sep 2007 | B1 |
7277429 | Norman et al. | Oct 2007 | B2 |
7327680 | Kloth | Feb 2008 | B1 |
7391736 | Na et al. | Jun 2008 | B2 |
7403524 | Hill | Jul 2008 | B2 |
7424744 | Wu et al. | Sep 2008 | B1 |
7430175 | Dropps et al. | Sep 2008 | B2 |
7457245 | McAlpine et al. | Nov 2008 | B2 |
7519860 | Hatonen et al. | Apr 2009 | B2 |
7540025 | Tzadikario | May 2009 | B2 |
7543052 | Cesa Klein | Jun 2009 | B1 |
7719982 | Varma | May 2010 | B2 |
8325749 | Thomas et al. | Dec 2012 | B2 |
8553710 | White et al. | Oct 2013 | B1 |
20020064170 | Siu et al. | May 2002 | A1 |
20020075883 | Dell et al. | Jun 2002 | A1 |
20020080789 | Henderson et al. | Jun 2002 | A1 |
20020118692 | Oberman et al. | Aug 2002 | A1 |
20020154637 | Keller-Tuberg | Oct 2002 | A1 |
20020167950 | Chang et al. | Nov 2002 | A1 |
20030005145 | Bullard | Jan 2003 | A1 |
20030026287 | Mullendore et al. | Feb 2003 | A1 |
20030035432 | Sreejith et al. | Feb 2003 | A1 |
20030058880 | Sarkinen | Mar 2003 | A1 |
20030063348 | Posey, Jr. | Apr 2003 | A1 |
20030185154 | Mullendore et al. | Oct 2003 | A1 |
20030218977 | Pan et al. | Nov 2003 | A1 |
20040013124 | Peebles et al. | Jan 2004 | A1 |
20040120276 | Golla et al. | Jun 2004 | A1 |
20040165598 | Shrimali et al. | Aug 2004 | A1 |
20050036502 | Blanc et al. | Feb 2005 | A1 |
20050111460 | Sahita | May 2005 | A1 |
20050138238 | Tierney et al. | Jun 2005 | A1 |
20050138243 | Tierney et al. | Jun 2005 | A1 |
20050210533 | Copeland et al. | Sep 2005 | A1 |
20050226156 | Keating et al. | Oct 2005 | A1 |
20060104298 | McAlpine et al. | May 2006 | A1 |
20060120289 | Cunningham | Jun 2006 | A1 |
20060123480 | Oh et al. | Jun 2006 | A1 |
20060272018 | Fouant | Nov 2006 | A1 |
20060285548 | Hill et al. | Dec 2006 | A1 |
20070064617 | Reves | Mar 2007 | A1 |
20070067438 | Goranson et al. | Mar 2007 | A1 |
20070086464 | Somashekhar | Apr 2007 | A1 |
20070094729 | Hoefelmeyer et al. | Apr 2007 | A1 |
20070118909 | Hertzog et al. | May 2007 | A1 |
20070150949 | Futamura et al. | Jun 2007 | A1 |
20070180526 | Copeland, III | Aug 2007 | A1 |
20070192861 | Varghese et al. | Aug 2007 | A1 |
20070240207 | Belakhdar et al. | Oct 2007 | A1 |
20070268830 | Li et al. | Nov 2007 | A1 |
20080080548 | Mullendore et al. | Apr 2008 | A1 |
20080082977 | Araujo et al. | Apr 2008 | A1 |
20080151863 | Lawrence et al. | Jun 2008 | A1 |
20080253289 | Naven et al. | Oct 2008 | A1 |
20080259798 | Loh et al. | Oct 2008 | A1 |
20080263661 | Bouzida | Oct 2008 | A1 |
20080285449 | Larsson et al. | Nov 2008 | A1 |
20090003212 | Kwan et al. | Jan 2009 | A1 |
20090077663 | Sun et al. | Mar 2009 | A1 |
20090300209 | Elzur | Dec 2009 | A1 |
20100061238 | Godbole et al. | Mar 2010 | A1 |
20100061239 | Godbole et al. | Mar 2010 | A1 |
20100061390 | Godbole et al. | Mar 2010 | A1 |
20100158031 | Thomas et al. | Jun 2010 | A1 |
20100165843 | Thomas | Jul 2010 | A1 |
20110154132 | Aybay | Jun 2011 | A1 |
20110267942 | Aybay et al. | Nov 2011 | A1 |
20110310739 | Aybay | Dec 2011 | A1 |
20120140626 | Anand et al. | Jun 2012 | A1 |
Number | Date | Country |
---|---|---|
1 892 905 | Feb 2008 | EP |
2 361 139 | Oct 2001 | GB |
WO 9704546 | Feb 1997 | WO |
Entry |
---|
Search Report for European Application No. 09170041.9, mailed Nov. 23, 2009 (8 pages). |
F.K. Liotopoulos et al., “A Modular, 160 Gbps ATM Switch Architecture for Multimedia Networking Support, based on a 3-Stage Clos Network” Proceedings of the International Teletraffic Congress. ITC-16. Teletraffic Engineering in a Competitive World. Edinburgh, UK, Jun. 7, 1999, Amsterdam: Elsevier, NL, vol. 3A, XP000877657 ISBN: 978-0-444-50268-1, pp. 529-538. |
Office Action mailed Mar. 26, 2010 for U.S. Appl. No. 12/242,224 (17 pages). |
Office Action mailed Mar. 29, 2010 for U.S. Appl. No. 12/242,230 (11 pages). |
Office Action mailed May 11, 2010 for U.S. Appl. No. 12/345,490 (12 pages). |
William J. Daily, “Virtual-Channel Flow Control” IEEE Transactions on Parallel and Distributed Systems, vol. 3, No. 2, Mar. 1992, pp. 194-205. |
Office Action mailed Apr. 29, 2010 for U.S. Appl. No. 12/343,728, filed Dec. 24, 2008. |
Office Action mailed Oct. 15, 2010 for U.S. Appl. No. 12/343,728, filed Dec. 24, 2008. |
Office Action mailed May 2, 2011 for U.S. Appl. No. 12/343,728, filed Dec. 24, 2008. |
Office Action mailed Oct. 7, 2011 for U.S. Appl. No. 12/343,728, filed Dec. 24, 2008. |
Office Action mailed Sep. 17, 2010 for U.S. Appl. No. 12/242,224 (9 pages). |
Office Action mailed Sep. 17, 2010 for U.S. Appl. No. 12/242,230 (16 pages). |
Office Action mailed Oct. 15, 2010 for U.S. Appl. No. 12/345,490 (14 pages). |
Office Action mailed Aug. 9, 2011 for U.S. Appl. No. 12/242,224 (7 pages). |
Office Action mailed Mar. 17, 2011 for U.S. Appl. No. 12/242,230 (11 pages). |
Office Action mailed May 23, 2011 for U.S. Appl. No. 12/558,118 (6 pgs). |
Office Action mailed Apr. 1, 2011 for U.S. Appl. No. 12/345,490 (14 pages). |
Office Action mailed Aug. 19, 2011 for U.S. Appl. No. 12/345,490 (14 pages). |
U.S. Appl. No. 12/953,149, filed Nov. 23, 2010, entitled “Methods and Apparatus for Destination Based Hybrid Load Balancing Within a Switch Fabric” (49 pgs). |
U.S. Office Action mailed Oct. 6, 2011 for U.S. Appl. No. 12/242,230. |
Number | Date | Country | |
---|---|---|---|
20130121343 A1 | May 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12343728 | Dec 2008 | US |
Child | 13692425 | US |