US20020147826A1 - Apparatus and method for sending point-to-point protocol over ethernet - Google Patents

Apparatus and method for sending point-to-point protocol over ethernet Download PDF

Info

Publication number
US20020147826A1
US20020147826A1 US10/091,171 US9117102A US2002147826A1 US 20020147826 A1 US20020147826 A1 US 20020147826A1 US 9117102 A US9117102 A US 9117102A US 2002147826 A1 US2002147826 A1 US 2002147826A1
Authority
US
United States
Prior art keywords
packet
tcp
mss
header
network
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US10/091,171
Inventor
Daniel Sultan
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
NortonLifeLock Inc
Original Assignee
Daniel Sultan
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Daniel Sultan filed Critical Daniel Sultan
Priority to US10/091,171 priority Critical patent/US20020147826A1/en
Publication of US20020147826A1 publication Critical patent/US20020147826A1/en
Assigned to NEXLAND, INC. reassignment NEXLAND, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SULTAN, DANIEL
Assigned to SYMANTEC CORPORATION reassignment SYMANTEC CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: NEXLAND, INC.
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/13Flow control; Congestion control in a LAN segment, e.g. ring or bus
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/19Flow control; Congestion control at layers above the network layer
    • H04L47/193Flow control; Congestion control at layers above the network layer at the transport layer, e.g. TCP related
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/36Flow control; Congestion control by determining packet size, e.g. maximum transfer unit [MTU]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • H04L69/161Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • H04L69/163In-band adaptation of TCP data exchange; In-band control procedures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • H04L69/168Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP] specially adapted for link layer protocols, e.g. asynchronous transfer mode [ATM], synchronous optical network [SONET] or point-to-point protocol [PPP]

