Method to implement an L4-L7 switch using split connections and an offloading NIC
IPC분류정보
국가/구분
United States(US) Patent
등록
국제특허분류(IPC7판)
H04L-012/26
H04L-012/28
H04J-003/16
출원번호
UP-0356850
(2006-02-17)
등록번호
US-7616563
(2009-11-23)
발명자
/ 주소
Eiriksson, Asgeir Thor
Noureddine, Wael
출원인 / 주소
Chelsio Communications, Inc.
대리인 / 주소
Beyer Law Group LLP
인용정보
피인용 횟수 :
14인용 특허 :
51
초록▼
A method of operating intelligent network interface circuitry includes the network interface circuitry coupling a core processor to a network to facilitate communication over the network between the core processor and at least a first peer and a second peer. A first connection connects to the first
A method of operating intelligent network interface circuitry includes the network interface circuitry coupling a core processor to a network to facilitate communication over the network between the core processor and at least a first peer and a second peer. A first connection connects to the first peer and a second connection connects to the second peer. The network interface circuitry receives data packets from the first peer via the network on the first connection, according to a first particular protocol. The network interface circuitry processes the received data, including associating, with the second connection, data that is at least a portion of the data packets received on the first connection, such that the data received by the intelligent network interface circuitry on the first connection is switched to be outgoing from the intelligent network interface circuitry on the second connection, according to a second particular protocol.
대표청구항▼
What is claimed is: 1. A method of operating intelligent network interface circuitry, wherein the network interface circuitry couples a core processor to a network to facilitate communication over the network between the core processor and at least a first peer and a second peer, wherein a first co
What is claimed is: 1. A method of operating intelligent network interface circuitry, wherein the network interface circuitry couples a core processor to a network to facilitate communication over the network between the core processor and at least a first peer and a second peer, wherein a first connection connects to the first peer and a second connection connects to the second peer, a plurality of connections, including the second connection, connecting to a plurality of separate peers, the method comprising: by the network interface circuitry, receiving data packets from the first peer via the network on the first connection, according to a first particular protocol; and processing the received data, including associating, with the second connection, data that is at least a portion of the data packets received on the first connection, such that the data received by the intelligent network interface circuitry on the first connection is switched to be outgoing from the intelligent network interface circuitry on the second connection, according to a second particular protocol wherein the first particular protocol operates at no higher than layer 4, and processing the received data includes processing the packets at higher than layer 4, wherein the associating is based on a result of processing the layers higher than layer 4 to determine which of the plurality of connections is the second connection. 2. The method of claim 1, wherein: the network interface circuitry includes a pipelined processor circuitry configured to process data received by the network interface circuitry from the core for transmission to a peer via one of the connections and also to process data received by the network interface circuitry via one of the connections for receipt by the core; and associating, with the second connection, data that is at least a portion of the data packets received on the first connection includes generating data by the core processor, to be delivered on the second connection. 3. The method of claim 1, wherein: associating, with the second connection, data that is at least a portion of the data packets received on the first connection includes placing the data in a transmit buffer associated with the second connection. 4. The method of claim 3, wherein: the data is placed in the transmit buffer associated with the second connection without storing the data in a receive buffer associated with the first connection. 5. The method of claim 3, wherein: placing the data in a transmit buffer associated with the second connection includes appending the data to data already in the transmit buffer associated with the second connection. 6. The method of claim 1, wherein: the data received from the first peer via the network on the first connection is payload data included in data packets received from the first peer associated with the first connection; the first connection and the second connection are full duplex, and the method further comprises, by the intelligent network interface circuitry receiving data packets from the second peer on the second connection; associating, with the first connection, the data packets received on the second connection, such that the data incoming to the intelligent network interface circuitry on the second connection is switched to be outgoing from the intelligent network interface circuitry on the first connection. 7. The method of claim 1, wherein: processing at least a portion of data packets received on the first connection to determine which of the plurality of connections is the second connection includes the network interface circuitry providing the at least a portion of the data packet, corresponding to higher than layer 4 and received on the first connection to the core processor; and the core processor provides an indication to the network interface circuitry of the determination of which of the plurality of connections is the second connection. 8. The method of claim 7, wherein: the network interface circuitry providing the at least a portion of the data packet received on the first connection to the core processor includes delineating at least one protocol data unit in the data received on the first connection; and the at least a portion of the data packet received on the first connection is at least a portion of the at least one protocol data unit delineated by the network interface circuitry. 9. The method of claim 1, wherein: the network interface circuitry determines which of the plurality of connections is the second connection by processing the at least a portion of the data packet, corresponding to higher than layer 4 and received on the first connection in view of control information associated with the connections. 10. The method of claim 1, wherein: the portion of the data packets processed for associating the received data with the second connection includes a portion of the data packets associated with layer 5 to 7 packet headers. 11. The method of claim 10, wherein: the portion of the data packets associated with layer 5 to 7 packet headers includes iSCSI packet headers. 12. The method of claim 11, wherein: the plurality of separate peers to which the plurality of connections connect are storage controllers. 13. The method of claim 1, wherein: the processing of at least a portion of data packets received on the first connection to determine which of the plurality of connections is the second connection is on a per Protocol Data Unit basis in at least one of layers 5-7. 14. The method of claim 13, wherein: the portion of the data packets associated with layer 5 to 7 packet headers includes iSCSI packet headers. 15. The method of claim 1, further comprising: performing supplemental processing on the data provided on the second connection, not associated with switching the data. 16. The method of claim 15, wherein the supplemental processing includes verifying the integrity of the received data. 17. The method of claim 16, including: inserting, into the received data, a result of computing the integrity of the received data. 18. The method of claim 15, wherein the supplemental processing includes at least one of encryption/decryption and compression/decompression. 19. The method of claim 1, wherein: the first protocol and the second protocol are variants of the same protocol with environment specific optimizations. 20. The method of claim 1, wherein: the first protocol and the second protocol are variants of the same protocol configured differently. 21. A method of operating intelligent network interface circuitry, wherein the network interface circuitry couples a core processor to a network to facilitate communication over the network between the core processor and at least a first peer and a second peer, wherein a first connection connects to the first peer and a second connection connects to the second peer, the method comprising: by the network interface circuitry, receiving data packets from the first peer via the network on the first connection, according to a first particular protocol; and processing the received data, including associating, with the second connection, data that is at least a portion of the data packets received on the first connection, such that the data received by the intelligent network interface circuitry on the first connection is switched to be outgoing from the intelligent network interface circuitry on the second connection, according to a second particular protocol, wherein: the network interface circuitry includes a pipelined processor circuitry configured to process data received by the network interface circuitry from the core for transmission to a peer via one of the connections and also to process data received by the network interface circuitry via one of the connections for receipt by the core; and associating, with the second connection, data that is at least a portion of the data packets received on the first connection includes generating data by the core processor, to be delivered on the second connection; and wherein the pipelined processor circuitry includes ingress form packet circuitry configured to form ingress packets, from data received from the network, to provide to the core; egress form packet circuitry configured to form egress packets, from data received from the core, to provide to the network; intercept and redirect circuitry to selectively intercept packets from the ingress form packet circuitry, formed by the ingress form packet circuitry based on data received on the first connection, and to provide a message to the pipelined processor circuitry simulating a message from the core instructing the pipelined processor circuitry to provide the data of the ingress packets, from the ingress form packet circuitry based on data received on the first connection, to be redirected to the egress form packet circuitry to form egress packets to be delivered on the network on the second connection. 22. The method of claim 21, wherein: an identification of the second connection is stored in the network interface circuitry in a control block associated with the first connection. 23. The method of claim 21, wherein: the first particular protocol operates at no higher than layer 4, and processing the received data includes processing the packets at higher than layer 4, wherein the associating is based on a result of processing the layers higher than layer 4.
연구과제 타임라인
LOADING...
LOADING...
LOADING...
LOADING...
LOADING...
이 특허에 인용된 특허 (51)
Wang, Yi-Min; Hunt, Galen C.; Forin, Alessandro, Accelerating a distributed component architecture over a network using a modified RPC communication.
Boucher, Laurence B.; Blightman, Stephen E. J.; Craft, Peter K.; Higgen, David A.; Philbrick, Clive M.; Starr, Daryl D., Fast-path apparatus for receiving data corresponding to a TCP connection.
Laurence B. Boucher ; Stephen E. J. Blightman ; Peter K. Craft ; David A. Higgen ; Clive M. Philbrick ; Daryl D. Starr, Intelligent network interface device and system for accelerated communication.
Boucher, Laurence B.; Philbrick, Clive M.; Starr, Daryl D.; Blightman, Stephen E. J.; Craft, Peter K.; Higgen, David A., Intelligent network interface system and method for accelerated protocol processing.
Boucher Laurence B. ; Blightman Stephen E. J. ; Craft Peter K. ; Higgen David A. ; Philbrick Clive M. ; Starr Daryl D., Intelligent network interface system method for protocol processing.
Laurence B. Boucher ; Stephen E. J. Blightman ; Peter K. Craft ; David A. Higgen ; Clive M. Philbrick ; Daryl D. Starr, Intelligent network interfaced device and system for accelerated communication.
Hariguchi, Yoichi; Panigrahy, Rina; Sharma, Samar; Nagaraj, Ashwath, Methods and apparatus for mapping ranges of values into unique values of particular use for range matching operations using an associative memory.
Griswold,Doug; Bexten,Ron, Mobile data communications apparatus, methods and computer program products implementing cellular wireless data communications via a wireless local area network.
Boucher, Laurence B.; Blightman, Stephen E. J.; Craft, Peter K.; Higgen, David A.; Philbrick, Clive M.; Starr, Daryl D., Obtaining a destination address so that a network interface device can write network data without headers directly into host memory.
Boucher Laurence B. ; Blightman Stephen E. J. ; Craft Peter K. ; Higgen David A. ; Philbrick Clive M. ; Starr Daryl D., Passing a communication control block from host to a local device such that a message is processed on the device.
Boucher Laurence B. ; Blightman Stephen E. J. ; Craft Peter K. ; Higgen David A. ; Philbrick Clive M. ; Starr Daryl D., Passing a communication control block from host to a local device such that a message is processed on the device.
Laurence B. Boucher ; Stephen E. J. Blightman ; Peter K. Craft ; David A. Higgen ; Clive M. Philbrick ; Daryl D. Starr, Passing a communication control block to a local device such that a message is processed on the device.
Craft, Peter K.; Philbrick, Clive M.; Boucher, Laurence B.; Starr, Daryl D.; Blightman, Stephen E. J.; Higgen, David A., Port aggregation for network connections that are offloaded to network interface devices.
Craft, Peter K.; Philbrick, Clive M.; Boucher, Laurence B.; Higgen, David A., Protocol processing stack for use with intelligent network interface device.
Craft, Peter K.; Philbrick, Clive M.; Boucher, Laurence B.; Higgen, David A., Protocol processing stack for use with intelligent network interface device.
Peter K. Craft ; Olive M. Philbrick ; Laurence B. Boucher ; David A. Higgen, Protocol processing stack for use with intelligent network interface device.
Cross, Patricia C.; Connery, Glenn W.; Duguay, Christopher J., System and method for operating a network adapter when an associated network computing system is in a low-power state.
Laurence B. Boucher ; Stephen E. J. Blightman ; Peter K. Craft ; David A. Higgen ; Clive M. Philbrick ; Daryl D. Starr, TCP/IP offload network interface device.
Ramaswamy, Kumar; Lin, Cher-Wen; Rettberg, Randall David; Rahman, Mizanur Mohammed, User-level dedicated interface for IP applications in a data packet switching and load balancing system.
Hirasawa, Satoru; Sasaki, Yoshimi; Takahashi, Takenari; Ohtsuka, Takayuki; Inoue, Toshifumi; Fukuda, Kenji, Communication apparatus for transmitting data through a plurality of data-paths.
※ AI-Helper는 부적절한 답변을 할 수 있습니다.