The present disclosure relates to communication of information between data processing devices.
For some data processing devices, it can be useful to perform data processing tasks at more than one processing module. This provides for more efficient execution of processing tasks, improving the device speed and increasing the number and type of tasks that can be executed by the device. For data processing devices that employ more than one processing module, it can be desirable to have the processing modules communicate with each other. This allows a particular task to be executed by a combination of both processing modules. However, providing communications format between processing modules can be difficult, as existing communication protocols do not allow a processing module to readily differentiate between communications intended for processing and communications intended for another purpose. Accordingly, an improved method and system for communication between devices would be useful.
The present disclosure may be better understood, and its numerous features and advantages made apparent to those skilled in the art by referencing the accompanying drawings.
The use of the same reference symbols in different drawings indicates similar or identical items.
A method of communicating with a network interface includes providing a packet to the network interface, where the packet includes an address field indicating a destination of the packet. The network interface analyzes the address field, and determines if it reflects an address associated with the network interface. If not, the network interface provides the packet to a network. If the network interface determines the address field reflects an address associated with the interface, it provides information in the packet to an application executing at the network interface. Accordingly, information targeted to an application can be communicated by associating an address, such as a network address, with the network interface, allowing for communication of the information without extensive processing of each packet at the interface.
Referring to
The network 110 is a packet switched network configured to communicate packets to nodes in the network. Each packet communicated by the network 110 includes address information indicating the target node for that packet. Accordingly, each node associated with the network 110, including the host node 102 and the remote node 150, is associated with a unique address, such as an Internet Protocol (IP) address, a Media Access Control (MAC) address, and the like. The network 110 includes one or more routers, servers, and other routing devices that route a packet through the network based on the target address information indicated by the packet. The network 110 can be a wide-area network, such as the Internet, or a local area network, or a combination thereof.
The host node 102 includes a processor 105 and a network interface 130. The processor 105 is a data processing device configured to execute applications, including an application 120 and a device driver 125. The application 102 is an application configured to communicate with the network interface 130 and the remote node 150. In particular, the application 102 is configured to provide information for communication to either the network interface 130 or the remote node 150 via the device driver 125. In a particular embodiment, the network interface 130 and the processor 105 are enclosed within a common physical housing, such as a single computer device (e.g. a desktop computer, laptop computer, server, or the like).
The device driver 125 is configured to control the network interface 130, and in particular to provide an interface between the application 120 and the network interface 130. Accordingly, in response to receiving information from the application 120, the device driver 125 forms the information into one or more packets and provide those packets to the network interface 130.
The network interface 130 is configured to communicate packets to the network 110. In particular the network interface 130 also includes a physical interface 137, which provides a physical medium of communication between the processor 105 and the processor 115. The physical interface can be a bus interface, a network interface, and the like. The network interface 130 also includes a physical interface 138, which provides a physical medium of communication between the host node 102 and the network 110. The physical interface 138 controls physical signaling to the network 110 to ensure that packets are provided to the network. In addition, the network interface 130 includes a processor 115 configured to execute applications, such as the application 133. The application 133 can be any kind of software application or function, such as a web server, portion of an online interactive game (e.g. a game server), and the like. Thus, both the processor 105 and the processor 115 are configured to execute applications, allowing the host node 102 to perform tasks more efficiently. In addition, the network interface 130 is configured to execute applications and to interface with the network 110, providing for additional processing ability without requiring an additional motherboard or other space-consuming device to provide the processing ability.
In operation, the host node 102 associates the network interface 130 with a network address. In an embodiment, this network address is different from the network address associated with the host node 102 itself. By associating the network interface 130 with a network address, such as an IP or MAC address, the application 130 is able to easily communicate with either the application 133 and the remote node 150 without a large amount of additional processing overhead.
To illustrate, in order to provide information to the remote node 150, the application 120 sends the information to the device driver 125, which forms a packet including address information associated with the remote node 150 and communicates the packet to the physical interface 137 at the network interface 130, which in turn provides the received packet to an address monitoring module 135. The address monitoring module 135 at the network interface 130 analyzes the packet and determines that the address information reflected in the packet indicates the packet is not targeted for any applications running at the network interface 130. Accordingly, the address monitoring module 135 provides the packet to the physical interface 138, which communicates the packet to the network 110. The network 110 in turn routes the packet to the remote node 150.
In order to provide information to the application 133, the application 120 sends the information to the device driver 125, which forms a packet including the information in a data payload, and also including address information associated with the network interface 130. The device driver 125 provides the packet to the network interface 130, and the address monitoring module 135 determines that the address information reflected in the packet is associated with an application running at the network interface 130. Accordingly, the address monitoring module 135 provides the packet to the application 133, which accesses the information included in the data payload of the packet. Thus, by associating a network address with the network interface 130, the application 120 can send information to the application 133 through an existing device driver 125, without extensive redesign of the driver or the application itself.
The application 133 can also communicate information to the application 120 by forming packets addressed to the network address associated with the host node 102. The packets are looped back to the processor 105 by the network interface 130. In particular, the processor 115 determines the packets are addressed to the host node 102, and in response provides the packets to the physical interface 137, which provides the packets to the device driver 125, which in turn provides the information reflected in the packets to the application 120. Thus, the application 133 can
Network addresses are typically assigned via a network administrator or network administration software such as a DHCP server. The host node 102 will acquire or be configured with its network address by the network administrator or the network administration software. This associates the host node 102 with the assigned network address for subsequent communication of packets.
The network address associated with the network interface 130 can be determined by one of a number of different methods. First, the address can be assigned by a network administrator or administration software such as a DHCP server in the same way as an address was assigned to the host node 102. In this case, the network address would appear to be similar to any other network address on the external network. In some cases this method may not be desirable because it might expose applications running inside the network interface to other nodes on the external network opening a potential security hole.
A second method would be to assign a network address that is not addressable or routable on the external network to provide for added security that only the host node can access applications running in the network device. This can be accomplished by using a special command from the device driver 125 to the network interface 130 to indicate what the assigned address should be. Alternatively, the network interface 130 itself could determine an appropriate non-routable network address once the host node has been assigned its own network address.
The operation of the data processing system 100 can be understood with reference to an example. In the example, the application 133 is a web server that provides information to the network 110 indicative of a web page. The application 120 can be a database or other application that produces content for the web pages provided by the application 133. The remote node 150 can be another server that produces web pages reflecting information from the application 120. By providing information to the network interface 130 and the remote node 150 in the manner described above, the application 120 can efficiently update the web pages provided by both the application 133 and the remote node 150 using the device driver 125.
The host node 120 can also associate a particular alphanumeric string, referred to as a name, with the address assigned to the network interface 130. This can allow a user to easily access and communicate with the network interface 130. For example, in an embodiment the application 120 can be a web interface application, such as a web browser. By entering the name associated with the address assigned to the network interface into an address bar of the web interface, a user can ensure that information entered via the application 120 is provided to the network interface 130.
In an embodiment, the address assigned to the network interface 130 is associated with a private address space. As used herein, private address space refers to a set of network addresses that are generally accessible via a wide area network such as the Internet. By assigning the network interface 130 a private address, this ensures that the assigned address does not match the network address of another node in the network 110, such as the remote node 150. This in turn ensures that the address assigned to the network interface is unique with respect to other nodes in the network and non-routable.
Referring to
The public network 245 is a packet switched network including a number of routers, servers, clients, and other computer devices configured to route packets through the network. Each device in the public network can be associated with a unique address, such as an IP address. The public network 245 is associated with a public address space, whereby each device in the network can communicate with each other device. Further, the addresses of the public address space are also known to devices in the private network 210.
The private network 210 is a packet switched network such as a local area network (LAN) or other network associated with a private address space relative to the public network 245. Thus, the private network 210 can include routers, servers, clients, or other computer devices, whereby each device is associated with a unique address. These addresses are private and non-routable with respect to the public network 245. For example, if a device in the public network 245 (e.g. a router) receives a packet associated with an address in the private address space of the private network 210, the device is typically configured to discard the packet, and typically cannot route the packet associated with the private address through the public network 245. This provides security for devices in the private network 210 by ensuring that the devices cannot be communicated with directly by devices in the public network 245.
The gateway 255 is a router, server, modem, digital subscriber line (DSL) device, or the like that is configured to provide for communication between the private network 210 and the public network 245. In particular, the gateway 255 is associated with both a public address of the public network 245 and a private address associated with the private network 210. To illustrate, the public network 245 can communicate packets to a device in the private network 210 by addressing the packet to the public address associated with the gateway 255. The gateway 255 determines the private address for the device that is the target of the packet, associates that private address with the packet, and provides the packet to the private network 210 for routing to the target device. Similarly, if a device in the private network 210 communicates a packet associated with a public address, the private network 210 routes the packet to the gateway 255, which in turn provides the packet to the public network 245 for routing to the destination.
The host node 202 is configured similarly to the host node 102 of
In the illustrated embodiment of
To illustrate, in a particular embodiment the private network 210 is associated with a private address space based on a specified address subnet. For example, the address space of the private network 210 can be associated with the subnet 192.x.x.x, so that the address of each device in the private network 210 is an address in the 192 subnet. In this embodiment, the address associated with the network interface 230 will be from a different subnet, such as 10.x.x.x. This ensures that the private network address associated with the network interface 230 does not conflict with a private network address of a device in the private network 210. Further, the addresses associated with the subnet of the address for the network interface 230 are non-routable by the private network 210 and the public network 245, thereby shielding the network interface 230 from direct access by outside devices in either network. In another embodiment, the host node 202 can be associated with a public address, so that it can be communicated with directly by devices in the public network 245, such as the remote node 260, while the network interface 230 is associated with a private address that is not routable by either the private network 210 or the public network 245.
Referring to
At block 306, it is determined whether the address information included in the packet indicates the network address of the network interface, or another address. If the address information indicates the network address of the network interface, the method flow moves to block 308 and the information in the data payload of the packet is routed to an application executing at the network interface device, such as a web browser, server application, online interactive game, and the like. If, at block 306, it is determined that the address information included in the packet is not associated with the network address of the network interface, the packet is routed to a physical interface of the network interface device. The physical interface communicates the packet to the network, where the packet is routed to the information target.
Referring to
At block 406, the device driver or other interface module determines if the message is targeted to the application at the network interface device. If so, the method flow moves to block 408 and a packet is created. The packet includes information reflecting the message in a data payload of the packet. In addition, the packet includes a header or other portion that includes address information indicating the network address associated with the network interface device. At block 412, the created packet is provided to the network interface.
If, at block 406, it is determined that the message is not targeted to an application executing at the network interface, the method flow moves to block 410 and the device driver or other interface module creates a packet including a data payload and address portion, such as a header. The data payload includes information reflecting the message. The address portion includes information indicating an address associated with the device that is the target of the message. The method flow proceeds to block 412, and the packet is provided to the network interface for communication to the target device via the network.
The above disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments that fall within the true spirit and scope of the present invention. Thus, to the maximum extent allowed by law, the scope of the present invention is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.
This application claims priority to U.S. Provisional Patent Application No. 60/908,024, entitled “METHOD AND SYSTEM FOR ABSTRACT PRIVATE COMMUNICATION BETWEEN TWO NODES,” filed on Mar. 26, 2007, which is assigned to the current assignee hereof and is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5353412 | Douglas et al. | Oct 1994 | A |
5355371 | Auerbach et al. | Oct 1994 | A |
5675736 | Brady et al. | Oct 1997 | A |
5771287 | Gilley et al. | Jun 1998 | A |
5890963 | Yen | Apr 1999 | A |
6009458 | Hawkins et al. | Dec 1999 | A |
6015348 | Lambright et al. | Jan 2000 | A |
6240517 | Nishioka | May 2001 | B1 |
6424621 | Ramaswamy et al. | Jul 2002 | B1 |
6615218 | Mandal et al. | Sep 2003 | B2 |
6625661 | Baldwin, Jr. et al. | Sep 2003 | B1 |
6745236 | Hawkins et al. | Jun 2004 | B1 |
6763371 | Jandel | Jul 2004 | B1 |
6810528 | Chatani | Oct 2004 | B1 |
6908389 | Puskala | Jun 2005 | B1 |
6918042 | Debry | Jul 2005 | B1 |
6941353 | Lane | Sep 2005 | B1 |
6961852 | Craft | Nov 2005 | B2 |
6970943 | Subramanian et al. | Nov 2005 | B1 |
6988196 | Cromer et al. | Jan 2006 | B2 |
7000115 | Lewis et al. | Feb 2006 | B2 |
7003548 | Barck et al. | Feb 2006 | B1 |
7046680 | McDysan et al. | May 2006 | B1 |
7056217 | Pelkey et al. | Jun 2006 | B1 |
7065756 | Barsness et al. | Jun 2006 | B2 |
7139780 | Lee et al. | Nov 2006 | B2 |
7209449 | Tang et al. | Apr 2007 | B2 |
7249109 | Silverbrook et al. | Jul 2007 | B1 |
7274702 | Toutant et al. | Sep 2007 | B2 |
20010014097 | Beck et al. | Aug 2001 | A1 |
20020078223 | Baldonado et al. | Jun 2002 | A1 |
20020180583 | Paatero et al. | Dec 2002 | A1 |
20020198932 | Wagner | Dec 2002 | A1 |
20030041136 | Cheline et al. | Feb 2003 | A1 |
20030177187 | Levine et al. | Sep 2003 | A1 |
20030191857 | Terrell et al. | Oct 2003 | A1 |
20030198017 | Hashimoto et al. | Oct 2003 | A1 |
20030204566 | Dhupelia et al. | Oct 2003 | A1 |
20040015725 | Boneh et al. | Jan 2004 | A1 |
20040068580 | Jo et al. | Apr 2004 | A1 |
20040230801 | Sueyoshi et al. | Nov 2004 | A1 |
20040246905 | Dunagan et al. | Dec 2004 | A1 |
20040249879 | Beverly | Dec 2004 | A1 |
20040259633 | Gentles et al. | Dec 2004 | A1 |
20050044270 | Grove et al. | Feb 2005 | A1 |
20050060442 | Beverly et al. | Mar 2005 | A1 |
20050107161 | Fujimoto et al. | May 2005 | A1 |
20050188073 | Nakamichi et al. | Aug 2005 | A1 |
20050278459 | Boucher et al. | Dec 2005 | A1 |
20060010133 | Bozek et al. | Jan 2006 | A1 |
20060010265 | Aiken et al. | Jan 2006 | A1 |
20060034275 | Roberts et al. | Feb 2006 | A1 |
20060069724 | Langdon | Mar 2006 | A1 |
20060098653 | Adams et al. | May 2006 | A1 |
20060121986 | Pelkey et al. | Jun 2006 | A1 |
20060160621 | Rowe et al. | Jul 2006 | A1 |
20060203842 | Wollmershauser et al. | Sep 2006 | A1 |
20060259579 | Beverly | Nov 2006 | A1 |
20060259632 | Crawford et al. | Nov 2006 | A1 |
20060274750 | Babbar et al. | Dec 2006 | A1 |
20070005986 | Bernard et al. | Jan 2007 | A1 |
20070060373 | Beverly | Mar 2007 | A1 |
20070086343 | Kujawa et al. | Apr 2007 | A1 |
20070101408 | Nakhjiri | May 2007 | A1 |
20070189517 | Koseki et al. | Aug 2007 | A1 |
20070226498 | Walmsley et al. | Sep 2007 | A1 |
20070297405 | He | Dec 2007 | A1 |
20070298879 | Kobayashi et al. | Dec 2007 | A1 |
20080005441 | Droux et al. | Jan 2008 | A1 |
20080009337 | Jackson et al. | Jan 2008 | A1 |
20080009352 | Aoyama et al. | Jan 2008 | A1 |
20080010371 | Yamamoto et al. | Jan 2008 | A1 |
20080013551 | Scholl | Jan 2008 | A1 |
20080016236 | Beverly et al. | Jan 2008 | A1 |
20080022389 | Calcev et al. | Jan 2008 | A1 |
20080039208 | Abrink et al. | Feb 2008 | A1 |
20080045285 | Fujito | Feb 2008 | A1 |
20080049621 | McGuire et al. | Feb 2008 | A1 |
Number | Date | Country |
---|---|---|
10218795 | Nov 2003 | DE |
10314451 | Dec 1998 | JP |
2001246147 | Sep 2001 | JP |
03062995 | Jul 2003 | WO |
2006124357 | Nov 2006 | WO |
Entry |
---|
PCT International Search Report, Jun. 25, 2008, 9 pages. |
International Search Report for PCT/US06/017659 dated Jul. 10, 2007, 3 pages. |
Bangun, Ricky A. et al., “A Network Architecture for Multiuser Networked Games on Demand,” 1997 International Conference on Information, IEEE, vol. 3, pp. 1815-1819, XP002507873. |
Smed, Jouni et al., “Aspects of Networking in Multiplayer Computer Games,” Electronic Library Emerald UK, vol. 20, No. 2, 2002, pp. 87-97, XP002507872. |
CyberGuard: “CyberGuard SG User Manual,” retrieved from kc.mcafee.com/resources/sites/MCAFEE/content/live/product—documentation/21000/PD21320/en—US/UserManual—v2.1.0.pdf, Aug. 23, 2004, pp. 1-202. |
EP Search Report for 08732696.3 dated Mar. 30, 2011, 8 pages. |
“European Application No. 08732696 EPO Examination Report”, Dec. 14, 2011 , 7 pages. |
“Data Race Announces Winmax ‘Soft’ Modem, Fax, LAN Combo PC Card Sold Directly to Consumers”, PR Newswire, http://www.thefreelibrary.com/data+race+announces+Winmax+‘Soft’+. . . , downloaded from web on Sep. 16, 2013. Mar. 7, 1995 , 3 pages. |
Number | Date | Country | |
---|---|---|---|
20080239954 A1 | Oct 2008 | US |
Number | Date | Country | |
---|---|---|---|
60908024 | Mar 2007 | US |