Definitions

  • This invention relates to computer networks and specifically to a method of transmitting and receiving information using point-to-point protocol (“PPP”) over an ethernet network.
  • PPP point-to-point protocol
  • the use of this invention is not limited to the internet, the internet provides the primary environment for practicing the invention.
  • the internet is not a single network, but comprises a large number of interconnected networks.
  • the device originating the information which may be a computer, will initially construct packets in which the data being transmitted is contained as a “payload.”
  • “Headers” and “trailers” conforming to the transmission protocols being used will be prepended and appended to the data to provide routers with sufficient information to forward the packets from network to network, in a series of “hops,” until the packet arrives at its intended destination.
  • packet shall refer, generically, to a sequence of bytes representing a unit of data being transmitted pursuant to one or more transmission protocols.
  • “Bytes” shall refer to an octet of binary digits.
  • MTU maximum transmission unit
  • MTU maximum transmission unit
  • the MTU may be different for different networks.
  • MTU is determined as a function of network design, including network bandwidth, maximal diameter, and desired imposed jitter. Since an IP packet in transit will frequently traverse more than a single network, it may encounter MTUs of different sizes. Since a packet cannot be transmitted over a network whose MTU is smaller than the packet size, one possible solution has been for a sending device to use a path MTU discovery algorithm to determine the smallest MTU that will be encountered during transit to the destination, and to establish a maximum packet size based upon that information. However, that solution has encountered a number of documented difficulties (RFC 2923, “TCP Problems with Path MTU Discovery”), and does not always present an acceptable solution for the problem.
  • RRC 2923 “TCP Problems with Path MTU Discovery”
  • Each network segment is defined by a router, and a packet passing through a router when transiting from one network to another will have its headers and trailers analyzed, stripped, modified, or added to by the router, depending upon the protocol being used by the next network segment.
  • routers maintain information about the networks connected to them, including the MTU. When a router encounters a packet that is larger than the MTU for the next network segment in the path to the packet's destination, the packet will not be accepted by the network segment, and may be lost, with a resulting communication failure between the sending and receiving devices. For this reason, it is important that packets be properly sized to be accepted by the networks they will be transiting.
  • Data to be transmitted to a remote device will normally be generated by a process running on a computer.
  • the data will be sent to a TCP buffer in the RAM of the computer where it will be formatted and encapsulated within a TCP header and an IP header which provide addressing information for the packet and for the process on the recipient machine. Thereafter, additional headers will be added, depending upon the network protocols being used on the network to which the computer is connected. For ethernet networks, the last header to be added will be an ethernet header, which is added by the ethernet driver that is attached to the physical transmission medium.
  • a reverse process is employed to decapsulate the packet and provide data to the appropriate process running on the destination computer.
  • the processes of encapsulation and decapsulation, and associated functions of receiving, comparing, setting option and header values, transmitting, and the like, are carried out by programs and drivers running on the sending device.
  • Ethernet is a low-level network protocol, and is the primary protocol found in local area networks (LANs). Ethernet frames transport data carried in higher level protocols across ethernet networks. Ethernet drivers accept information formatted by upper level protocols such as IP, TCP (transmission control protocol), ARP (address resolution protocol), and ICMP (internet control message protocol), and “encapsulate” it for delivery across the ethernet network.
  • IP transmission control protocol
  • ARP address resolution protocol
  • ICMP Internet control message protocol
  • Ethernet is a multiple access network in which many devices may be attached to the same physical transmission medium. Because each device on an ethernet network must be able to be uniquely distinguished from the others, each is identified by a globally unique physical address, sometimes referred to as a “medium access control”, or “MAC” address.
  • MAC medium access control
  • the sending device adds an eight byte preamble and an ethernet header at the beginning of the packet.
  • the ethernet header is 14 bytes, and comprises the destination device's MAC address, the sending device's MAC address, and the ethernet type.
  • a 4-byte trailer comprising a check frame sequence is appended to the packet. The packet is then transmitted to the network, and the device that recognizes its own address in the destination address field receives the frame.
  • Ethernet frames may be of varying length. However, the maximum permissible length of an ethernet frame which, by convention, does not include the preamble, but which does include the header (which holds the source and destination addresses, and the ethernet type), and the trailing Frame Check Sequence, is 1518 bytes.
  • Information formatted in higher level protocols such as IP, TCP, or PPP, is contained in a data field, or “payload,” that is located between the ethernet frame's header and trailer. Because the maximum size of an ethernet packet is 1518 bytes, including the 14-byte header and the 4-byte trailer, the maximum size payload for an ethernet packet is 1,500 bytes. All information associated with packets from upper layer protocols, including their headers, must fit within the 1500 byte limit of the ethernet payload.
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • IP Transmission Control Protocol/Internet Protocol
  • the suite of protocols known as TCP/IP is the protocol used to carry information over the internet.
  • TCP/IP is also used in many LANs that are, or may be, connected to the internet.
  • the IP portion of TCP/IP is a network layer protocol that supports TCP and other higher layer protocols.
  • IP uses a header that includes the source and destination addresses of the sending and recipient devices in the now-familiar 32-bit format representing four decimal numbers: xxx.xxx.xxx.xxx.
  • the basic IP header is 20 bytes in length, although the addition of options in an “Options” field may extend the length past 20 bytes. Most options for an IP header are used only for diagnostic purposes, and an IP header generally will have a length of 20 bytes except under the most unusual conditions.
  • TCP is a protocol located above IP, in the transport layer, and a TCP packet will always be encapsulated within an IP packet for transmission to its destination.
  • TCP embodies an architecture having all of the functionality required to implement reliability, sequencing, flow control, and streaming necessary for an end-to-end signaling model.
  • TCP provides a communication channel between processes on each host system by communicating through a “socket,” which is bound to a TCP port address, and which acts as the interface between the process and the network.
  • the basic TCP header is 20 bytes in length, and relies upon the IP header within which it is encapsulated to provide source and destination device addresses.
  • the TCP header includes source and destination ports, and other information needed to place packets in sequence, to control packet fragmentation, to acknowledge receipt of a packet, to verify the integrity of information, to signal various conditions, and to carry out other functions.
  • the TCP header may also contain options which will control the handling of following TCP packets in the session. One of those options is a maximum segment size (“MSS”) value which occupies 4 bytes of the TCP options field (2 bytes identify the option as MSS and two bytes represent the number of bytes for the maximum segment size). When set, this number limits the number of bytes in the TCP payload that the sending device is prepared to receive throughout the session.
  • MSS maximum segment size
  • the header of a TCP packet for “opening” a socket for communications will set a flag bit to signal a SYN (synchronize) condition, and will include other information that is used in the session associated with the socket being opened.
  • the MSS value can be set only in the initial SYN packet.
  • Other options, such as the Window Scale option and the SACK (“selective acknowledgment) are also available only in an initial SYN packet.
  • PPP point-to-point protocol
  • IETF Internet Engineering Task Force
  • PPP provides a standard for transporting such higher-level protocols between two peer devices by encapsulating higher-level data along with negotiation mechanisms for configuring the link.
  • the PPP header may include configuration options, one of which is a “maximum-receive-unit” (MRU). This option may be sent to inform the peer (receiving device) that the implementation can receive larger packets, or to request that the peer send smaller packets.
  • MRU maximum-receive-unit
  • PPP is probably best known for use in telephone or ISDN dial-up links, or DSL connections between individual computers and internet service providers (“ISPs”) who provide a connection to the internet.
  • ISPs internet service providers
  • Data formatted for IP is encapsulated within a PPP packet for delivery from the individual computer to the ISP.
  • the encapsulation will be stripped away, and the IP packet will be delivered to the internet for further transmission to its destination.
  • PPP was developed as a protocol to connect two “peer” devices, it lends itself to methods of access control, billing functionality, and type of service demands. These features and controls, although desirable under particular circumstances, are specific to “two-party” networks, and are not available in traditional ethernet networks. These desirable features of PPP have led to recent efforts to develop a method for transmitting PPP over ethernet networks. These efforts are described in RFC-2516 which, although not an internet standard, proposes a method for transmitting PPP over Ethernet (“PPoE”) by encapsulating PPP packets within ethernet packets to provide many of the benefits associated with each of the protocols.
  • PPPoE PPP over Ethernet
  • the PPPoE header for an ethernet frame is 6 bytes long.
  • the payload of a PPPoE packet includes a PPP packet, whose header is 2 bytes in length, and any other packets that may be encapsulated within the PPP packet.
  • Optional “tags” attached to the PPPoE packet are carried in the payload section, and may further reduce the maximum PPP payload size.
  • RFC 2516 provides that the MRU option must not be negotiated to be larger than 1492 bytes. This options is relevant, however, only when the PPP packet will be received by the device that will generate a responding transmission.
  • the PPP and PPPoE headers will be stripped from the packet before it reaches its destination, and the packet will then be routed to its final destination without the MRU information.
  • the receiving machine will not be aware that the packet it sends in response will be transiting a network segment using PPP protocol on its trip back to the sending device, and it will default to sending a packet whose size is limited to the maximum size for an ethernet payload, or 1500 bytes.
  • the method and apparatus of the present invention uses the initializing TCP header to carry information to the receiving machine to limit the size of TCP packets transmitted from the receiving device to the sending device. This ensures that packets sent by the receiving device will be at least 8 bytes smaller than the maximum packet size for ethernet, and will permit those packets to accept PPP and PPPoE headers without becoming larger than the maximum packet size for ethernet.
  • This invention allows for adjustment of the packet size by adjusting the maximum segment size (“MSS”) in the encapsulated TCP packet that opens a session using a SYN command.
  • the TCP MSS option is located in the TCP header, and specifies the maximum number of data octets (defined herein as “bytes”) in a TCP segment exclusive of the TCP header (RFC 879).
  • RRC 879 the maximum number of data octets
  • the sending device ensures that packets sent by the receiving device will be able to have the PPP and PPPoE headers added, and still be no larger than the ethernet maximum of 1518 bytes.
  • FIG. 1 is a representation of three network segments having routers between network segments and a computer at either end. The makeup of a hypothetical packet is shown at various stages during transit between the computers.
  • FIG. 2 is a depiction of an ethernet packet in which is encapsulated, respectively, a PPPoE packet, a PPP packet, an IP packet, and a TCP packet having an options field.
  • a byte scale indicating byte length is located at the top of the figure.
  • FIG. 3 depicts an ethernet packet in which is encapsulated a PPPoE packet, a PPP packet, an IP packet, and a TCP packet in which the options field is absent.
  • a byte scale indicating byte length is located at the top of the figure.
  • FIG. 1 depicts a hypothetical network having three network segments.
  • a first computer 2 is located at one end, while a second computer 4 is located at the other end.
  • the three network segments are connected by routers 6 and 8 . Depictions of a single packet of information are shown at each network segment.
  • the packet 10 has a TCP packet that is encapsulated within an IP packet which, in turn, is encapsulated within a PPP packet.
  • the PPP packet is encapsulated within a PPPoE packet, which itself is encapsulated within an ethernet packet.
  • the MSS option field value was set at “1452” bytes.
  • the MRU option of the PPP packet would have been set at 1492. If the PPP were being used on a serial network having only two devices, the receiving device would be able to use the MRU to send responding packets of the requested size. In FIG. 1, however, the packet 10 will be received at router 6 , and will be routed to router 8 on an ethernet segment that does not use PPP.
  • Router 6 will therefore strip out the PPP and the PPPoE headers from the packet 12 , will place the proper source and destination MAC addresses for sending to router 8 in the address field of the ethernet header, and will recalculate the check sum before sending the packet to router 8 .
  • the packet arrives at router 8 , it will again have the correct source and destination MAC addresses placed in the ethernet header, recalculate the check sum, and will transmit the packet 14 to the second computer 4 .
  • the second computer prepares to send a responding message, it will obtain packet size information from the MSS field option in the TCP packet.
  • an ethernet packet is depicted 10 in which is encapsulated, respectively, a PPPoE packet 70 , a PPP packet 90 , an IP packet 100 , and a TCP packet 80 .
  • Each packet has a header and a payload associated with it.
  • the ethernet packet header 20 has a length of 14 bytes.
  • the payload for the ethernet packet 70 includes the entirety of the PPPoE packet.
  • the header 40 for the PPPoE packet occupies 6 bytes, and has a payload 90 that encompasses the PPP packet.
  • the PPP header 50 is a 2-byte header having as the PPP payload the entire IP packet 100 .
  • the standard header 30 for the IP packet has a length of 20 bytes, not including optional fields which are not present in FIG. 2.
  • the payload 80 for the IP packet includes the entirety of the TCP packet.
  • the TCP header 60 includes an options field 110 which can hold information for the maximum segment size (“MSS”). As depicted in FIG. 2, the TCP header 60 with the optional 4 byte MSS is 24-bytes in length. In this packet the SYN flag 130 would be set, indicating that a session is being initiated and a socket is being opened for interprocess communications.
  • the TCP packet has a payload 120 whose maximum size is determined by the MSS value in the TCP options field 110 .
  • the TCP payload 120 carries process-specific information from a socket in the sending device to a corresponding socket in the receiving device.
  • a 4-byte trailing frame check sequence (FCS) 140 is appended to the ethernet packet.
  • FCS 4-byte trailing frame check sequence
  • the MSS is a 16 bit number that theoretically may be as large as 65,535.
  • the maximum size for an ethernet payload (not including the ethernet header or trailer) is 1500 bytes, it is clear that any packet in which the size of the ethernet packet, including both the 14 byte header and the 4 byte file check sequence, exceeds 1518 bytes cannot be transmitted over an ethernet medium.
  • the preferred embodiment of this invention initializes a TCP session by substituting the number “1452” (0x05ac in hexadecimal) into the MSS field when the SYN flag 130 is set in the TCP header. This is shown in FIG. 2 at 110 .
  • the value of 1452 is determined by subtracting from the maximum payload value for an ethernet frame (1500 bytes) the number of bytes in the headers of the encapsulated packets. These are, the PPPoE header (6 bytes), the PPP header (2 bytes), the IP header (20 bytes) and the TCP header (20 bytes).
  • the MSS field is one of the options that must be included in a TCP packet to open a socket for a session. Any such TCP socket opening packet may be identified by the SYN flag 130 in the header, which is set for socket opening frames and otherwise is clear. None of the optional fields, including the MSS, the window scale option or the SACK options, will be needed for later transmissions once the session has started.
  • FIG. 3 shows an ethernet packet in which PPP is encapsulated, and the TCP header does not include an options field. Because this packet does not open a session, the SYN flag 130 in the TCP header is clear. For non-initializing TCP packets, the TCP payload will always be preceded by the basic 20 byte TCP header.
  • the method of this invention can be implemented through software or firmware in any PPPoE session. Implementation may take the form of checking the MSS value for any TCP SYN packet and replacing any MSS value with “1452” if the original MSS value is larger than 1452; or the method could simply write the number “1452” into the MSS field for each TCP SYN packet, without first analyzing the existing value.
  • the preferred embodiment substitutes the value “1452” into the MSS option for initializing TCP packets
  • any other number that is less than 1452 may be substituted into the MSS field, and will ensure that the receiving device will send responding packets that are more than 8 bytes smaller than the maximum size for an ethernet packet.
  • Other network factors may indicate the use of a smaller packet size, although a smaller packet size may require more packets to be transmitted to convey the same data, resulting in a decrease in communications efficiency. It will be understood that the description herein relates to the preferred embodiment of the invention, and that the scope of the invention will encompass a range of MSS values, and is limited only by the following claims.

