|Publication number||US7120701 B2|
|Application number||US 09/792,879|
|Publication date||Oct 10, 2006|
|Filing date||Feb 22, 2001|
|Priority date||Feb 22, 2001|
|Also published as||US20020116523|
|Publication number||09792879, 792879, US 7120701 B2, US 7120701B2, US-B2-7120701, US7120701 B2, US7120701B2|
|Inventors||Ulhas S. Warrier, Saul Lewites, Prakash N. Iyer|
|Original Assignee||Intel Corporation|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (13), Non-Patent Citations (5), Referenced by (37), Classifications (30), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This invention relates to dynamically assigning a source address to a data packet based on the destination of the data packet.
A computer network may include a private realm and a public realm. The private realm contains computers sharing a private addressing scheme known only to the computers in that private realm. The public realm contains computers sharing a public addressing scheme known to all computers in the network, whether public or private. A packet may be sent between computers on the public and private realms through an interface device, such as a gateway.
Like reference symbols in the various drawings indicate like elements.
Network 10 (
Private realm 12 includes, here computers A and B (i.e. private clients) and gateway 16. Public realm 14 includes, here computer C (i.e. public client) and gateway 16 connected by Internet 18.
Private clients A and B share a private addressing scheme known only to members of private realm 12. Each private client has its own private address. Here private client A has the private IP address PrA while private client B has the private IP address PrB. Typically, a Request for Comment 1918 (“RFC 1918”) standard defines reserved private IP address spaces in the private realm.
Public client C has a public addressing scheme known to all members of network 10. Each public client has its own public address. Here, public client C has a public IP address PuC.
Gateway 16 has both a private realm interface 15 and a public realm interface 17. Private realm interface 15 has at least one private address, here private IP address PrG, and public interface 17 has at least one public address, here public IP address PUG. In this embodiment, gateway 16 is a computer, which belongs to both the public and the private realms and uses interfaces 15 and 17 to connect private realm 12 with the public realm 14. Other types of interface devices may be used instead of, or in addition to, gateway 16.
Clients A, B and C and gateway 16 also contain a plurality of ports 11. Ports 11 serve as unique endpoint identifiers for logical connections between applications running on clients A, B, C and gateway 16. Port numbers PN (not shown) serve as addresses within a computer. The port numbers function to identify each individual port 11 located on a particular device in network 10.
Application Y running on a private or public client (for example A) may communicate with another application Z running on another private or public client (for example C) over network 10. Application Y communicates with application Z using a packet 20 sent via ports 11 of clients A and C via gateway 16.
Packet 20 (
Applications (for example Y and Z) running on private and public clients (for example A and C respectively) build packets 20 using operations named socket calls. Socket calls function to create and use communication entities known as sockets that contain information necessary for applications to prepare, send and receive packets 20.
A socket is a software abstraction that embodies source address 28 and source port number 29 of a client sending a packet and destination address 26 and destination port number 27 of a client receiving the packet. Sockets are used to bind source addresses 28 to source ports 11 identified by source port numbers 29 and destination addresses 26 to destination ports 11 identified by destination port numbers 27.
Examples of socket calls include: SOCKET( ) which creates a communication endpoint; BIND( ) which attaches a local address and port to a socket; LISTEN( ) which announces a willingness to accept a connection; ACCEPT( ) which blocks a caller until a connection attempt arrives; CONNECT( ) which actively attempts to establish a connection; SEND( ) which sends a packet over the connection; RECEIVE( ) which receives a packet over the connection; and CLOSE( ) which releases the connection. Other operations also known as socket calls and not listed above may also be used to perform socket operations depending upon the software/hardware configuration of a particular client A, B or C.
The proper preparation of packet 20 includes providing the proper source address 28, source port number 29, destination address 26, destination port number 27 and buffer 22 in packet 20. The proper source address and port number for packet 20 prepared at a client in the private addressing realm should depend upon the destination of the packet.
For example, application Y on private client A may send packet 20A (
However, for application Y on private client A to send packet 20C (
Hence, a private client, here A, has two source addresses; a private source address (i.e. source address 28 and source port 29 in
Network Address Translation (“NAT”) is a protocol that enables Internet Protocol (“IP”) computers in a private realm to exchange data packets with IP computers in the public realm via a gateway. NAT functions by modifying (i.e. translating) the source address information of packets received at the gateway to ensure packets contain the proper source address.
Host-NAT is a protocol that enables computers in the private realm to perform NAT on packets prior to sending packets to a gateway. In other words, Host-NAT allows private clients, as opposed to the gateway, to modify packets between the private and public addressing realms.
Network Address Translation (“NAT”) translates the address field of packet 20C between public and private realms. NAT enables packet 20C to be routed between the public and private addressing realms by modifying (i.e. translating) the source IP address 28 and/or port addresses 27 and 29 of packet 20C between the public and private addressing realms.
Realm Specific Internet Protocol (“RSIP”) is a protocol that enables clients (e.g. A and B) in the private addressing realm to perform Host-NAT. Host-NAT allows a private client of private realm 12 to perform NAT functions to prepare packets to be sent over network 10.
Heretofore, applications employing NAT, Host-NAT and RSIP failed for applications requiring the proper addressing and port information prior to building packet 20C. For example, applications that encrypt packet 20C or insert addressing information 24 into buffer 22, like IP telephony, require the proper address and port information prior to building a packet. Often, recipients of packets sent by these applications receive addressing information in buffer 22. NAT, Host-NAT and RSIP fail such applications because NAT, Host-NAT and RSIP only manipulate information within address field 24 and do not update addressing information that may be provided within buffer 22.
Client A receives (303) a public address of gateway 16, for example PuG, for use with the assigned (301) source port number 29 of client A. Here, client A receives (303) the public address of gateway 16 for possible use as the public address of A.
Client A receives (305) a private address of client A, here PrA, for use with the assigned (301) source port number 29 of client A. Here, client A receives (305) the private address PrA for possible use as the private address of A.
Client A selects (307) either the public or private address of A to use as its source address 28 based on the destination address 26 of packet 20. If the destination address 26 of packet 20 is public, process 30 retrieves (309) the public address of the gateway for use as the source address 28. If the destination address 26 of packet 20 is private, process 30 retrieves (311) the private address of the client for use as source address 28.
Process 30 provides (313) the retrieved (309) public address to the application (for example Y) on client A if Y is attempting to send a packet 20 to an address in the public realm. Process 30 provides (315) the retrieved (311) private address to application Y on client A if Y is attempting to send a packet 20 to an address in the private realm.
The retrieved public (309) and private (311) addresses are provided (313 and 315) to client A for use by application Y. The assigned (301) source port is also provided to application Y. For example application Y may encrypt the addressing information 24 of packet 20. Application Y may also insert the proper addressing information 24 within buffer 22.
Process 30 enables client A to build (317) packet 20 using the retrieved public (309) or private (311) source address 28 and the assigned (301) source port number 29. Packet 20 will be built to contain the proper addressing information, based on its destination address 26, without the need to translate or modify addressing information 24.
For example, application 42 initiates the creation of a packet 20 by sending a signal to socket interface 44. Socket interface 44 receives a signal from application 42 to initiate socket bind operations for creating a socket for building (317) packet 20. Socket interceptor 46 intercepts the socket bind operations to ensure a proper source port 11 of client A is assigned (301) to the socket created for packet 20. Typically, this involves assigning a source port number 29 for the socket from a pool of source ports registered with A.
For an application requiring binding to a specific source port 11 socket interceptor 46 will close the first socket opened for packet 20 (if it is not the desired source port) and attempt to open a new socket for packet 20. The new socket will attempt to bind to the specific source port required by the application. Opening the new specific socket for packet 20 will succeed provided another application or private client of gateway 16 is not using the specific source port. If the new socket fails, the request to send a packet will be dropped and the application will have to try again.
Assigned source port number 29 may be stored in a memory table (not shown) accessible to gateway 16. The assigned source port number 29 may be used by gateway 16 to de-multiplex destination addresses PuG of a packet received in response to a packet sent by a private client. For example, gateway 16 may de-multiplex a packet 20D using assigned source port number 29 mapped in a mapping table to private source address PrA that the port number is assigned too. The destination port number 27 of reply packet 20D, here the source port number 29, is mapped to the address PrA of the client that sent packet 20C. Thus, the reply packet received at the interface device, here gateway 16, is de-multiplexed and sent to the client who has been assigned the source port number 29 found in the destination port number 27 of the reply packet received at interface 17.
Socket interceptor 46 also creates two sockets for each socket which application 42 requests for building a packet. One of the sockets is a public socket and is be bound to the public address of the client (i.e. the public gateway address, here PuG). The other socket is a private socket and is bound to the private address of client A, here PrA.
The selection (307) of the public or private socket from which packet 20 is built is based on the destination address of the packet found in a socket call (for example connect( ) or sendto( )). Once the public or private socket is selected (307) packet 20 is built (317) and flows through the regular network interface card 49 according to the specifications in the route table of the client.
Process 30, however, is not limited to use with any particular hardware or software configuration and may find applicability in any computing or processing environment. Process 30 may be implemented in hardware, software, or a combination of the two. Process 30 may be implemented in computer programs executing on programmable computers that each include a processor, a storage medium readable by the processor including volatile and non-volatile memory and/or storage elements and input and output devices.
Process 30 may be implemented in a high level procedural or object-oriented programming language as one or more programs to communicate with a computer system. However, the programs can be implemented in assembly or machine language. The language may be compiled or interpreted language.
Each computer program may be stored on a storage medium or device (e.g. CD-Rom, hard disk, or magnetic diskettes) that is readable by a general or special purpose programmable computer for configuring and operating the computer to perform process 30. Process 30 may also be implemented as a computer-readable storage medium, configured with a computer program, where, upon execution, instruction in the computer program cause the computer to operate in accordance with process 30.
A number of embodiments of the invention have been described. Nevertheless, it will be understood that various modifications may be made without departing from the spirit and scope of the invention. For example, clients A, B, C and gateway 16 may have multiple public and private addresses for sending packets. Accordingly, other embodiments are within the scope of the following claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5623601 *||Nov 21, 1994||Apr 22, 1997||Milkway Networks Corporation||Apparatus and method for providing a secure gateway for communication and data exchanges between networks|
|US5884025 *||Feb 4, 1997||Mar 16, 1999||Sun Microsystems, Inc.||System for packet filtering of data packet at a computer network interface|
|US6154839 *||Apr 23, 1998||Nov 28, 2000||Vpnet Technologies, Inc.||Translating packet addresses based upon a user identifier|
|US6324178 *||May 26, 1998||Nov 27, 2001||3Com Corporation||Method for efficient data transfers between domains of differing data formats|
|US6353891 *||Aug 9, 2000||Mar 5, 2002||3Com Corporation||Control channel security for realm specific internet protocol|
|US6477164 *||Aug 7, 1998||Nov 5, 2002||Clarent Corporation||System and method for real-time data and voice transmission over an internet network|
|US6567405 *||Feb 4, 2002||May 20, 2003||3Com Corporation||Method and protocol for distributed network address translation|
|US6584096 *||Dec 30, 1998||Jun 24, 2003||Nortel Networks Limited||Method and apparatus for connecting a home network to the internet|
|US6708219 *||Oct 26, 1999||Mar 16, 2004||3Com Corporation||Method and system for dual-network address utilization|
|US6781982 *||Oct 26, 1999||Aug 24, 2004||3Com Corporation||Method and system for allocating persistent private network addresses between private networks|
|US6884025 *||Sep 30, 2002||Apr 26, 2005||United Technologies Corporation||Shim lock/pin anti-rotation bumper design|
|US20020026528 *||Jul 16, 2001||Feb 28, 2002||Lo Kwoktung B.||System and method for selectively bridging and routing data packets between multiple networks|
|US20020042875 *||Jul 23, 2001||Apr 11, 2002||Jayant Shukla||Method and apparatus for end-to-end secure data communication|
|1||G. Montenegro et al., "RSIP Support for End-to-end IPsec", Experimental, Oct. 2001.|
|2||Jeffrey Lou et al., "IP Host Network Address (and Port) Translation", draft-ietf-nat-hnat-00.txt, Nov. 1998.|
|3||Michael Borella et al., "Distributed Network Address Translation", draft-borella-aatn-dnat-01.txt, Oct. 1998.|
|4||Nikander, Pekka "Combining Trust Management, Jini, IPv6, and Wireless links: A Proposal for a Service Network Archictecture for Ad Hoc Environments Extended Abstract", Helsiniki University of Technology, firstname.lastname@example.org.|
|5||Y. Rekhter et al., "Address Allocation for Private Internets", Best Current Practice, Feb. 1996.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US7437474 *||Feb 22, 2001||Oct 14, 2008||Intel Corporation||Proxy-less packet routing between private and public address realms|
|US7554993 *||Mar 27, 2003||Jun 30, 2009||Hewlett-Packard Development Company, L.P.||Method and apparatus for performing connection management with multiple stacks|
|US7561531||Apr 19, 2005||Jul 14, 2009||Intel Corporation||Apparatus and method having a virtual bridge to route data frames|
|US7720097 *||Dec 20, 2005||May 18, 2010||Ricoh Company, Ltd.||Communication apparatus, communication method, communication program and recording medium|
|US7827309 *||Jul 14, 2003||Nov 2, 2010||Hitachi, Ltd.||Information processing apparatus for concealing the identity of internet protocol addresses|
|US7937471 *||Jun 3, 2002||May 3, 2011||Inpro Network Facility, Llc||Creating a public identity for an entity on a network|
|US8090843 *||Apr 15, 2011||Jan 3, 2012||Impro Network Facility, LLC||Creating a public identity for an entity on a network|
|US8156246||Sep 26, 2011||Apr 10, 2012||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8190708||Oct 20, 2000||May 29, 2012||Nomadix, Inc.||Gateway device having an XML interface and associated method|
|US8244886||Sep 2, 2010||Aug 14, 2012||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8266266||Jan 11, 2010||Sep 11, 2012||Nomadix, Inc.||Systems and methods for providing dynamic network authorization, authentication and accounting|
|US8266269||Dec 19, 2011||Sep 11, 2012||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8364806||Aug 3, 2012||Jan 29, 2013||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8370477||Aug 3, 2012||Feb 5, 2013||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8370524||Jul 16, 2012||Feb 5, 2013||Nomadix, Inc.||Systems and methods for network address translation|
|US8516083||May 2, 2012||Aug 20, 2013||Nomadix, Inc.||Systems and methods of communicating using XML|
|US8606917||Oct 24, 2012||Dec 10, 2013||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8613053||Oct 11, 2011||Dec 17, 2013||Nomadix, Inc.||System and method for authorizing a portable communication device|
|US8713641||Dec 8, 1999||Apr 29, 2014||Nomadix, Inc.||Systems and methods for authorizing, authenticating and accounting users having transparent computer access to a network using a gateway device|
|US8725888||Oct 21, 2013||May 13, 2014||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8725899||Oct 21, 2013||May 13, 2014||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8788690||Dec 2, 2013||Jul 22, 2014||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US8832315||Jan 31, 2013||Sep 9, 2014||Nomadix, Inc.||Systems and methods for network address translation|
|US9160672||Mar 31, 2015||Oct 13, 2015||Nomadix, Inc.||Systems and methods for controlling user perceived connection speed|
|US9160714 *||Jun 30, 2003||Oct 13, 2015||Telefonaktiebolaget L M Ericsson (Publ)||Using tunneling to enhance remote LAN connectivity|
|US9491136||Sep 5, 2014||Nov 8, 2016||Nomadix, Inc.||Systems and methods for network address translation|
|US9548935||Jul 18, 2014||Jan 17, 2017||Nomadix, Inc.||Systems and methods for providing content and services on a network system|
|US20020116502 *||Feb 22, 2001||Aug 22, 2002||Iyer Prakash N.||Proxy-less packet routing between private and public address realms|
|US20030233454 *||Jun 3, 2002||Dec 18, 2003||Alkhatib Hasan S.||Creating a public identity for an entity on a network|
|US20040117506 *||Jul 14, 2003||Jun 17, 2004||Hiromichi Ito||Communication method and information processing apparatus|
|US20040190533 *||Mar 27, 2003||Sep 30, 2004||Prashant Modi||Method and apparatus for performing connection management with multiple stacks|
|US20040234054 *||Jun 19, 2002||Nov 25, 2004||Helmut Kunkel||Method for automatically controlling paths of information|
|US20040267874 *||Jun 30, 2003||Dec 30, 2004||Lars Westberg||Using tunneling to enhance remote LAN connectivity|
|US20050053063 *||Sep 4, 2003||Mar 10, 2005||Sajeev Madhavan||Automatic provisioning of network address translation data|
|US20060190717 *||Dec 20, 2005||Aug 24, 2006||Kohki Ohhira||Communication apparatus, communication method, communication program and recording medium|
|US20060233168 *||Apr 19, 2005||Oct 19, 2006||Saul Lewites||Virtual bridge|
|US20110196945 *||Apr 15, 2011||Aug 11, 2011||Inpro Network Facility, Llc||Creating a public identity for an entity on a network|
|U.S. Classification||709/245, 709/223, 370/389, 370/391, 709/236, 370/392, 709/246, 370/390, 370/474, 370/401, 709/238|
|International Classification||H04L29/06, H04L29/12, G06F15/16|
|Cooperative Classification||H04L63/02, H04L61/2514, H04L29/12452, H04L29/12367, H04L29/12396, H04L61/2525, H04L61/2546, H04L29/12009|
|European Classification||H04L63/02, H04L61/25A5, H04L61/25A1B, H04L61/25A2A, H04L29/12A, H04L29/12A4A2A, H04L29/12A4A1B, H04L29/12A4A5|
|Feb 15, 2002||AS||Assignment|
Owner name: INTEL CORPORATION, CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:WARRIER, ULHAS S.;LEWITES, SAUL;IYER, PRAKASH N.;REEL/FRAME:012612/0495
Effective date: 20010517
|May 17, 2010||REMI||Maintenance fee reminder mailed|
|Oct 10, 2010||LAPS||Lapse for failure to pay maintenance fees|
|Nov 30, 2010||FP||Expired due to failure to pay maintenance fee|
Effective date: 20101010