[go: up one dir, main page]

WO2002009370A1 - Systems and methods for transmitting data packets - Google Patents

Systems and methods for transmitting data packets Download PDF

Info

Publication number
WO2002009370A1
WO2002009370A1 PCT/US2000/040576 US0040576W WO0209370A1 WO 2002009370 A1 WO2002009370 A1 WO 2002009370A1 US 0040576 W US0040576 W US 0040576W WO 0209370 A1 WO0209370 A1 WO 0209370A1
Authority
WO
WIPO (PCT)
Prior art keywords
data
sequence number
segment
receiving device
transmitting
Prior art date
Application number
PCT/US2000/040576
Other languages
French (fr)
Inventor
Shrikumar Hariharasubrahmanian
Original Assignee
Shrikumar Hariharasubrahmanian
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 Shrikumar Hariharasubrahmanian filed Critical Shrikumar Hariharasubrahmanian
Priority to AU77570/00A priority Critical patent/AU7757000A/en
Publication of WO2002009370A1 publication Critical patent/WO2002009370A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/06Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/1607Details of the supervisory signal
    • H04L1/1642Formats specially adapted for sequence numbers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1809Selective-repeat protocols
    • 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/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/324Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the data link layer [OSI layer 2], e.g. HDLC
    • 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/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]

Definitions

  • the present invention relates generally to networks and, more particularly, to systems and methods for transmitting data packets in a network.
  • Communication networks permit communication devices, such as personal computers, servers, laptops, personal digital assistants (PDAs), and other similar devices, to communicate with one another.
  • PDAs personal digital assistants
  • household appliances have begun including micro-controllers and/or microcomputers that allow these appliances to communicate over a communication network, such as the Internet.
  • Communication over these networks is often governed by a packetization protocol and a corresponding packet exchange protocol that specifies how the communication devices on the network must operate under various circumstances. These protocols are specified under the relevant standards and are applicable to the domains in which the communication devices operate.
  • Packetization and packet exchange protocols usually require that a communication device involved in data communications transmit a data file as a series of discrete packets.
  • a conventional communication device must typically store various record information associated with the transmitted data packet in its local memory. For example, the communication device may store a pointer in its local memory indicating what portion of the data file has been sent. This communication device may then use the pointer information to determine what portion of the file to transmit in the next packet.
  • storing pointer information in this manner requires that the communication device have a large amount of local memory.
  • Some communication devices such as mini-computers, micro-controllers, and microcomputers, lack sufficient local memory to store the pointer information associated with transmitting data packets over a packet-based network. These devices, therefore, often associate themselves as slave devices to one or more host computers that contain the resources to perform operations on their behalf. For example, the host computers may store the file pointer information for the slave devices and transmit this information to the slave devices when required. Such arrangements can result in delays in the transmission of the packets and increase the cost of connecting the devices to the communication network. Therefore, there exists a need for systems and methods that enable communication devices with limited memory capacity to communicate over a network.
  • a method for transmitting data as a number of segments in separate packets where each packet includes a sequence number field.
  • the method includes partitioning the sequence number field into portions and generating a sequence number corresponding to the portions, where at least one portion of the sequence number identifies a particular segment of the data.
  • the method also includes transmitting a data packet including a segment of the data and the sequence number to a receiving device and receiving an acknowledgement packet from the receiving device.
  • the acknowledgement packet including an acknowledgment sequence number.
  • the method further includes determining a next segment of the data to transmit based on the acknowledgment sequence number.
  • a system for transmitting data in a network includes a number of segments transmitted in separate packets.
  • the system includes a memory configured to store instructions and a processor configured to execute the instructions.
  • the instructions cause the processor to generate a sequence number including multiple portions, at least one portion indicating a particular segment of the data.
  • the instructions also cause the processor to transmit a data packet including a segment of the data and the sequence number to a receiving device and receive an acknowledgement packet from the receiving device.
  • the acknowledgement packet includes an acknowledgment sequence number.
  • the instructions further cause the processor to determine a next segment of the data to transmit based on the acknowledgment sequence number.
  • a computer-readable medium that stores instructions executable by one or more processors.
  • the instructions cause the processor to generate at least one portion of a sequence number based on processing to be performed by a receiving device and to generate at least one other portion based on a relevant protocol specification.
  • the instructions also cause the processor to transmit a data packet including a data segment and the sequence number to a receiving device.
  • a method for transmitting a data stream in a number of discrete packets is provided, where each packet includes a segment of the data stream and a sequence number field.
  • the method includes partitioning the sequence number field into portions.
  • the method also includes generating a sequence number corresponding to the portions, where at least one portion identifies a particular segment of the data stream.
  • the method further includes transmitting a data packet including a segment of the data stream and the sequence number to a receiving device.
  • a device for transmitting a data stream in a number of discrete packets includes a segment of the data stream and at least one header field.
  • the device includes logic configured to partition the header field into a plurality of subf ⁇ elds.
  • the device also includes logic configured to generate a value for the header field in accordance with a transmission control protocol, where at least one subfield identifies a particular segment of the data stream.
  • the device further includes logic configured to transmit a data packet including a segment of the data stream and the header field to a receiving device.
  • Fig. 1 illustrates an exemplary network in which systems and methods consistent with the present invention may be implemented
  • Fig 2 illustrates an exemplary configuration of a communication device of Fig. 1 in an implementation consistent with the present invention
  • Fig. 3 illustrates an exemplary configuration of a network peer of Fig. 1 in an implementation consistent with the present invention
  • Fig. 4 illustrates exemplary processing, consistent with the present invention, for transmitting data in a network
  • Fig. 5 illustrates an exemplary structure of a Transmission Control Protocol packet
  • Fig. 6 illustrates an exemplary sequence number field in an implementation consistent with the present invention.
  • Systems and methods consistent with the present invention permit a communication device having restricted memory resources to transmit data packets in a network.
  • the communication device transmits the data packets without storing various transmission control record information in its local memory.
  • the communication device relies upon peer devices to perform much of the record keeping associated with transmitting data streams as a series of discrete packets.
  • the network 100 may include communication devices 110 and network peers 120 connected to a network 130. Three communication devices 110 and three network peers 120 have been shown in Fig. 1 for simplicity. In practice, the network 100 may include more or less communication devices 110 and network peers 120.
  • the network 130 may include one or more data communication networks, such as the Internet, an intranet, a wide area network, or the like.
  • the network 130 includes a packet-based network that operates according to a communications protocol, such as a Transmission Control Protocol and all related protocols, as specified in
  • the communication devices 110 may include computer devices, electronic devices, or similar devices with or without extensive computational and/or memory resources.
  • the communication devices 110 may connect to the network 130 via wired, wireless, or optical communication paths.
  • the communication devices 110 connect to the network 130 using a data link protocol, such as the Serial Line Internet Protocol, Ethernet, or Token Ring.
  • the network peers 120 may include computer devices, such as personal computers, servers, laptops, personal digital assistants (PDAs), etc. that connect to the network 130 via wired, wireless, or optical communication paths.
  • the network peers 120 communicate with the communication devices 110 via data packetized in accordance with the relevant transmission control protocol, such as the Transmission Control
  • the network peers 120 may communicate with the communication devices 110 via a virtual circuit, a connection, or a socket through the network 130.
  • a communication device 110 may perform the role of a network peer 120 at various times in the same conversation or different conversations and vice versa.
  • communication devices 110 may perform the functions described below as being performed by network peers 120.
  • network peers 120 may perform the functions described as being performed by communication devices 110.
  • the communication device 110 may include a bus 210, a processor 220, a local memory 230, an input device 240, an output device 250, and a communication interface 260.
  • the bus 210 permits communication among the components of the communication device 110. It should be understood that additional busses (not shown) may connect one or more of the components of communication device 110.
  • the processor 220 may be any type of conventional processor or microprocessor that interprets and executes instructions.
  • the local memory 230 may be a large or small capacity memory device, such as a random access memory (RAM), a read only memory (ROM), or another type of dynamic or static storage device that stores information and instructions for processing by the processor 220.
  • the input device 240 may include any conventional mechanism that permits a user to input information into the communication device 110, such as a keyboard, a keypad, a mouse, a microphone, data acquisition sensors, etc.
  • the output device 250 may include any conventional mechanism that outputs information to the user, including a display, a speaker, transducers, actuators, etc.
  • the communication interface 260 may include any transceiver-like mechanism that enables the communication device 110 to communicate with other devices and systems.
  • the communication interface 260 may include mechanisms for communicating via a network, such as the network 130.
  • Communication device 110 consistent with the present invention, may transmit a data file as a number of discrete packets over a network, such as network 130.
  • communication device 110 transmits data without storing various record information, as described in more detail below.
  • the communication device 110 performs these tasks in response to processor 220 executing sequences of instructions contained in a computer-readable medium, such as the memory 230.
  • a computer-readable medium may include one or more memory devices and/or carrier waves.
  • the instructions may be read into memory 230 from another computer- readable medium or from another device via the communication interface 260. Execution of the sequences of instructions contained in memory 230 causes processor
  • the exemplary network peer 120 includes a bus 310, a processor 320, a main memory 330, a ROM 340, a storage device 350, an input device 360, an output device 370, and a communication interface 380.
  • the bus 310 permits communication among the components of the network peer 120. It should be understood that additional busses (not shown) may connect one or more of the components of network peer 120.
  • the processor 320 may include any type of conventional processor or microprocessor that interprets and executes instructions.
  • the main memory 330 may include a RAM or another type of dynamic storage device that stores information and instructions for execution by the processor 320. Main memory 330 may also be used to store temporary variables or other intermediate information during execution of instructions by processor 320.
  • ROM 340 may include a conventional ROM device and/or another type of static storage device that stores static information and instructions for processor 320.
  • the storage device 350 may include a magnetic disk or optical disk and its corresponding drive and/or some other type of magnetic or optical recording medium and its corresponding drive for storing information and/or instructions.
  • the input device 360 may include any conventional mechanism that permits an operator to input information to the network peer device 120, such as a keyboard, a mouse, a microphone, a pen, voice recognition and/or biometric mechanisms, data acquisition sensors, etc.
  • the output device 370 may include any conventional mechanism that outputs information to the operator, including a display, a printer, a speaker, a transducer, an actuator, etc.
  • the communication interface 380 may include any transceiver-like mechanism that enables the network peer 120 to communicate with other devices and/or systems, such as communication devices 110.
  • the communication interface 380 may include a modem or an Ethernet interface to a network.
  • communication interface 380 may include other mechanisms for communicating via a network, such as network 130.
  • the network peer 120 performs the functions described below in response to processor 320 executing sequences of instructions contained in a computer-readable medium, such as memory 330.
  • the instructions may be read into memory 330 from another computer-readable medium, such as a storage device 350, or from a separate device via communication interface 380.
  • Execution of the sequences of instructions contained in memory 330 causes processor 320 to perform the process steps that will be described hereafter.
  • hard-wired circuitry may be used in place of or in combination with software instructions to implement the present invention.
  • FIG. 4 illustrates an exemplary process, consistent with the present invention, for transmitting data via a network.
  • Processing begins when a communication device, such as communication device 110 (Fig. 1), wishes to transmit a data stream via network 130 [step 410].
  • the data stream may represent a file or any data message destined for a network peer, such as network peer 120.
  • the communication device 110 in an implementation consistent with the present invention, may have a restricted memory capacity. As a result, the communication device 110 may be incapable of performing the necessary record keeping associated with transmitting a file via a particular protocol, such as Transmission Control
  • a sending device transmits data streams, such as data files, as a number of separate packets.
  • Fig. 5 illustrates an exemplary data packet 500 consistent with the Transmission Control Protocol.
  • the Transmission Control Protocol packet 500 includes a source port field, a destination port field, a sequence number field, an acknowledge number field, a header length field, a reserved field, a flags field, a window size field, a checksum field, an urgent pointer field, an options field and a data field.
  • the source port and destination port fields include data that identify the source and destination of the data packet.
  • the sequence number field includes data that identifies the first byte of data in the packet.
  • the acknowledge number field includes data that identifies the next byte of data that the source expects to receive from the destination.
  • the header length field includes data that identifies the length of the header.
  • the reserved field may be used for future expansions.
  • the flags field may include several flags, such as Urgent, Acknowledge, Push, Reset, Synchronize, and Finish.
  • the Urgent flag indicates whether the data in the urgent pointer field is valid.
  • the Acknowledge flag indicates whether the data in the acknowledgement number field is valid.
  • the Push flag indicates whether the accompanying data should be passed to the application at the destination in an expedited manner.
  • the Reset flag indicates whether the connection should be reset.
  • the Synchronize flag is used to establish an initial agreement on the sequence numbers.
  • the Finish flag indicates whether the source has finished sending data.
  • the window size field includes data that identifies the amount of space the destination has available for storage of unacknowledged data.
  • the checksum field includes a checksum value that may cover both the header and the data stored in the packet.
  • the urgent pointer field includes data that identifies whether this packet should take priority over the normal data stream.
  • the options field may contain any of a number of predefined options.
  • the data field includes the actual payload of the data packet 500.
  • the length of the data field may vary based on a number of factors, such as the maximum expected file size, network operating parameters, etc.
  • a conventional sending device stores transmission control records associated with the transmitted packet.
  • the transmission control records typically include file offset information indicating what portion of the file has been sent.
  • the file offset information may be stored as an offset pointer in local memory that enables the sending device to know which portion of the data file to transmit next.
  • the transmission control records also typically include the Transmission Control Protocol sequence number transmitted with the packet. The conventional sending device stores such transmission control records for each connection it maintains.
  • the communication device 110 avoids storing this record information by taking advantage of record keeping performed by peer devices, such as network peer 120, as described in more detail below.
  • the communication device 110 partitions the sequence number field into a number of portions [step 420].
  • the communication device 110 may partition the 32-bit sequence number field used in a conventional Transmission Control Protocol data packet, such as packet 500, into a number of portions.
  • Fig. 6 illustrates an exemplary sequence number field 600 partitioned in a manner consistent with the present invention.
  • the sequence number field 600 may be divided into fields 610, 620 and 630. In alternative implementations of the present invention, the sequence number field 600 may be divided into different numbers of fields.
  • Field 630 may represent the least significant bits and field 610 may represent the most significant bits of sequence number field 600.
  • the size of fields 610, 620 and 630 may be based on a number of factors, such as the packet size used by communication device 110 to transmit data, maximum expected file sizes, etc.
  • communication device 110 transmits data packets having 1 Kbyte data payloads. It should be understood that 1 Kbyte represents 2 10 bits or 1024 bits of data.
  • the communication device 110 may set the size of field 630 to be 10 bits in length. That is, the size of field 630 may be set to n bits when the length of the data segments transmitted is 2" bits.
  • the communication device 110 may take advantage of some conventional and predictable processing performed by the network peer 120, as described in more detail below. It should be understood, however, that other correlations between both the number and size of the fields in sequence number field 600 and the size of the data segments transmitted via network 130 may be made in other implementations consistent with the present invention. Based on the guidance given herein, one of ordinary skill in this art would be able to set the various field sizes in the sequence number field 600 to take advantage of the conventional record keeping performed by peer devices, enabling the communication device 110 to avoid storing transmission control record information in its local memory.
  • the communication device 110 then generates the actual sequence number [step 430].
  • the communication device 110 consistent with the present invention, generates the actual values for fields 610 and 630 in a manner necessary to comply with the relevant protocol specification. For example, in a Transmission Control Protocol network, the communication device 110 generates the values for fields 610 and 630 in a manner such that sequence number field 600 complies with the protocol specification.
  • the actual value for field 620 may be chosen to represent a particular offset associated with a particular segment of the data file.
  • communication device 110 chooses the value for field 620 to take advantage of predictable processing performed by a network peer 120.
  • the communication device 110 may choose the value in field 620 to be "0" when transmitting the first 1 Kbyte segment in the data file.
  • the "0" indicates that the data segment is the initial 1 Kbyte segment in the data file, i.e., the data segment is offset zero bytes from the beginning of the file.
  • the communication device 110 then transmits the packet to network peer 120 [step 430].
  • the communication device 110 receives the acknowledgement message transmitted via network 130.
  • the communication device 110 then examines the acknowledgement sequence number and identifies the file offset information [step 450].
  • the communication device 110 determines that the value in field 620 associated with the acknowledgment sequence number is "1.” This value of "1" indicates that communication device 110 would send the first offset of the 20 Kbyte file next (i.e., the second Kbyte of the data file).
  • the communication device 110 then transmits the second Kbyte of data from the data file to the network peer 120 along with the new sequence number [step 460].
  • communication device 110 relies upon the network peer 120 to perform the processing required to identify the next segment of data to transmit. In this manner, communication device 110 may communicate with multiple peer devices without having to store transmission control records, such as local pointers identifying file offset information, in local memory 230 for any of the data conversations in which communication device 110 may be involved. This saves considerable memory and enables a processing device with limited memory to transmit data packets in a network.
  • Systems and methods consistent with the present invention enable a communication device having limited memory to transmit data over a packet-based network.
  • the communication device advantageously relies upon network peers to perform much of the record keeping associated with transmitting a data file as a number of discrete packets, thereby saving the limited memory space for other functions.
  • sequence number field has been illustrated as being divided into three portions with the middle portion used for identifying the segment of the data file. In alternative implementations, the sequence number field may be divided into other numbers of portions and the portion used to identify the segment of the data file may be represented by a different portion.
  • the field being manipulated to convey file offset information may be a field other than a sequence number field.
  • another field in a data packet may be manipulated to convey file offset information, while still satisfying the constraints associated with that field in the relevant protocol.
  • the communication device 110 transmits the packet to a network peer 120 and after some predictable processing of that field by the network peer 120, communication device 110 is able to identify the file offset information.
  • the data stream being transmitted has been described as a data file.
  • the data stream may include data messages, application generated data or any other data stream that may be broken up into segments and transmitted over a packet-based network.
  • a mathematical function may be used instead of manipulating various fields into subfields to convey file offset information.
  • communication device 110 may use a function F(a,b) to generate a particular field in a data packet, where "b" is the information of interest and "a” is the portion that assures compliance with the protocol requirements, such that F(a,b) is fully compliant with the relevant protocol.
  • the network peer 120 then receives the packet including the information generated from F(a,b) and applies some function "G" to generate G(F(a,b)).
  • the communication device 110 applies a reverse process, i.e., applies a function GFInverse ( ) to G(F(a,b)) from the acknowledgement message to identify the information of interest "b."
  • the information b may be a modified version of the data sent to the network peer 120.
  • the function F(a,b,c) may be a simple function that concatenates the bit fields a, b and c (e.g., fields 610, 620 and 630 in Fig. 6).
  • the function GFInverse ( ) may be a corresponding function that extracts bitfield b. In alternative implementations, however, other mathematical functions may be used.
  • a device such as communication device 110, may use any mathematical function to transmit information to a peer device, such as network peer 120, to take advantage of predictable processing performed by the network peer 120. The communication device 110 may then extract particular information of interest from an acknowledgement message transmitted back to the communication device 110. In this manner, the communication device 110 is able to save valuable local memory space.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Communication Control (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

Methods and systems for transmitting data packets enable a communication device (110) having limited memory to transmit data files in a packet-based network (410). The communication device partitions the sequence number field (600) transmitted with a data packet into multiple portions (420). The communication device then generates a sequence number corresponding to the portions, where at least one portion identifies a particular segment of the data file (430). The communication device then transmits a data packet including a segment of a data file and the sequence number to a receiving device (120). When the communication device receives the acknowledgement packet from the receiving device, the communication device may determine which segment of the data file to transmit next (460).

Description

SYSTEMS AND METHODS FOR TRANSMITTING DATA PACKETS
FIELD OF THE INVENTION The present invention relates generally to networks and, more particularly, to systems and methods for transmitting data packets in a network.
BACKGROUND OF THE INVENTION
Communication networks permit communication devices, such as personal computers, servers, laptops, personal digital assistants (PDAs), and other similar devices, to communicate with one another. Recently, household appliances have begun including micro-controllers and/or microcomputers that allow these appliances to communicate over a communication network, such as the Internet.
Communication over these networks is often governed by a packetization protocol and a corresponding packet exchange protocol that specifies how the communication devices on the network must operate under various circumstances. These protocols are specified under the relevant standards and are applicable to the domains in which the communication devices operate.
Packetization and packet exchange protocols usually require that a communication device involved in data communications transmit a data file as a series of discrete packets. A conventional communication device must typically store various record information associated with the transmitted data packet in its local memory. For example, the communication device may store a pointer in its local memory indicating what portion of the data file has been sent. This communication device may then use the pointer information to determine what portion of the file to transmit in the next packet. When a number of data conversations are occurring at the same time, storing pointer information in this manner requires that the communication device have a large amount of local memory.
Some communication devices, such as mini-computers, micro-controllers, and microcomputers, lack sufficient local memory to store the pointer information associated with transmitting data packets over a packet-based network. These devices, therefore, often associate themselves as slave devices to one or more host computers that contain the resources to perform operations on their behalf. For example, the host computers may store the file pointer information for the slave devices and transmit this information to the slave devices when required. Such arrangements can result in delays in the transmission of the packets and increase the cost of connecting the devices to the communication network. Therefore, there exists a need for systems and methods that enable communication devices with limited memory capacity to communicate over a network.
SUMMARY OF THE INVENTION Systems and methods consistent with the present invention address this and other needs by enabling a communication device to transmit data packets without requiring a large local memory to store various record information.
In accordance with the purpose of the invention as embodied and broadly described herein, a method for transmitting data as a number of segments in separate packets is provided, where each packet includes a sequence number field. The method includes partitioning the sequence number field into portions and generating a sequence number corresponding to the portions, where at least one portion of the sequence number identifies a particular segment of the data. The method also includes transmitting a data packet including a segment of the data and the sequence number to a receiving device and receiving an acknowledgement packet from the receiving device. The acknowledgement packet including an acknowledgment sequence number. The method further includes determining a next segment of the data to transmit based on the acknowledgment sequence number.
In another implementation consistent with the present invention, a system for transmitting data in a network is provided. The data includes a number of segments transmitted in separate packets. The system includes a memory configured to store instructions and a processor configured to execute the instructions. The instructions cause the processor to generate a sequence number including multiple portions, at least one portion indicating a particular segment of the data. The instructions also cause the processor to transmit a data packet including a segment of the data and the sequence number to a receiving device and receive an acknowledgement packet from the receiving device. The acknowledgement packet includes an acknowledgment sequence number. The instructions further cause the processor to determine a next segment of the data to transmit based on the acknowledgment sequence number.
In yet another implementation consistent with the present invention, a computer-readable medium that stores instructions executable by one or more processors is provided. The instructions cause the processor to generate at least one portion of a sequence number based on processing to be performed by a receiving device and to generate at least one other portion based on a relevant protocol specification. The instructions also cause the processor to transmit a data packet including a data segment and the sequence number to a receiving device. In still another implementation consistent with the present invention, a method for transmitting a data stream in a number of discrete packets, is provided, where each packet includes a segment of the data stream and a sequence number field. The method includes partitioning the sequence number field into portions. The method also includes generating a sequence number corresponding to the portions, where at least one portion identifies a particular segment of the data stream. The method further includes transmitting a data packet including a segment of the data stream and the sequence number to a receiving device.
In a further implementation consistent with the present invention, a device for transmitting a data stream in a number of discrete packets is provided. Each packet includes a segment of the data stream and at least one header field. The device includes logic configured to partition the header field into a plurality of subfϊelds. The device also includes logic configured to generate a value for the header field in accordance with a transmission control protocol, where at least one subfield identifies a particular segment of the data stream. The device further includes logic configured to transmit a data packet including a segment of the data stream and the header field to a receiving device.
BRIEF DESCRIPTION OF THE DRAWINGS The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate an embodiment of the invention and, together with the description, explain the invention. In the drawings, Fig. 1 illustrates an exemplary network in which systems and methods consistent with the present invention may be implemented;
Fig 2 illustrates an exemplary configuration of a communication device of Fig. 1 in an implementation consistent with the present invention; Fig. 3 illustrates an exemplary configuration of a network peer of Fig. 1 in an implementation consistent with the present invention;
Fig. 4 illustrates exemplary processing, consistent with the present invention, for transmitting data in a network;
Fig. 5 illustrates an exemplary structure of a Transmission Control Protocol packet; and
Fig. 6 illustrates an exemplary sequence number field in an implementation consistent with the present invention.
DETAILED DESCRIPTION The following detailed description of the invention refers to the accompanying drawings. The same reference numbers in different drawings identify the same or similar elements. Also, the following detailed description does not limit the invention. Instead, the scope of the invention is defined by the appended claims.
Systems and methods consistent with the present invention permit a communication device having restricted memory resources to transmit data packets in a network. The communication device transmits the data packets without storing various transmission control record information in its local memory. The communication device relies upon peer devices to perform much of the record keeping associated with transmitting data streams as a series of discrete packets.
EXEMPLARY NETWORK Fig. 1 illustrates an exemplary network 100 in which systems and methods consistent with the present invention may be implemented. The network 100 may include communication devices 110 and network peers 120 connected to a network 130. Three communication devices 110 and three network peers 120 have been shown in Fig. 1 for simplicity. In practice, the network 100 may include more or less communication devices 110 and network peers 120. The network 130 may include one or more data communication networks, such as the Internet, an intranet, a wide area network, or the like. For example, in one implementation consistent with the present invention, the network 130 includes a packet-based network that operates according to a communications protocol, such as a Transmission Control Protocol and all related protocols, as specified in
"Requirements for Internet Hosts — Communication Layers," RFC1122, ftp://ftp.isi.edu/in-notes/rfcll22.txt, October 1989.
The communication devices 110 may include computer devices, electronic devices, or similar devices with or without extensive computational and/or memory resources. The communication devices 110 may connect to the network 130 via wired, wireless, or optical communication paths. In one implementation consistent with the present invention, the communication devices 110 connect to the network 130 using a data link protocol, such as the Serial Line Internet Protocol, Ethernet, or Token Ring. The network peers 120 may include computer devices, such as personal computers, servers, laptops, personal digital assistants (PDAs), etc. that connect to the network 130 via wired, wireless, or optical communication paths. According to an implementation consistent with the present invention, the network peers 120 communicate with the communication devices 110 via data packetized in accordance with the relevant transmission control protocol, such as the Transmission Control
Protocol. The network peers 120 may communicate with the communication devices 110 via a virtual circuit, a connection, or a socket through the network 130.
It should be noted that a communication device 110 may perform the role of a network peer 120 at various times in the same conversation or different conversations and vice versa. In other words, communication devices 110 may perform the functions described below as being performed by network peers 120. Similarly, network peers 120 may perform the functions described as being performed by communication devices 110.
EXEMPLARY COMMUNICATION DEVICE Fig. 2 illustrates an exemplary communication device 110 consistent with an implementation of the present invention. The communication device 110 may include a bus 210, a processor 220, a local memory 230, an input device 240, an output device 250, and a communication interface 260. The bus 210 permits communication among the components of the communication device 110. It should be understood that additional busses (not shown) may connect one or more of the components of communication device 110.
The processor 220 may be any type of conventional processor or microprocessor that interprets and executes instructions. The local memory 230 may be a large or small capacity memory device, such as a random access memory (RAM), a read only memory (ROM), or another type of dynamic or static storage device that stores information and instructions for processing by the processor 220.
The input device 240 may include any conventional mechanism that permits a user to input information into the communication device 110, such as a keyboard, a keypad, a mouse, a microphone, data acquisition sensors, etc. The output device 250 may include any conventional mechanism that outputs information to the user, including a display, a speaker, transducers, actuators, etc. The communication interface 260 may include any transceiver-like mechanism that enables the communication device 110 to communicate with other devices and systems. For example, the communication interface 260 may include mechanisms for communicating via a network, such as the network 130. Communication device 110, consistent with the present invention, may transmit a data file as a number of discrete packets over a network, such as network 130. In one implementation, communication device 110 transmits data without storing various record information, as described in more detail below. The communication device 110 performs these tasks in response to processor 220 executing sequences of instructions contained in a computer-readable medium, such as the memory 230. A computer-readable medium may include one or more memory devices and/or carrier waves.
The instructions may be read into memory 230 from another computer- readable medium or from another device via the communication interface 260. Execution of the sequences of instructions contained in memory 230 causes processor
220 to perform processes that will be described later. Alternatively, hardwired circuitry may be used in place of or in combination with software instructions to implement processes consistent with the present invention. For example, the functions performed by the components of communication device 110 may be fully implemented via a combination of logic gates formed in silicon. Thus, the present invention is not limited to any specific combination of hardware circuitry and software.
EXEMPLARY NETWORK PEER Fig. 3 illustrates an exemplary network peer 120 consistent with the present invention. The exemplary network peer 120 includes a bus 310, a processor 320, a main memory 330, a ROM 340, a storage device 350, an input device 360, an output device 370, and a communication interface 380. The bus 310 permits communication among the components of the network peer 120. It should be understood that additional busses (not shown) may connect one or more of the components of network peer 120.
The processor 320 may include any type of conventional processor or microprocessor that interprets and executes instructions. The main memory 330 may include a RAM or another type of dynamic storage device that stores information and instructions for execution by the processor 320. Main memory 330 may also be used to store temporary variables or other intermediate information during execution of instructions by processor 320. ROM 340 may include a conventional ROM device and/or another type of static storage device that stores static information and instructions for processor 320. The storage device 350 may include a magnetic disk or optical disk and its corresponding drive and/or some other type of magnetic or optical recording medium and its corresponding drive for storing information and/or instructions. The input device 360 may include any conventional mechanism that permits an operator to input information to the network peer device 120, such as a keyboard, a mouse, a microphone, a pen, voice recognition and/or biometric mechanisms, data acquisition sensors, etc. The output device 370 may include any conventional mechanism that outputs information to the operator, including a display, a printer, a speaker, a transducer, an actuator, etc. The communication interface 380 may include any transceiver-like mechanism that enables the network peer 120 to communicate with other devices and/or systems, such as communication devices 110. For example, the communication interface 380 may include a modem or an Ethernet interface to a network. Alternatively, communication interface 380 may include other mechanisms for communicating via a network, such as network 130.
The network peer 120 performs the functions described below in response to processor 320 executing sequences of instructions contained in a computer-readable medium, such as memory 330. The instructions may be read into memory 330 from another computer-readable medium, such as a storage device 350, or from a separate device via communication interface 380. Execution of the sequences of instructions contained in memory 330 causes processor 320 to perform the process steps that will be described hereafter. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the present invention. For example, the functions performed by the components of network peer
120 may be fully implemented via a combination of logic gates formed in silicon. Thus, the present invention is not limited to any specific combination of hardware circuitry and software.
EXEMPLARY PROCESSING Fig. 4 illustrates an exemplary process, consistent with the present invention, for transmitting data via a network. Processing begins when a communication device, such as communication device 110 (Fig. 1), wishes to transmit a data stream via network 130 [step 410]. The data stream may represent a file or any data message destined for a network peer, such as network peer 120. As described above, the communication device 110, in an implementation consistent with the present invention, may have a restricted memory capacity. As a result, the communication device 110 may be incapable of performing the necessary record keeping associated with transmitting a file via a particular protocol, such as Transmission Control
Protocol. For example, in a conventional Transmission Confrol Protocol network, a sending device transmits data streams, such as data files, as a number of separate packets. Fig. 5 illustrates an exemplary data packet 500 consistent with the Transmission Control Protocol. The Transmission Control Protocol packet 500 includes a source port field, a destination port field, a sequence number field, an acknowledge number field, a header length field, a reserved field, a flags field, a window size field, a checksum field, an urgent pointer field, an options field and a data field. The source port and destination port fields include data that identify the source and destination of the data packet. The sequence number field includes data that identifies the first byte of data in the packet. The acknowledge number field includes data that identifies the next byte of data that the source expects to receive from the destination.
The header length field includes data that identifies the length of the header. The reserved field may be used for future expansions. The flags field may include several flags, such as Urgent, Acknowledge, Push, Reset, Synchronize, and Finish. The Urgent flag indicates whether the data in the urgent pointer field is valid. The Acknowledge flag indicates whether the data in the acknowledgement number field is valid. The Push flag indicates whether the accompanying data should be passed to the application at the destination in an expedited manner. The Reset flag indicates whether the connection should be reset. The Synchronize flag is used to establish an initial agreement on the sequence numbers. The Finish flag indicates whether the source has finished sending data.
The window size field includes data that identifies the amount of space the destination has available for storage of unacknowledged data. The checksum field includes a checksum value that may cover both the header and the data stored in the packet. The urgent pointer field includes data that identifies whether this packet should take priority over the normal data stream.
The options field may contain any of a number of predefined options. The data field includes the actual payload of the data packet 500. The length of the data field may vary based on a number of factors, such as the maximum expected file size, network operating parameters, etc. When a packet is sent, a conventional sending device stores transmission control records associated with the transmitted packet. The transmission control records typically include file offset information indicating what portion of the file has been sent. The file offset information may be stored as an offset pointer in local memory that enables the sending device to know which portion of the data file to transmit next. The transmission control records also typically include the Transmission Control Protocol sequence number transmitted with the packet. The conventional sending device stores such transmission control records for each connection it maintains. When multiple data conversations occur simultaneously, storing such record information for each conversation would take a considerable amount of space in the local memory of a sending device, such as local memory 230. According to an exemplary implementation, the communication device 110 avoids storing this record information by taking advantage of record keeping performed by peer devices, such as network peer 120, as described in more detail below.
The communication device 110, consistent with the present invention, partitions the sequence number field into a number of portions [step 420]. For example, according to an exemplary implementation, the communication device 110 may partition the 32-bit sequence number field used in a conventional Transmission Control Protocol data packet, such as packet 500, into a number of portions.
Fig. 6 illustrates an exemplary sequence number field 600 partitioned in a manner consistent with the present invention. The sequence number field 600 may be divided into fields 610, 620 and 630. In alternative implementations of the present invention, the sequence number field 600 may be divided into different numbers of fields. Field 630 may represent the least significant bits and field 610 may represent the most significant bits of sequence number field 600. The size of fields 610, 620 and 630 may be based on a number of factors, such as the packet size used by communication device 110 to transmit data, maximum expected file sizes, etc.
Assume that communication device 110 transmits data packets having 1 Kbyte data payloads. It should be understood that 1 Kbyte represents 210 bits or 1024 bits of data. In this case, the communication device 110 may set the size of field 630 to be 10 bits in length. That is, the size of field 630 may be set to n bits when the length of the data segments transmitted is 2" bits. By setting field 630 to be 10 bits in this example, the communication device 110 may take advantage of some conventional and predictable processing performed by the network peer 120, as described in more detail below. It should be understood, however, that other correlations between both the number and size of the fields in sequence number field 600 and the size of the data segments transmitted via network 130 may be made in other implementations consistent with the present invention. Based on the guidance given herein, one of ordinary skill in this art would be able to set the various field sizes in the sequence number field 600 to take advantage of the conventional record keeping performed by peer devices, enabling the communication device 110 to avoid storing transmission control record information in its local memory.
The communication device 110 then generates the actual sequence number [step 430]. The communication device 110, consistent with the present invention, generates the actual values for fields 610 and 630 in a manner necessary to comply with the relevant protocol specification. For example, in a Transmission Control Protocol network, the communication device 110 generates the values for fields 610 and 630 in a manner such that sequence number field 600 complies with the protocol specification.
The actual value for field 620, however, may be chosen to represent a particular offset associated with a particular segment of the data file. In other words, unlike conventional devices transmitting data in a Transmission Control Protocol based network which generates the entire sequence number in accordance with the protocol specification, communication device 110 chooses the value for field 620 to take advantage of predictable processing performed by a network peer 120.
For example, suppose communication device 110 wishes to transmit a 20 Kbyte data file in 1 Kbyte data segments. In this case, the communication device 110 may choose the value in field 620 to be "0" when transmitting the first 1 Kbyte segment in the data file. The "0" indicates that the data segment is the initial 1 Kbyte segment in the data file, i.e., the data segment is offset zero bytes from the beginning of the file. The communication device 110 then transmits the packet to network peer 120 [step 430].
The network peer 120 receives the packet including sequence number 600. In accordance with the Transmission Control Protocol requirements, network peer 120 generates an acknowledgement message including the next expected sequence number [step 440]. That is, the network peer 120 receives the 1 Kbyte segment and, in accordance with Transmission Control Protocol requirements, increments the received sequence number by 1024. In this case, incrementing the received sequence number by 1024 is equivalent to incrementing field 620 by "1," since field 630 is 10 bits in length and 210 = 1024. The network peer 120 then transmits the acknowledgment message, including the acknowledgement sequence number, to the communication device 110 [step 440].
The communication device 110 receives the acknowledgement message transmitted via network 130. The communication device 110 then examines the acknowledgement sequence number and identifies the file offset information [step 450]. In this example, assuming that the communication device 110 transmitted a "0" in field 620 of the sequence number field 600, the communication device 110 determines that the value in field 620 associated with the acknowledgment sequence number is "1." This value of "1" indicates that communication device 110 would send the first offset of the 20 Kbyte file next (i.e., the second Kbyte of the data file). The communication device 110 then transmits the second Kbyte of data from the data file to the network peer 120 along with the new sequence number [step 460].
This process repeats until all of the data segments of the data file have been transmitted to the network peer 120. During the entire process associated with transmitting the data file, communication device 110 relies upon the network peer 120 to perform the processing required to identify the next segment of data to transmit. In this manner, communication device 110 may communicate with multiple peer devices without having to store transmission control records, such as local pointers identifying file offset information, in local memory 230 for any of the data conversations in which communication device 110 may be involved. This saves considerable memory and enables a processing device with limited memory to transmit data packets in a network.
Systems and methods consistent with the present invention enable a communication device having limited memory to transmit data over a packet-based network. The communication device advantageously relies upon network peers to perform much of the record keeping associated with transmitting a data file as a number of discrete packets, thereby saving the limited memory space for other functions. The foregoing description of exemplary embodiments of the present invention provides illustration and description, but is not intended to be exhaustive or to limit the invention to the precise form disclosed. Modifications and variations are possible in light of the above teachings or may be acquired from practice of the invention. For example, while a series of steps have been described with respect to Fig. 4, the order of the steps may vary in other implementations consistent with the present invention. It should also be understood that sequence number field has been illustrated as being divided into three portions with the middle portion used for identifying the segment of the data file. In alternative implementations, the sequence number field may be divided into other numbers of portions and the portion used to identify the segment of the data file may be represented by a different portion.
It should further be understood that in alternative implementations of the present invention, the field being manipulated to convey file offset information may be a field other than a sequence number field. For example, another field in a data packet may be manipulated to convey file offset information, while still satisfying the constraints associated with that field in the relevant protocol. In this case, the communication device 110 transmits the packet to a network peer 120 and after some predictable processing of that field by the network peer 120, communication device 110 is able to identify the file offset information. Further, the data stream being transmitted has been described as a data file. In other implementations of the present invention, the data stream may include data messages, application generated data or any other data stream that may be broken up into segments and transmitted over a packet-based network.
Additionally, in further alternative implementations of the present invention, instead of manipulating various fields into subfields to convey file offset information, a mathematical function may be used. For example, communication device 110 may use a function F(a,b) to generate a particular field in a data packet, where "b" is the information of interest and "a" is the portion that assures compliance with the protocol requirements, such that F(a,b) is fully compliant with the relevant protocol. The network peer 120 then receives the packet including the information generated from F(a,b) and applies some function "G" to generate G(F(a,b)). The network peer
120 then transmits the information from G(F(a,b)) back to the communication device 110 in an acknowledgement message. The communication device 110 applies a reverse process, i.e., applies a function GFInverse ( ) to G(F(a,b)) from the acknowledgement message to identify the information of interest "b." The information b may be a modified version of the data sent to the network peer 120. In the exemplary implementation described above in which a field is broken into subfields, the function F(a,b,c) may be a simple function that concatenates the bit fields a, b and c (e.g., fields 610, 620 and 630 in Fig. 6). The function GFInverse ( ) may be a corresponding function that extracts bitfield b. In alternative implementations, however, other mathematical functions may be used. In essence, a device, such as communication device 110, may use any mathematical function to transmit information to a peer device, such as network peer 120, to take advantage of predictable processing performed by the network peer 120. The communication device 110 may then extract particular information of interest from an acknowledgement message transmitted back to the communication device 110. In this manner, the communication device 110 is able to save valuable local memory space.
The scope of the invention is defined by the following claims and their equivalents.

Claims

WHAT IS CLAIMED IS:
1. A method for transmitting data as a number of segments in separate packets, each packet including a sequence number field, the method comprising: partitioning the sequence number field into a plurality of portions; generating a sequence number corresponding to the plurality of portions, at least one portion identifying a particular segment of the data; transmitting a data packet including a segment of the data and the sequence number to a receiving device; receiving an acknowledgement packet from the receiving device, the acknowledgement packet including an acknowledgment sequence number; and determining a next segment of the data to transmit based on the acknowledgment sequence number.
2. The method of claim 1, wherein the acknowledgement sequence number includes an incremented version of the at least one portion of the sequence number transmitted to the receiving device and wherein the determining includes: identifying the next segment to transmit based on the incremented version.
3. The method of claim 1, wherein the transmitting includes: transmitting the data packet using transmission control protocol/Internet protocol (TCP/IP).
4. The method of claim 1, further comprising: repeating the transmitting, receiving and determining for additional segments of the data file until all the segments of the data have been transmitted.
5. The method of claim 1, wherein the transmitting includes: transmitting the data packet without storing information identifying the segment being transmitted to the receiving device.
6. The method of claim 1, wherein the plurality of portions includes a least significant portion, wherein the partitioning includes: setting the length of the least significant portion based on the length of the segments transmitted.
7. The method of claim 6, wherein the setting includes: setting the length of the least significant portion to n bits when the length of the segments transmitted is 2n bits.
8. The method of claim 1, wherein the generating includes: generating the at least one portion of the sequence number based on predictable processing performed by the receiving device, and generating at least one other portion of the sequence number in accordance with a specification of a relevant protocol.
9. A system for transmitting data in a network, the data including a number of segments transmitted in separate packets, the system comprising: a memory configured to store instructions; and a processor configured to execute the instructions to: generate a sequence number including a plurality of portions, at least one portion indicating a particular segment of the data, transmit a data packet including a segment of the data and the sequence number to a receiving device, receive an acknowledgement packet from the receiving device, the acknowledgement packet including an acknowledgment sequence number, and determine a next segment of the data to transmit based on the acknowledgment sequence number.
10. The system of claim 9, wherein the acknowledgement sequence number includes an incremented version of the at least one portion of the sequence number transmitted to the receiving device and wherein when determining, the processor: identifies the next segment to transmit based on the incremented at least one portion of the sequence number.
11. The system of claim 9, wherein when transmitting, the processor: transmits the data packet using transmission control protocol/Internet protocol
(TCP/IP).
12. The system of claim 9, wherein the processor is further configured to: repeat the transmitting, receiving and determining for additional segments of the data until all the segments of the data have been transmitted and acknowledged.
13. The system of claim 9, wherein when transmitting, the processor: transmits the data packet without storing information identifying the segment being transmitted to the receiving device.
14. The system of claim 9, wherein the plurality of portions includes a first portion, and the processor is further configured to: set the length of the first portion based on the length of the segments transmitted.
15. The system of claim 14, wherein when setting, the processor is configured to: set the length of the first portion to n bits when the length of the segments transmitted is 2n bits.
16. The system of claim 9, wherein when generating, the processor: generates the at least one portion of the sequence number based on predictable processing performed by the receiving device, and generating at least one other portion of the sequence number in accordance with a specification of a relevant protocol.
17. A computer-readable medium having stored thereon a plurality of sequences of instructions, said sequences of instructions including instructions which, when executed by at least one processor, cause said processor to perform the steps of: generating a sequence number including a plurality of portions, at least one portion identifying a particular segment of data; transmitting a data packet including a segment of the data and the sequence number to a receiving device; receiving an acknowledgement packet from the receiving device, the acknowledgement packet including an acknowledgment sequence number; and determining a next segment of the data to transmit based on the acknowledgment sequence number.
18. The computer-readable medium of claim 17, wherein the acknowledgement sequence number includes an incremented version of the at least one portion of the sequence number transmitted to the receiving device and wherein the determining includes: identifying the next segment to transmit based on the incremented at least one portion of the sequence number.
19. The computer-readable medium of claim 17, wherein the transmitting includes: transmitting the data packet using transmission control protocol/Internet protocol (TCP/IP).
20. The computer-readable medium of claim 17, including instructions for causing the processor to perform the further steps of: repeating the transmitting, receiving and determining for additional segments of the data until all the segments of the data have been transmitted.
21. The computer-readable medium of claim 17, wherein the transmitting includes: transmitting the data packet without storing information identifying the segment being transmitted to the receiving device.
22. The computer-readable medium of claim 17, wherein the plurality of portions includes a least significant portion, the computer-readable medium including instructions for causing said processor to perform the further steps of: setting the length of the least significant portion based on the length of the segments transmitted.
23. The computer-readable medium of claim 22, wherein the setting includes: setting the length of the least significant portion to n bits when the length of the segments transmitted is 2" bits.
24. The computer-readable medium of claim 17, wherein the generating includes: generating the at least one portion of the sequence number based on predictable processing performed by the receiving device, and generating at least one other portion of the sequence number in accordance with specifications of a relevant protocol.
25. A system for transmitting a data stream as a number of discrete packets, each packet including a sequence number, the system comprising: means for generating a sequence number including a plurality of portions, at least one portion identifying a particular segment of the data stream; means for sending a data packet including a first segment of the data stream and the sequence number to a receiving device; means for obtaining an acknowledgement packet from the receiving device, the acknowledgement packet including an acknowledgment sequence number; and means for identifying a next segment of the data stream to transmit based on the acknowledgment sequence number.
26. A method for transmitting data packets, each packet including a sequence number and a data segment, comprising: generating at least one portion of the sequence number based on processing to be performed by a receiving device; generating at least one other portion of the sequence number based on a relevant protocol specification; and transmitting a data packet including a data segment and the sequence number to a receiving device.
27. The method of claim 26, further comprising: receiving an acknowledgement packet from the receiving device, the acknowledgement packet including an acknowledgment sequence number; and determining a next data segment to transmit based on the acknowledgment sequence number.
28. The method of claim 27, wherein the at least one portion identifies a particular data segment in a data stream, wherein the determining includes: identifying a portion of the acknowledgement sequence number corresponding to the at least one portion transmitted to the receiving device, and determining a next data segment of the data stream to transmit based on a value of the identified portion.
29. A system for transmitting data packets, each packet including a sequence number and a data segment, the system comprising: a memory configured to store instructions; and a processor configured to execute the instructions to: generate at least one portion of the sequence number based on processing to be performed by a receiving device, generate at least one other portion of the sequence number based on a relevant protocol specification, and transmit a data packet including a data segment and the sequence number to a receiving device.
30. The system of claim 29, wherein the processor is further configured to: receive an acknowledgement packet from the receiving device, the acknowledgement packet including an acknowledgment sequence number, and determine a next data segment to transmit based on the acknowledgment sequence number.
31. The system of claim 30, wherein the at least one portion identifies a particular data segment in a data stream, and when determining, the processor is configured to: identify a portion of the acknowledgement sequence number corresponding to the at least one portion transmitted to the receiving device, and determine a next data segment of the data stream to transmit based on a value of the identified portion.
32. A computer-readable medium that stores instructions executable by one or more processors to perform the steps of: generating at least one portion of the sequence number based on processing to be performed by a receiving device; generating at least one other portion of the sequence number based on a relevant protocol specification; transmitting a data packet including a data segment and the sequence number to a receiving device.
33. The computer-readable medium of claim 32, including instructions for causing said processor to perform the further steps of: receiving an acknowledgement packet from the receiving device, the acknowledgement packet including an acknowledgment sequence number; and determining a next data segment to transmit based on the acknowledgment sequence number.
34. The computer-readable medium of claim 33, wherein the at least one portion identifies a particular data segment in a data stream, wherein the determining includes: identifying a portion of the acknowledgement sequence number corresponding to the at least one portion transmitted to the receiving device, and determining a next segment of the data stream to transmit based on a value of the identified portion.
35. A method for transmitting a data stream in a number of discrete packets, each packet including a segment of the data stream and a sequence number field, the method comprising: partitioning the sequence number field into a plurality of portions; generating a sequence number corresponding to the plurality of portions, at least one portion identifying a particular segment of the data stream; and transmitting a data packet including a segment of the data stream and the sequence number to a receiving device.
36. The method of claim 35, wherein the generating includes: generating at least one other portion of the sequence number such that the sequence number complies with a relevant protocol.
37. A method for transmitting a data stream in a number of discrete packets, each packet including a segment of the data stream and at least one header field, the method comprising: partitioning the header field into a plurality of subfields; generating a value for the header field in accordance with a transmission control protocol, at least one subfield identifying a particular segment of the data stream; and transmitting a data packet including a segment of the data stream and the header field to a receiving device.
38. The method of claim 37, further comprising: receiving an acknowledgement packet from the receiving device, the acknowledgement packet including a modified version of the header field; and determining a next data segment to transmit based on the modified version of the header field.
39. A device for transmitting a data stream in a number of discrete packets, each packet including a segment of the data stream and at least one header field, the device comprising: logic configured to partition the header field into a plurality of subfields; logic configured to generate a value for the header field in accordance with a transmission control protocol, at least one subfield identifying a particular segment of the data stream; and logic configured to transmit a data packet including a segment of the data stream and the header field to a receiving device.
40. The device of claim 39, further comprising: logic configured to receive an acknowledgement packet from the receiving device, the acknowledgement packet including a modified version of the header field; and logic configured to determine a next data segment to transmit based on the modified version of the header field.
41. A method for transmitting a data stream in a number of discrete packets, each packet including a segment of the data stream and at least one header field, the method comprising: providing a first function to generate the header field in compliance with a transmission control protocol; generating the header field using the first function, the header field including information representing file offset information; transmitting a data packet including a segment of the data stream and the header field to a receiving device; receiving an acknowledgement packet from the receiving device; applying a second function to a portion of the acknowledgement packet corresponding to the header field; and identifying file offset information from results of applying the second function.
42. The method of claim 1, wherein the data represents at least one of a data file, a data message and application generated data.
43. The system of claim 9, wherein the data represents at least one of a data file, a data message and application generated data.
44. The computer-readable medium of claim 17, wherein the data represents at least one of a data file, a data message and application generated data.
PCT/US2000/040576 1999-08-07 2000-08-04 Systems and methods for transmitting data packets WO2002009370A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU77570/00A AU7757000A (en) 1999-08-07 2000-08-04 Systems and methods for transmitting data packets

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US14776499P 1999-08-07 1999-08-07
US60/147,764 1999-08-07

Publications (1)

Publication Number Publication Date
WO2002009370A1 true WO2002009370A1 (en) 2002-01-31

Family

ID=22522810

Family Applications (2)

Application Number Title Priority Date Filing Date
PCT/US2000/021280 WO2001067272A1 (en) 1999-08-07 2000-08-04 Virtual memory systems and methods
PCT/US2000/040576 WO2002009370A1 (en) 1999-08-07 2000-08-04 Systems and methods for transmitting data packets

Family Applications Before (1)

Application Number Title Priority Date Filing Date
PCT/US2000/021280 WO2001067272A1 (en) 1999-08-07 2000-08-04 Virtual memory systems and methods

Country Status (2)

Country Link
AU (2) AU7757000A (en)
WO (2) WO2001067272A1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6961777B1 (en) * 1999-08-06 2005-11-01 Shrikumar Hariharasubrahmanian Systems and methods for predicting fields in a data packet

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5852721A (en) * 1994-06-08 1998-12-22 Hughes Electronics Corporation Method and apparatus for selectively retrieving information from a source computer using a terrestrial or satellite interface
US6006268A (en) * 1997-07-31 1999-12-21 Cisco Technology, Inc. Method and apparatus for reducing overhead on a proxied connection
US6091733A (en) * 1997-01-09 2000-07-18 Kabushiki Kaisha Toshiba Communication device using communication protocol including transport layer and communication method using communication protocol including transport layer

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5084877A (en) * 1989-05-05 1992-01-28 At&T Bell Laboratories High speed transport protocol
US5862335A (en) * 1993-04-01 1999-01-19 Intel Corp. Method and apparatus for monitoring file transfers and logical connections in a computer network
US5781615A (en) * 1995-08-30 1998-07-14 Lucent Technologies Inc. Fully distributed message storage facilities in a distributed switching system
US6098172A (en) * 1997-09-12 2000-08-01 Lucent Technologies Inc. Methods and apparatus for a computer network firewall with proxy reflection

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5852721A (en) * 1994-06-08 1998-12-22 Hughes Electronics Corporation Method and apparatus for selectively retrieving information from a source computer using a terrestrial or satellite interface
US6091733A (en) * 1997-01-09 2000-07-18 Kabushiki Kaisha Toshiba Communication device using communication protocol including transport layer and communication method using communication protocol including transport layer
US6006268A (en) * 1997-07-31 1999-12-21 Cisco Technology, Inc. Method and apparatus for reducing overhead on a proxied connection

Also Published As

Publication number Publication date
AU7757000A (en) 2002-02-05
WO2001067272A1 (en) 2001-09-13
AU6758000A (en) 2001-09-17

Similar Documents

Publication Publication Date Title
US7009967B1 (en) Systems and methods for transmitting data packets
US7185114B1 (en) Virtual memory systems and methods
EP1359727A2 (en) Internet protocol system using hardware protocol and relating parallel data processing method
US7289509B2 (en) Apparatus and method of splitting a data stream over multiple transport control protocol/internet protocol (TCP/IP) connections
US7020716B2 (en) Method and system for verifying the hardware implementation of TCP/IP
EP0996069B1 (en) Method of transferring image data using a IEEE 1394 bus
US7197046B1 (en) Systems and methods for combined protocol processing protocols
US7953093B2 (en) TCP/IP reordering
US6819681B1 (en) Systems and methods for predicting data fields in layered protocols
JPH11134274A (en) Mechanism for reducing interruption overhead in device driver
WO2009045498A1 (en) Thin client discovery
WO2022001416A1 (en) Data transmission method, data transmission apparatus, and data transmission device
EP1952592B1 (en) Communication apparatus and method
JP2006325054A (en) TCP / IP reception processing circuit and semiconductor integrated circuit having the same
WO2019224860A1 (en) Communication device, communication method, and communication program
JP3569149B2 (en) Communication control device
US6961777B1 (en) Systems and methods for predicting fields in a data packet
US20030152162A1 (en) Transmitter, receiver, and methods
CN101088070B (en) Method and system for remote recording mechanism
WO2002009370A1 (en) Systems and methods for transmitting data packets
US20050080922A1 (en) Address translation program and address translation apparatus
US7420991B2 (en) TCP time stamp processing in hardware based TCP offload
EP1525722B1 (en) Packet signal processing architecture
EP1206862A1 (en) Systems and methods for predicting fields in a data packet
JP2000165423A (en) Channel expansion method for IEEE 1394 serial bus

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CR CU CZ DE DK DM DZ EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: JP