Accelerating data transfer in a virtual computer system with tightly coupled TCP connections
First Claim
Patent Images
1. A method comprising:
- running a first operating system and a second operating system on a computer system, the first operating system having a first network protocol stack including a first transmission control protocol (TCP) layer and the second operating system having a second network protocol stack including a second TCP layer;
establishing a logical connection between the first and second TCP layers, including creating, by the first TCP layer, a first TCP control block corresponding to the logical connection, and creating, by the second TCP layer, a second TCP control block corresponding to the logical connection; and
coupling the first TCP control block to the second TCP control block, including executing instructions, by an entity that accesses the first and second TCP control blocks, that are specialized for a situation in which the first and second TCP control blocks correspond to the same logical connection.
1 Assignment
0 Petitions
Accused Products
Abstract
First and second operating systems of a virtual computer system can communicate using respective first and second network protocol stacks, by employing procedures that are specialized for a situation in which a TCP control block of the first stack and a TCP control block of the second stack correspond to the same logical connection. In this case, various TCP requirements can be bypassed by coupling the TCP control blocks, reducing or eliminating data copies and providing other efficiencies.
-
Citations
48 Claims
-
1. A method comprising:
-
running a first operating system and a second operating system on a computer system, the first operating system having a first network protocol stack including a first transmission control protocol (TCP) layer and the second operating system having a second network protocol stack including a second TCP layer; establishing a logical connection between the first and second TCP layers, including creating, by the first TCP layer, a first TCP control block corresponding to the logical connection, and creating, by the second TCP layer, a second TCP control block corresponding to the logical connection; and coupling the first TCP control block to the second TCP control block, including executing instructions, by an entity that accesses the first and second TCP control blocks, that are specialized for a situation in which the first and second TCP control blocks correspond to the same logical connection. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24)
-
-
25. A method comprising:
-
running a first operating system and a second operating system on a computer system, the first operating system having a first network protocol stack including a first transmission control protocol (TCP) layer and the second operating system having a second network protocol stack including a second TCP layer; establishing a logical connection between the first and second TCP layers, including creating, by the first TCP layer, a first TCP control block corresponding to the logical connection, and creating, by the second TCP layer, a second TCP control block corresponding to the logical connection; and coupling the first TCP control block to the second TCP control block, including executing a function call that references the first and second TCP control blocks. - View Dependent Claims (26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47)
-
-
48. A method comprising:
-
running a first operating system and a second operating system on a computer system, the first operating system having a first network protocol stack including a first transmission control protocol (TCP) layer and the second operating system having a second network protocol stack including a second TCP layer; establishing a logical connection between the first and second TCP layers, including creating, by the first TCP layer, a first TCP control block corresponding to the logical connection, and creating, by the second TCP layer, a second TCP control block corresponding to the logical connection; coupling the first TCP control block to the second TCP control block, including referencing the first TCP control block by a set of instructions and referencing the second TCP control block by the set of instructions.
-
Specification