Abstract

A method of using point-to-point protocol (PPP) to transmit information from a device connected to an ethernet network, comprises the steps of identifying each packet having a PPPoE header and an encapsulated TCP packet, determining whether the SYN flag within the header of the TCP header is set, and if the SYN flag is set, modifying the value of the Maximum Segment Size in the TCP header to be no larger than 1452 bytes, and transmitting said packet to the destination address appearing in said IP header.

Description

  • This application is a continuation-in-part of application Ser. No. 09/798,432, filed Mar. 2, 2001, and which is incorporated herein in its entirety by reference.[0001]
  • FIELD OF THE TECHNOLOGY
  • This invention relates to computer networks and specifically to a method of transmitting and receiving information using point-to-point protocol (“PPP”) over an ethernet network. Although the use of this invention is not limited to the internet, the internet provides the primary environment for practicing the invention. [0002]
  • BACKGROUND OF THE INVENTION
  • The internet is not a single network, but comprises a large number of interconnected networks. When information is to be transmitted across the internet, the device originating the information, which may be a computer, will initially construct packets in which the data being transmitted is contained as a “payload.” “Headers” and “trailers” conforming to the transmission protocols being used will be prepended and appended to the data to provide routers with sufficient information to forward the packets from network to network, in a series of “hops,” until the packet arrives at its intended destination. As used in this specification, “packet” shall refer, generically, to a sequence of bytes representing a unit of data being transmitted pursuant to one or more transmission protocols. “Bytes” shall refer to an octet of binary digits. Once the packet arrives at its destination, headers and footers are stripped away, and the data is made available to the appropriate process running on the recipient computer. [0003]
  • Within the design of IP (“internet protocol”), every physical network has a maximum packet size, designated “maximum transmission unit,” or MTU, and the MTU may be different for different networks. MTU is determined as a function of network design, including network bandwidth, maximal diameter, and desired imposed jitter. Since an IP packet in transit will frequently traverse more than a single network, it may encounter MTUs of different sizes. Since a packet cannot be transmitted over a network whose MTU is smaller than the packet size, one possible solution has been for a sending device to use a path MTU discovery algorithm to determine the smallest MTU that will be encountered during transit to the destination, and to establish a maximum packet size based upon that information. However, that solution has encountered a number of documented difficulties (RFC 2923, “TCP Problems with Path MTU Discovery”), and does not always present an acceptable solution for the problem. [0004]
  • Each network segment is defined by a router, and a packet passing through a router when transiting from one network to another will have its headers and trailers analyzed, stripped, modified, or added to by the router, depending upon the protocol being used by the next network segment. In order to route packets efficiently, routers maintain information about the networks connected to them, including the MTU. When a router encounters a packet that is larger than the MTU for the next network segment in the path to the packet's destination, the packet will not be accepted by the network segment, and may be lost, with a resulting communication failure between the sending and receiving devices. For this reason, it is important that packets be properly sized to be accepted by the networks they will be transiting. [0005]
  • Because each packet of information is discretely routed from source to destination, packets may follow different paths, depending upon network conditions. While most networks comprising the internet are high speed networks, using protocols such as ATM and the like, conditions occasionally arise in which other, slower transmission protocols and media are used. Under some circumstances, passage across a network may involve a packet's being transmitted across an ethernet network using point-to-point protocol (“PPP”). Such protocols may be found in dial-up networks, ISDN, and, more recently, DSL networks, and are frequently used to connect individual devices to an internet service provider. When this combination of protocols is used, it is not uncommon for difficulties to arise that culminate in the loss of transmitted data. [0006]
  • Data to be transmitted to a remote device will normally be generated by a process running on a computer. The data will be sent to a TCP buffer in the RAM of the computer where it will be formatted and encapsulated within a TCP header and an IP header which provide addressing information for the packet and for the process on the recipient machine. Thereafter, additional headers will be added, depending upon the network protocols being used on the network to which the computer is connected. For ethernet networks, the last header to be added will be an ethernet header, which is added by the ethernet driver that is attached to the physical transmission medium. When the packet is received at the destination, a reverse process is employed to decapsulate the packet and provide data to the appropriate process running on the destination computer. The processes of encapsulation and decapsulation, and associated functions of receiving, comparing, setting option and header values, transmitting, and the like, are carried out by programs and drivers running on the sending device. [0007]
  • Ethernet is a low-level network protocol, and is the primary protocol found in local area networks (LANs). Ethernet frames transport data carried in higher level protocols across ethernet networks. Ethernet drivers accept information formatted by upper level protocols such as IP, TCP (transmission control protocol), ARP (address resolution protocol), and ICMP (internet control message protocol), and “encapsulate” it for delivery across the ethernet network. [0008]
  • Ethernet is a multiple access network in which many devices may be attached to the same physical transmission medium. Because each device on an ethernet network must be able to be uniquely distinguished from the others, each is identified by a globally unique physical address, sometimes referred to as a “medium access control”, or “MAC” address. When information is to be delivered across an ethernet network, the sending device adds an eight byte preamble and an ethernet header at the beginning of the packet. The ethernet header is 14 bytes, and comprises the destination device's MAC address, the sending device's MAC address, and the ethernet type. A 4-byte trailer comprising a check frame sequence is appended to the packet. The packet is then transmitted to the network, and the device that recognizes its own address in the destination address field receives the frame. [0009]
  • Ethernet frames may be of varying length. However, the maximum permissible length of an ethernet frame which, by convention, does not include the preamble, but which does include the header (which holds the source and destination addresses, and the ethernet type), and the trailing Frame Check Sequence, is 1518 bytes. [0010]
  • Information formatted in higher level protocols, such as IP, TCP, or PPP, is contained in a data field, or “payload,” that is located between the ethernet frame's header and trailer. Because the maximum size of an ethernet packet is 1518 bytes, including the 14-byte header and the 4-byte trailer, the maximum size payload for an ethernet packet is 1,500 bytes. All information associated with packets from upper layer protocols, including their headers, must fit within the 1500 byte limit of the ethernet payload. [0011]
  • The suite of protocols known as TCP/IP (“Transmission Control Protocol/Internet Protocol”) is the protocol used to carry information over the internet. TCP/IP is also used in many LANs that are, or may be, connected to the internet. The IP portion of TCP/IP is a network layer protocol that supports TCP and other higher layer protocols. IP uses a header that includes the source and destination addresses of the sending and recipient devices in the now-familiar 32-bit format representing four decimal numbers: xxx.xxx.xxx.xxx. The basic IP header is 20 bytes in length, although the addition of options in an “Options” field may extend the length past 20 bytes. Most options for an IP header are used only for diagnostic purposes, and an IP header generally will have a length of 20 bytes except under the most unusual conditions. [0012]
  • TCP is a protocol located above IP, in the transport layer, and a TCP packet will always be encapsulated within an IP packet for transmission to its destination. TCP embodies an architecture having all of the functionality required to implement reliability, sequencing, flow control, and streaming necessary for an end-to-end signaling model. TCP provides a communication channel between processes on each host system by communicating through a “socket,” which is bound to a TCP port address, and which acts as the interface between the process and the network. [0013]
  • The basic TCP header is 20 bytes in length, and relies upon the IP header within which it is encapsulated to provide source and destination device addresses. The TCP header includes source and destination ports, and other information needed to place packets in sequence, to control packet fragmentation, to acknowledge receipt of a packet, to verify the integrity of information, to signal various conditions, and to carry out other functions. The TCP header may also contain options which will control the handling of following TCP packets in the session. One of those options is a maximum segment size (“MSS”) value which occupies 4 bytes of the TCP options field (2 bytes identify the option as MSS and two bytes represent the number of bytes for the maximum segment size). When set, this number limits the number of bytes in the TCP payload that the sending device is prepared to receive throughout the session. [0014]
  • The header of a TCP packet for “opening” a socket for communications will set a flag bit to signal a SYN (synchronize) condition, and will include other information that is used in the session associated with the socket being opened. The MSS value can be set only in the initial SYN packet. Other options, such as the Window Scale option and the SACK (“selective acknowledgment) are also available only in an initial SYN packet. Once the TCP session has been opened, and throughout the session until the session is closed (by setting a bit in the FIN flag) the TCP parameters for communicating with the socket will remain as they were established when the session was opened, and the TCP header will remain at a constant length of 20-bytes throughout the session. [0015]
  • The point-to-point protocol (“PPP”) is a set of interdependent protocols designed to work together to support the concurrent operation of multiple higher-layer protocols over a PPP serial link. PPP is an IETF (Internet Engineering Task Force) Standard specified in RFC-1661. PPP provides a standard for transporting such higher-level protocols between two peer devices by encapsulating higher-level data along with negotiation mechanisms for configuring the link. The PPP header may include configuration options, one of which is a “maximum-receive-unit” (MRU). This option may be sent to inform the peer (receiving device) that the implementation can receive larger packets, or to request that the peer send smaller packets. The default MRU is 1500 bytes. [0016]
  • PPP is probably best known for use in telephone or ISDN dial-up links, or DSL connections between individual computers and internet service providers (“ISPs”) who provide a connection to the internet. Data formatted for IP is encapsulated within a PPP packet for delivery from the individual computer to the ISP. At the ISP, the encapsulation will be stripped away, and the IP packet will be delivered to the internet for further transmission to its destination. [0017]
  • Because PPP was developed as a protocol to connect two “peer” devices, it lends itself to methods of access control, billing functionality, and type of service demands. These features and controls, although desirable under particular circumstances, are specific to “two-party” networks, and are not available in traditional ethernet networks. These desirable features of PPP have led to recent efforts to develop a method for transmitting PPP over ethernet networks. These efforts are described in RFC-2516 which, although not an internet standard, proposes a method for transmitting PPP over Ethernet (“PPPoE”) by encapsulating PPP packets within ethernet packets to provide many of the benefits associated with each of the protocols. [0018]
  • The PPPoE header for an ethernet frame is 6 bytes long. The payload of a PPPoE packet includes a PPP packet, whose header is 2 bytes in length, and any other packets that may be encapsulated within the PPP packet. Optional “tags” attached to the PPPoE packet are carried in the payload section, and may further reduce the maximum PPP payload size. In order to accommodate the PPP packet within the ethernet frame, RFC 2516 provides that the MRU option must not be negotiated to be larger than 1492 bytes. This options is relevant, however, only when the PPP packet will be received by the device that will generate a responding transmission. However, when the packet that is encapsulated within the PPP packet is destined for a device that lies beyond the network segment that is using PPP, the PPP and PPPoE headers will be stripped from the packet before it reaches its destination, and the packet will then be routed to its final destination without the MRU information. When this happens, the receiving machine will not be aware that the packet it sends in response will be transiting a network segment using PPP protocol on its trip back to the sending device, and it will default to sending a packet whose size is limited to the maximum size for an ethernet payload, or 1500 bytes. [0019]
  • When this responding packet reaches the router immediately preceding the PPPoE segment, the addition of the PPP (2 byte) and PPPoE (6 byte) headers may increase the size of the ethernet payload to more than 1500 bytes, if the payload's original size had been larger than 1492 bytes. When that happens, the packet will be larger than the MTU for that network, will not be able to transit the network segment, and will be lost. [0020]
  • The method and apparatus of the present invention uses the initializing TCP header to carry information to the receiving machine to limit the size of TCP packets transmitted from the receiving device to the sending device. This ensures that packets sent by the receiving device will be at least [0021] 8 bytes smaller than the maximum packet size for ethernet, and will permit those packets to accept PPP and PPPoE headers without becoming larger than the maximum packet size for ethernet.
  • SUMMARY OF THE INVENTION
  • This invention allows for adjustment of the packet size by adjusting the maximum segment size (“MSS”) in the encapsulated TCP packet that opens a session using a SYN command. The TCP MSS option is located in the TCP header, and specifies the maximum number of data octets (defined herein as “bytes”) in a TCP segment exclusive of the TCP header (RFC 879). In the preferred embodiment of this invention, an MSS of 1452 bytes has been found to provide successful communications, although a packet size of less than 1452 would also be usable, albeit with somewhat lower efficiency. [0022]
  • This is accomplished by identifying TCP SYN packets and setting the value of the MSS in the option section of the TCP header to 1452 bytes. By limiting the MSS to no more than 1452 bytes, the sending device ensures that packets sent by the receiving device will be able to have the PPP and PPPoE headers added, and still be no larger than the ethernet maximum of 1518 bytes.[0023]
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a representation of three network segments having routers between network segments and a computer at either end. The makeup of a hypothetical packet is shown at various stages during transit between the computers. [0024]
  • FIG. 2 is a depiction of an ethernet packet in which is encapsulated, respectively, a PPPoE packet, a PPP packet, an IP packet, and a TCP packet having an options field. A byte scale indicating byte length is located at the top of the figure. [0025]
  • FIG. 3 depicts an ethernet packet in which is encapsulated a PPPoE packet, a PPP packet, an IP packet, and a TCP packet in which the options field is absent. A byte scale indicating byte length is located at the top of the figure.[0026]
  • DESCRIPTION OF THE PREFERRED EMBODIMENT
  • FIG. 1 depicts a hypothetical network having three network segments. A [0027] first computer 2 is located at one end, while a second computer 4 is located at the other end. The three network segments are connected by routers 6 and 8. Depictions of a single packet of information are shown at each network segment. When the packet is sent from the first computer 2, it is traversing a network segment that uses point-to-point protocol over ethernet. This may typically be a DSL connection from a home or office to an internet service provider. The packet 10 has a TCP packet that is encapsulated within an IP packet which, in turn, is encapsulated within a PPP packet. The PPP packet is encapsulated within a PPPoE packet, which itself is encapsulated within an ethernet packet. In accordance with the present invention, as the packet left the sending computer 2, the MSS option field value was set at “1452” bytes. In addition, the MRU option of the PPP packet would have been set at 1492. If the PPP were being used on a serial network having only two devices, the receiving device would be able to use the MRU to send responding packets of the requested size. In FIG. 1, however, the packet 10 will be received at router 6, and will be routed to router 8 on an ethernet segment that does not use PPP. Router 6 will therefore strip out the PPP and the PPPoE headers from the packet 12, will place the proper source and destination MAC addresses for sending to router 8 in the address field of the ethernet header, and will recalculate the check sum before sending the packet to router 8. When the packet arrives at router 8, it will again have the correct source and destination MAC addresses placed in the ethernet header, recalculate the check sum, and will transmit the packet 14 to the second computer 4. When the second computer prepares to send a responding message, it will obtain packet size information from the MSS field option in the TCP packet. In so doing, it will limit packet size to at least 8 bytes less than the maximum for ethernet transmissions, thereby assuring that there will be room in the packet for the PPP and PPPoE headers when the packet reaches router 6 for delivery across the ethernet segment using PPP to first computer 2.
  • In FIG. 2, an ethernet packet is depicted [0028] 10 in which is encapsulated, respectively, a PPPoE packet 70, a PPP packet 90, an IP packet 100, and a TCP packet 80. Each packet has a header and a payload associated with it. The ethernet packet header 20 has a length of 14 bytes. The payload for the ethernet packet 70 includes the entirety of the PPPoE packet. The header 40 for the PPPoE packet occupies 6 bytes, and has a payload 90 that encompasses the PPP packet. The PPP header 50 is a 2-byte header having as the PPP payload the entire IP packet 100. The standard header 30 for the IP packet has a length of 20 bytes, not including optional fields which are not present in FIG. 2. The payload 80 for the IP packet includes the entirety of the TCP packet. The TCP header 60 includes an options field 110 which can hold information for the maximum segment size (“MSS”). As depicted in FIG. 2, the TCP header 60 with the optional 4 byte MSS is 24-bytes in length. In this packet the SYN flag 130 would be set, indicating that a session is being initiated and a socket is being opened for interprocess communications. The TCP packet has a payload 120 whose maximum size is determined by the MSS value in the TCP options field 110. The TCP payload 120 carries process-specific information from a socket in the sending device to a corresponding socket in the receiving device. A 4-byte trailing frame check sequence (FCS) 140 is appended to the ethernet packet.
  • The MSS is a 16 bit number that theoretically may be as large as 65,535. However, because the maximum size for an ethernet payload (not including the ethernet header or trailer) is 1500 bytes, it is clear that any packet in which the size of the ethernet packet, including both the 14 byte header and the 4 byte file check sequence, exceeds 1518 bytes cannot be transmitted over an ethernet medium. [0029]
  • In order to limit ethernet packet length when using PPP, the preferred embodiment of this invention initializes a TCP session by substituting the number “1452” (0x05ac in hexadecimal) into the MSS field when the [0030] SYN flag 130 is set in the TCP header. This is shown in FIG. 2 at 110. The value of 1452 is determined by subtracting from the maximum payload value for an ethernet frame (1500 bytes) the number of bytes in the headers of the encapsulated packets. These are, the PPPoE header (6 bytes), the PPP header (2 bytes), the IP header (20 bytes) and the TCP header (20 bytes).
  • Within a TCP header, the MSS field is one of the options that must be included in a TCP packet to open a socket for a session. Any such TCP socket opening packet may be identified by the [0031] SYN flag 130 in the header, which is set for socket opening frames and otherwise is clear. None of the optional fields, including the MSS, the window scale option or the SACK options, will be needed for later transmissions once the session has started.
  • FIG. 3 shows an ethernet packet in which PPP is encapsulated, and the TCP header does not include an options field. Because this packet does not open a session, the [0032] SYN flag 130 in the TCP header is clear. For non-initializing TCP packets, the TCP payload will always be preceded by the basic 20 byte TCP header.
  • The method of this invention can be implemented through software or firmware in any PPPoE session. Implementation may take the form of checking the MSS value for any TCP SYN packet and replacing any MSS value with “1452” if the original MSS value is larger than 1452; or the method could simply write the number “1452” into the MSS field for each TCP SYN packet, without first analyzing the existing value. [0033]
  • Although the preferred embodiment substitutes the value “1452” into the MSS option for initializing TCP packets, those of skill in the art will appreciate that any other number that is less than 1452 may be substituted into the MSS field, and will ensure that the receiving device will send responding packets that are more than 8 bytes smaller than the maximum size for an ethernet packet. Other network factors may indicate the use of a smaller packet size, although a smaller packet size may require more packets to be transmitted to convey the same data, resulting in a decrease in communications efficiency. It will be understood that the description herein relates to the preferred embodiment of the invention, and that the scope of the invention will encompass a range of MSS values, and is limited only by the following claims. [0034]

Claims (9)

What is claimed is:
1. A method for transmitting data across a network having an ethernet network segment using point-to-point protocol (PPP), comprising the steps of:
identifying each packet having a TCP packet encapsulated within a PPPoE packet that is to be transmitted across said network;
analyzing each said identified TCP packet to determine whether the SYN flag within the header of said TCP packet is set;
if said SYN flag is set, comparing the MSS value contained in said TCP header with a predetermined decimal number that is no larger than the decimal number 1452,
if said MSS value is larger than said predetermined decimal number, substituting the predetermined decimal number into said MSS value;
transmitting said packet to said network for routing to a destination.
2. A method for transmitting data across an ethernet network segment using point-to-point protocol as claimed in claim 1, wherein said predetermined decimal number is 1452.
3. A method for transmitting data from a first device to a second device across a network having an ethernet network segment using point-to-point protocol, comprising the steps of:
identifying packets transmitted from said first device having a TCP packet encapsulated within an ethernet header;
for each identified TCP packet, determining whether the header of said TCP packet contains an MSS field;
determining whether the value in said MSS field is larger than the decimal number 1452;
if said value in said MSS field is larger than the decimal number 1452, substituting a predetermined number no greater than the decimal number 1452 into said MSS field,
placing said packet on said network for delivery to said second device.
4. A method for transmitting data from a first device to a second device across a network having an ethernet network segment using point-to-point protocol as claimed in claim 3, wherein said predetermined number is the decimal number 1452.
5. A method for transmitting data from a first device to a second device across a network having an ethernet network segment using point-to-point protocol, comprising the steps of:
identifying packets transmitted from said first device having a TCP packet encapsulated within an ethernet header;
for each identified TCP packet, determining whether the header of said TCP packet contains an MSS field;
for each identified TCP packet containing an MSS field, substituting a predetermined number no greater than the decimal number 1452 into said MSS field,
placing said packet on said network for delivery to said second device.
6. A method for transmitting data from a first device to a second device across a network having an ethernet network segment using point-to-point protocol as claimed in claim 5, wherein said predetermined number is the decimal number 1452.
7. A machine readable storage having stored thereon a computer program for transmitting information over an ethernet network using point-to-point protocol (PPP), said computer program comprising a routine set of instruction for causing the machine to perform the steps of:
accepting a packet for transmission across said ethernet network;
determining whether said packet contains an encapsulated TCP packet having a header option for an MSS field;
comparing the value in said MSS field with the decimal number 1452;
for packets having an MSS value greater than the decimal number 1452, substituting a predetermined number no greater than the decimal number 1452 into said MSS field,
placing said packet on said network for delivery to said second device.
8. A machine readable storage having stored thereon a computer program for transmitting information over an ethernet network using the point-to-point protocol, said computer comprising:
a TCP packet buffer
a comparator configured to determine whether a header of a TCP formatted packet in said TCP packet buffer contains an MSS field;
an MSS setter configured to set said MSS field to a value in a range from zero to 1452;
an encapsulator configured to encapsulate said TCP-formatted packet within a payload of an IP packet, to encapsulate said IP packet within a payload of a PPP packet, to encapsulate said PPP packet within a payload of a PPPoE packet, and to encapsulate said PPPoE packet within a payload of an ethernet packet; and
an ethernet packet transmitter.
9. A machine readable storage as claimed in claim 8 wherein said MSS setter is configured to set said MSS field to a value of 1452.
US10/091,171 2001-03-02 2002-03-04 Apparatus and method for sending point-to-point protocol over ethernet Abandoned US20020147826A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/091,171 US20020147826A1 (en) 2001-03-02 2002-03-04 Apparatus and method for sending point-to-point protocol over ethernet

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/798,432 US20020124095A1 (en) 2001-03-02 2001-03-02 Apparatus and method for sending point-to-point protocol over ethernet
US10/091,171 US20020147826A1 (en) 2001-03-02 2002-03-04 Apparatus and method for sending point-to-point protocol over ethernet

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/798,432 Continuation-In-Part US20020124095A1 (en) 2001-03-02 2001-03-02 Apparatus and method for sending point-to-point protocol over ethernet

Publications (1)

Publication Number Publication Date
US20020147826A1 true US20020147826A1 (en) 2002-10-10

Family

ID=25173383

Family Applications (2)

Application Number Title Priority Date Filing Date
US09/798,432 Abandoned US20020124095A1 (en) 2001-03-02 2001-03-02 Apparatus and method for sending point-to-point protocol over ethernet
US10/091,171 Abandoned US20020147826A1 (en) 2001-03-02 2002-03-04 Apparatus and method for sending point-to-point protocol over ethernet

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/798,432 Abandoned US20020124095A1 (en) 2001-03-02 2001-03-02 Apparatus and method for sending point-to-point protocol over ethernet

Country Status (3)

Country Link
US (2) US20020124095A1 (en)
EP (1) EP1364290A4 (en)
WO (1) WO2002071235A1 (en)

Cited By (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040168062A1 (en) * 2002-12-09 2004-08-26 Kabushiki Kaisha Toshiba Contents transmission/reception scheme with function for limiting recipients
US20040230662A1 (en) * 2003-02-14 2004-11-18 Julio Estrada System and method for sending and receiving large messages in a collaborative work environment
US20050078604A1 (en) * 2003-10-08 2005-04-14 Wai Yim Connectionless TCP/IP data exchange
US20050080919A1 (en) * 2003-10-08 2005-04-14 Chia-Hsin Li Method and apparatus for tunneling data through a single port
US20050169272A1 (en) * 2004-02-03 2005-08-04 Yung-Chieh Lo Method for fragmenting an incoming packet into a first outgoing packet and a second outgoing packet
US20050220120A1 (en) * 2002-06-11 2005-10-06 Walter Klausberger Method and access multiplexer for quick access to data networks
US20060104288A1 (en) * 2004-11-16 2006-05-18 Wai Yim Method and apparatus for tunneling data using a single simulated stateful TCP connection
US7088737B1 (en) * 2000-10-27 2006-08-08 Redback Networks Inc. Method and apparatus for combining packets having different protocol encapsulations within a circuit
US20060200517A1 (en) * 2005-03-03 2006-09-07 Steve Nelson Method and apparatus for real time multi-party conference document copier
US20060239298A1 (en) * 2005-04-22 2006-10-26 Cisco Technology Inc. Techniques for encapsulating point to point protocol (PPP) over Ethernet frames
US20070285501A1 (en) * 2006-06-09 2007-12-13 Wai Yim Videoconference System Clustering
KR100939638B1 (en) 2008-09-25 2010-01-29 에스케이씨앤씨 주식회사 Improved TCP Transmission Method Suitable for Embedded system
US20100271976A1 (en) * 2005-04-22 2010-10-28 Cisco Technology, Inc. Techniques for encapsulating point to point (ppp) over ethernet frames
US20110321039A1 (en) * 2010-06-29 2011-12-29 International Business Machines Corporation Virtual network packet transfer size manager
US20130016724A1 (en) * 2011-07-17 2013-01-17 Broadcom Corporation Link layer preemption
US20140056140A1 (en) * 2012-08-22 2014-02-27 Lockheed Martin Corporation Terminated transmission control protocol tunnel
US9419851B1 (en) * 2013-08-13 2016-08-16 Ca, Inc. Application transaction tracking across network boundaries
US11048535B2 (en) * 2016-12-21 2021-06-29 Tencent Technology (Shenzhen) Company Limited Method and apparatus for transmitting data packet based on virtual machine

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6728268B1 (en) * 1999-06-22 2004-04-27 Trimble Navigation Ltd. Method and system to connect internet protocol hosts via an application specific bus
US20030167338A1 (en) * 2002-03-01 2003-09-04 Globespanvirata Incorporated System and method to provide PPPoE connectivity to non-PPPoE clients
US7873045B2 (en) * 2003-09-15 2011-01-18 Exar Corporation Generating an encapsulating header based on encapsulated information provided at protocol-dependent locations
US8359398B1 (en) * 2004-01-20 2013-01-22 Oracle America, Inc. Efficient proxying of messages
US20050228926A1 (en) * 2004-04-05 2005-10-13 Smith Zachary S Virtual-bus interface and associated system and method
US8165111B2 (en) * 2006-07-25 2012-04-24 PSIMAST, Inc Telecommunication and computing platforms with serial packet switched integrated memory access technology
CN101170496B (en) * 2007-09-14 2011-04-13 华为技术有限公司 An identification method and device for point-to-point media stream
US10212022B2 (en) 2013-09-13 2019-02-19 Microsoft Technology Licensing, Llc Enhanced network virtualization using metadata in encapsulation header

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5958053A (en) * 1997-01-30 1999-09-28 At&T Corp. Communications protocol with improved security
US6034963A (en) * 1996-10-31 2000-03-07 Iready Corporation Multiple network protocol encoder/decoder and data processor
US6564267B1 (en) * 1999-11-22 2003-05-13 Intel Corporation Network adapter with large frame transfer emulation
US6636505B1 (en) * 1999-05-28 2003-10-21 3Com Corporation Method for service provisioning a broadband modem
US6711166B1 (en) * 1997-12-10 2004-03-23 Radvision Ltd. System and method for packet network trunking
US6973097B1 (en) * 2000-08-29 2005-12-06 Nortel Networks Limited Modifying message size indications in communications over data networks

Family Cites Families (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5867660A (en) * 1995-05-11 1999-02-02 Bay Networks, Inc. Method and apparatus for communicating between a network workstation and an internet
US5774660A (en) * 1996-08-05 1998-06-30 Resonate, Inc. World-wide-web server with delayed resource-binding for resource-based load balancing on a distributed resource multi-node network
US5835725A (en) * 1996-10-21 1998-11-10 Cisco Technology, Inc. Dynamic address assignment and resolution technique
JP3482091B2 (en) * 1997-01-09 2003-12-22 株式会社東芝 Communication device
US5835036A (en) * 1997-05-12 1998-11-10 Cisco Systems Co. Method of encoding data for transmission
US6226680B1 (en) * 1997-10-14 2001-05-01 Alacritech, Inc. Intelligent network interface system method for protocol processing
US6160808A (en) * 1997-12-18 2000-12-12 3Com Corporation Technique for transmitting incoming multi-link point-to-point (PPP) packet traffic over multiple outgoing links in a multi-link bundle
US6097720A (en) * 1998-04-07 2000-08-01 3Com Corporation Enabling multicast distribution efficiencies in a dialup access environment
EP0975123A1 (en) * 1998-07-15 2000-01-26 Telefonaktiebolaget L M Ericsson (Publ) Communication device and method for reliable and low-delay packet transmission
US6381646B2 (en) * 1998-11-03 2002-04-30 Cisco Technology, Inc. Multiple network connections from a single PPP link with partial network address translation
JP3791217B2 (en) * 1998-12-01 2006-06-28 日本電信電話株式会社 PPP communication system
JP3183343B2 (en) * 1999-02-26 2001-07-09 日本電気株式会社 Data communication method, terminal device, relay device, data communication system and recording medium thereof
KR100416996B1 (en) * 1999-05-10 2004-02-05 삼성전자주식회사 Variable-length data transmitting and receiving apparatus in accordance with radio link protocol for a mobile telecommunication system and method thereof
JP2000324164A (en) * 1999-05-12 2000-11-24 Nec Corp Device for transferring packet data

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6034963A (en) * 1996-10-31 2000-03-07 Iready Corporation Multiple network protocol encoder/decoder and data processor
US5958053A (en) * 1997-01-30 1999-09-28 At&T Corp. Communications protocol with improved security
US6711166B1 (en) * 1997-12-10 2004-03-23 Radvision Ltd. System and method for packet network trunking
US6636505B1 (en) * 1999-05-28 2003-10-21 3Com Corporation Method for service provisioning a broadband modem
US6564267B1 (en) * 1999-11-22 2003-05-13 Intel Corporation Network adapter with large frame transfer emulation
US6973097B1 (en) * 2000-08-29 2005-12-06 Nortel Networks Limited Modifying message size indications in communications over data networks

Cited By (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7088737B1 (en) * 2000-10-27 2006-08-08 Redback Networks Inc. Method and apparatus for combining packets having different protocol encapsulations within a circuit
US20050220120A1 (en) * 2002-06-11 2005-10-06 Walter Klausberger Method and access multiplexer for quick access to data networks
US7424023B2 (en) * 2002-06-11 2008-09-09 Siemens Aktiengesellschaft Method and access multiplexer for quick access to data networks
US20040168062A1 (en) * 2002-12-09 2004-08-26 Kabushiki Kaisha Toshiba Contents transmission/reception scheme with function for limiting recipients
US7516328B2 (en) 2002-12-09 2009-04-07 Kabushiki Kaisha Toshiba Contents transmission/reception scheme with function for limiting recipients
US7188245B2 (en) * 2002-12-09 2007-03-06 Kabushiki Kaisha Toshiba Contents transmission/reception scheme with function for limiting recipients
US20040230662A1 (en) * 2003-02-14 2004-11-18 Julio Estrada System and method for sending and receiving large messages in a collaborative work environment
US7263071B2 (en) 2003-10-08 2007-08-28 Seiko Epson Corporation Connectionless TCP/IP data exchange
US20050078604A1 (en) * 2003-10-08 2005-04-14 Wai Yim Connectionless TCP/IP data exchange
US20050080919A1 (en) * 2003-10-08 2005-04-14 Chia-Hsin Li Method and apparatus for tunneling data through a single port
US7406533B2 (en) 2003-10-08 2008-07-29 Seiko Epson Corporation Method and apparatus for tunneling data through a single port
US7986694B2 (en) 2004-02-03 2011-07-26 Realtek Semiconductor Corp. Method for fragmenting an incoming packet into a first outgoing packet and a second outgoing packet
US20050169272A1 (en) * 2004-02-03 2005-08-04 Yung-Chieh Lo Method for fragmenting an incoming packet into a first outgoing packet and a second outgoing packet
US7392323B2 (en) 2004-11-16 2008-06-24 Seiko Epson Corporation Method and apparatus for tunneling data using a single simulated stateful TCP connection
US20060104288A1 (en) * 2004-11-16 2006-05-18 Wai Yim Method and apparatus for tunneling data using a single simulated stateful TCP connection
US20060200517A1 (en) * 2005-03-03 2006-09-07 Steve Nelson Method and apparatus for real time multi-party conference document copier
US20100271976A1 (en) * 2005-04-22 2010-10-28 Cisco Technology, Inc. Techniques for encapsulating point to point (ppp) over ethernet frames
US8204080B2 (en) * 2005-04-22 2012-06-19 Cisco Technology, Inc. Techniques for encapsulating point to point (PPP) over Ethernet frames
US7525972B2 (en) * 2005-04-22 2009-04-28 Cisco Technology, Inc. Techniques for encapsulating point to point protocol (PPP) over Ethernet frames
US20060239298A1 (en) * 2005-04-22 2006-10-26 Cisco Technology Inc. Techniques for encapsulating point to point protocol (PPP) over Ethernet frames
WO2006115881A3 (en) * 2005-04-22 2007-10-11 Cisco Tech Inc Techniques for encapsulating point to point protocol (ppp) over ethernet frames
US20070285501A1 (en) * 2006-06-09 2007-12-13 Wai Yim Videoconference System Clustering
KR100939638B1 (en) 2008-09-25 2010-01-29 에스케이씨앤씨 주식회사 Improved TCP Transmission Method Suitable for Embedded system
US20110321039A1 (en) * 2010-06-29 2011-12-29 International Business Machines Corporation Virtual network packet transfer size manager
US8832685B2 (en) * 2010-06-29 2014-09-09 International Business Machines Corporation Virtual network packet transfer size manager
US20130016724A1 (en) * 2011-07-17 2013-01-17 Broadcom Corporation Link layer preemption
US9166917B2 (en) * 2011-07-17 2015-10-20 Broadcom Corporation Link layer preemption
US20140056140A1 (en) * 2012-08-22 2014-02-27 Lockheed Martin Corporation Terminated transmission control protocol tunnel
US8837289B2 (en) * 2012-08-22 2014-09-16 Lockheed Martin Corporation Terminated transmission control protocol tunnel
US9419851B1 (en) * 2013-08-13 2016-08-16 Ca, Inc. Application transaction tracking across network boundaries
US11048535B2 (en) * 2016-12-21 2021-06-29 Tencent Technology (Shenzhen) Company Limited Method and apparatus for transmitting data packet based on virtual machine

Also Published As

Publication number Publication date
US20020124095A1 (en) 2002-09-05
EP1364290A1 (en) 2003-11-26
WO2002071235A1 (en) 2002-09-12
EP1364290A4 (en) 2008-09-10

Similar Documents

Publication Publication Date Title
US20020147826A1 (en) Apparatus and method for sending point-to-point protocol over ethernet
CA2311114C (en) Quality of service (qos) enhancement to multilink point-to-point protocol (ppp)
US7286536B2 (en) Method and system for early header compression
US7804780B2 (en) Receiving and transmitting devices for providing fragmentation at a transport level along a transmission path
US7042907B2 (en) Packet transfer apparatus and method
US7483376B2 (en) Method and apparatus for discovering path maximum transmission unit (PMTU)
US7443845B2 (en) Apparatus and method for a lightweight, reliable, packet-based transport protocol
US7526577B2 (en) Multiple offload of network state objects with support for failover events
JP3967548B2 (en) Link configuration method and apparatus
US7742454B2 (en) Network performance by dynamically setting a reassembly timer based on network interface
US6845105B1 (en) Method and apparatus for maintaining sequence numbering in header compressed packets
EP1678909B1 (en) Method, system and article for dynamic real-time stream aggregation in a network
JP3863334B2 (en) Information transfer method, communication apparatus, and data communication system
US20070076618A1 (en) IP communication device and IP communication system therefor
US7480301B2 (en) Method, system and article for improved TCP performance during retransmission in response to selective acknowledgement
US20070027991A1 (en) TCP isolation with semantic processor TCP state machine
US7761508B2 (en) Access device-based fragmentation and interleaving support for tunneled communication sessions
CN111865940A (en) Transmission optimization method and device
US20050100010A1 (en) Method, system and article for router-assisted fast processing of packet termination in hosts
WO2008003218A1 (en) Method, apparatus and system for information transmitting between devices in ethernet
US20050038899A1 (en) Method, system and article for client application control of network transmission loss tolerance
US8583822B2 (en) Method and system for minimum frame size support for a communication protocol encapsulated over Ethernet
EP4333397A1 (en) Packet processing method and system, and network device
Snyder et al. Rethinking the NTCIP Design and Protocols-Analyzing the Issues
Genkov An algorithm and software for finding proper packet size in an IPv6 network using double connection

Legal Events

Date Code Title Description
AS Assignment

Owner name: NEXLAND, INC., FLORIDA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SULTAN, DANIEL;REEL/FRAME:013877/0222

Effective date: 20030321

AS Assignment

Owner name: SYMANTEC CORPORATION, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NEXLAND, INC.;REEL/FRAME:014275/0046

Effective date: 20030924

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION