Computer networks are widely used for communication between computing devices. Such networks exist in large corporations or academic environments, as well as increasingly, in home and small office environments.
In some scenarios, operations that involve computers communicating over a network fail. There can be any of a number of reasons that such an operation may fail, making it difficult to identify the reason in any particular scenario. For example, failure can be the result of a defect within any of the computers that are attempting to communicate or a defect in a network component interconnecting those computers. Though, the failure could alternatively be the result of mis-configuration of any of the computers or network components involved in the operation.
To aid in detecting the cause of a failure, tools have been developed to analyze portions of a network. One such tool is called “trace route.” “Trace route” is provided by many operating systems, and can indicate the hops between two networked computing devices. Another such tool commonly available is called “ping,” which can be used to determine whether a networked computing device is reachable from another computing device.
Though these tools are available, they may not be adequate in some scenarios. The likelihood that the tools will be unsuitable for detecting problems on a home network may be particularly high. A home network may be managed by an individual who lacks the sophistication to use the tools or interpret output of the tools.
To improve a user experience, a computer may be equipped with a diagnostic tool to detect a network configuration that blocks communication between the computer and other devices on the network. The tool can detect a network configured with a NAT between the computer and other devices on the private network, which may impede communication between those devices. In some embodiments, the tool may be used as part of a diagnostic process when a computer user experiences communication problems, as part of a network setup routine or in other scenario in which it is desirable to determine whether a double NAT network configuration exists.
The tool may be run on a computing device connected to a network to determine whether a double NAT condition is present. In its operation, the tool discovers a NAT device, such as a router, to which the computing device is connected. The tool then identifies whether that NAT device is connected to another NAT device.
In some embodiments, the tool may differentiate between scenarios in which multiple NAT devices disrupt network communications between devices intended to be on the same private network and scenarios in which multiple NAT devices represent an intended network configuration in which a first private network is connected to a second private network. These network configurations may be distinguished based on the protocols used by the NAT devices. If both NAT devices use protocols used by home NAT devices, a double NAT configuration with respect to a private network may be identified. Conversely, if the network to which the device is connected or either of the NAT devices uses a protocol associated with a corporate network, an Internet Service Provider or other protocol not used within home networking devices, the network configuration may not be deemed to have a double NAT configuration with respect to a private network.
One way to detect whether two devices inside a private network might be separated by a NAT would be to directly test whether a NAT exists between the system running the tool and each other device in the private network. However, that would require the tool to know the addresses of all the other devices on the private network. It should be appreciated that requiring this knowledge is not ideal, and the present invention avoids the need for such knowledge by using the technique of testing for a double NAT configuration as discussed.
The foregoing is a non-limiting summary of the invention, which is defined by the attached claims.
The accompanying drawings are not intended to be drawn to scale. In the drawings, each identical or nearly identical component that is illustrated in various figures is represented by a like numeral. For purposes of clarity, not every component may be labeled in every drawing. In the drawings:
The inventors have recognized and appreciated that a “double NAT” network configuration can interfere with network communications, but is a difficult problem for many computer users to recognize. The problem may be particularly troublesome in a home networking setting, and can arise, for example, when devices are added to expand the network beyond a simple single router configuration. Yet, home users frequently lack the sophistication to distinguish between communication problems caused by a double NAT network and problems that can be caused by mis-configuration of computers on the network or failure of devices on the network.
The inventors have recognized and appreciated the desirability of providing a diagnostic tool that can detect a “double NAT” scenario, but is simple enough for even an unsophisticated home user to use. The tool may automate the process of detecting a double NAT scenario such that user interaction with the tool may not be required in some embodiments.
A double NAT scenario arises when two devices intended to be on the same private network are behind devices that perform a network address translation (NAT) such that any path between the two devices involves network address translation. Because the two devices each operate in different network address spaces, such a configuration can preclude communication between the two devices, as each device does not recognize the other device as being on the same home network.
Private network 102 may be in any suitable location, including a home or a small office. However,
Private network 102 includes a network address translation (NAT) device 104, which may be any suitable device, such as a cable modem, DSL modem, and/or wired or wireless router, that provides NAT services to a portion of computing devices in private network 102. The computing devices may be any suitable networked computing devices, such as desktop computer 106, and may be connected to the NAT device using any suitable communication medium, whether wired or wireless.
NAT services include assigning private addresses to devices on the private network. In addition, the NAT services provided by a NAT device such as the NAT device 104 frequently include interfacing between two networks with different network address spaces: an external network, and an internal private network to which the NAT device assigns private network addresses to computing devices behind the NAT device. (For the remainder of this document, if a device is said to be “behind” a NAT device, then the NAT device provides NAT services to the device.) Accordingly, the NAT device may have at least two network addresses assigned to it: an external network address in the external network address space and a private network address in the internal private network address space. While the external network is often the Internet, it may also be another private network, as the invention is not limited in this respect. The NAT device may assign private network addresses in the address space of the internal private network to computing devices behind the NAT device in any suitable way (e.g., DHCP), and may also act as a router for the computing devices on the private network. However, not all NAT devices may act as routers, and the invention is not limited in this respect.
The NAT services provided by the NAT device may also include obscuring the private addresses of computing devices in the internal network from devices on other networks, including the external network, such that communications between computing devices in the internal network and devices in other networks appear to be directed to or originating from the external network address of the NAT device. The obscuring may be done via any suitable technique, such as network masquerading. In typical NAT implementations, the NAT device does not obscure a network address of a computing device on the internal network from other computing devices on the internal network.
In the example illustrated by
Additionally, in some environments in which the invention may be practiced, external networks may also provide network address translation services for devices connected to them. In the computing environment 100 of
The private network 102 also includes a second NAT device, NAT device 112, that provides NAT services to a different portion of the computing devices in the private network 102 from the portion provided by NAT device 104. While the NAT device 112 is illustrated as a wireless access point/router, like the NAT device 104, the NAT device 112 may be any suitable NAT device that provides NAT services to computing devices behind to it over any suitable communications medium.
The private network 102 may include the NAT device 112 for any suitable reason, as the invention is not limited in this respect. For example, a network administrator may install the NAT device 112 in order to communicate over a different communications medium than what is provided by the NAT device (e.g., wireless instead of wired communication). As another example, the addition of the NAT device 112 may allow the private network 102 to grow to a larger size than what could be supported only with the NAT device 104 (e.g., if the NAT device 104 has a fixed number of physical communications ports).
The NAT device 112 is itself behind the NAT device 104, and is assigned a private network address on the sub-network 105 by the NAT device 104. The NAT device 112 additionally is connected to sub-network 113, on which it assigns private addresses to computing devices behind it. Thus, the external address of the NAT device 112 is not a public address, but is a private address in the address space of the sub-network 105, while the internal address of the NAT device 112 is a private address in the address space of the sub-network 113. Accordingly, besides sub-network 105, private network 102 also includes sub-network 113.
The NAT device 112 may provide NAT services to any suitable networked computing devices, illustrated in the environment of
Because laptop computer 114 and printer 116 are behind the NAT device 112, their network addresses on the sub-network 113 may be obscured by the NAT device 112 from devices on other external networks, including sub-network 105. Therefore, other devices in the private network 102 that are not also on the sub-network 113, such as desktop computer 106, may encounter difficulties in communicating with devices on sub-network 113. Many network protocols or networked applications may rely on the ability to communicate directly with the network address of a device without going through a NAT. For example, a user of desktop computer 106 who desires to print a document on printer 116 may be prevented to do so, because the printing protocol used by the desktop computer 106 may rely on knowing the network address of printer 116 in order to print a document. As another example, a user of laptop computer 114 may not be able to share files over the network with desktop computer 106.
The type of network configuration in which one NAT device (NAT device 112) is behind a second NAT device (NAT device 104) is referred to in this document as a double NAT configuration. In the example of
In some embodiments of this invention, a computing device may be configured with a tool that can detect the presence of a double NAT configuration with respect to a private network in a computing environment. For example, laptop computer 114 may execute the tool, and the tool may notify a user in any suitable way that, because laptop computer 114 is behind two NAT devices that are both within the private network 102, the private network has a double NAT configuration. As another example, if the tool executes on desktop computer 106, even though desktop computer 106 is not itself behind two NAT devices, the tool may detect that other computing devices on the private network 102 are behind two NAT devices, and may communicate that information to a user in any suitable way.
Once the tool detects the presence of a double NAT configuration on the private network 102, the user may take steps to remedy or mitigate any communication issues caused by the situation. In some embodiments of the invention, the tool itself may provide such suggestions, or the tool may direct the user to more information at an external location, as the invention is not limited in this respect. As an example of a remedy, the tool may suggest that the NAT device 112 be configured to act in a bridge mode, in which it does not create a separate sub-network, but configures devices under its control to be on the external network, which in the case of NAT device 112 corresponds to the sub-network 105 provided by the NAT device 104. In some embodiments, in addition to or instead of suggesting that the NAT device 112 operate in a bridge mode, the tool may communicate directly with the NAT device 112 to configure it to operate in bridge mode. As a second example, a user may in some situations be able to remove the NAT device 112 from the computing environment, and connect devices that were behind the NAT device 112 directly to the NAT device 104.
As discussed above, in some computing environments, an ISP such as ISP 108 may also provide NAT services such as ISP NAT services 110, to computing devices, such as the NAT device 104, that are connected through it. Thus, devices, such as desktop computer 106, behind the NAT device 104 but not behind the NAT device 112, are in a double NAT configuration with respect to other devices on the private network managed by ISP 108, even if they are not in a double NAT configuration with respect to the private network 102. However, a double NAT configuration with respect to the ISP 108 is not likely to pose a problem for a user of computing devices on the private network 102, because such a user would not necessarily expect for devices on the private network 102 to be able to communicate openly with other devices in the ISP network.
Thus, from the point of view of an administrator of a home or small office network, it is especially useful to detect the presence of double NAT configuration with respect to the private network 102. Unlike in a double NAT configuration with respect to an ISP, the user or administrator of a private network such as private network 102 would expect that all devices on the private network be able to communicate with each other. The user would desire to have steps taken to modify the configuration of the private network (including removing a double NAT configuration with respect to the private network) to address communication problems between devices on the network. Additionally, in a typical home or small-office private network, both the NAT device 104 and the NAT device 112 would be under the administrative control of a single entity, such as a home user, with the authority to remedy the double NAT configuration.
Accordingly, some embodiments of this invention are able to distinguish between the presence of a double NAT configuration with respect to ISP 108 and the presence of a double NAT configuration with respect to private network 102. The inventors have appreciated that devices providing NAT services for an ISP respond to a disjoint set of communications protocols than devices, such as the NAT device 104, providing NAT services to a private network such as may be operated in a home or small office. Thus, based on the response of devices to a set of protocols, some embodiments of the invention focus on the detection of a double NAT configuration in which a computing device is behind two NAT devices suitable for a small private network, such as a home or small office computing environment.
The process starts at block 200, which, in embodiments in which the invention is implemented as a tool, may correspond to the invocation by a user of the tool executing on a computing device on private network 102. In that scenario, the process of
Regardless of how invoked, the process may then check preliminary conditions that would indicate that the double NAT configuration detection process need not continue. These may be any suitable preliminary conditions. For example, at block 206, the process may check whether IPv4 support is enabled on the network. This check may be done in environments in which a NAT device typically only assigns IPv4 addresses. Thus, if IPv4 support is not enabled on the network, the process may proceed to termination block 204, as it has determined that no NAT device can be present in the computing environment.
Otherwise, if IPv4 support is enabled, the process may proceed to block 208, in which the tool obtains a network address, such as an LP address, of the first gateway device. The first gateway device may be the closest gateway device to the computing device on which the process is executing with respect to the number of hops. The IP address of the first gateway may be obtained in any suitable way. In some embodiments of the invention, the IP address is obtained by inspecting the local IP stack.
In other embodiments of the invention, the IP address is obtained by executing the ICMP (Internet Control Message Protocol) ping command, which is commonly available on a variety of operating systems, including variants of the WINDOWS® operating system and variants of UNIX® operating system. In some embodiments of the invention obtaining the IP address using the ping command, the process involves executing the ping command to a public destination LP address with the TTL (time-to-live) parameter set to one. The ping command accepts an input value that specifies a destination network address to which a packet is directed and a time-to-live input value. The underlying network hardware on the computer executing the tool may use this information to send an ICMP control packet directed to the network address specified. The public IP address may be obtained in any suitable way. In some embodiments, the selection of a destination IP address is made by attempting to select an address in the following order: a cached IP address for a fixed name, such as www.microsoft.com, any public IP address from the DNS cache, a DNS query result for a fixed name, such as www.microsoft.com, or a hardcoded public IP address, if the previous options are unavailable.
The time-to-live parameter in many network implementations is decremented by each router along the way to a destination network address, and thus indicates the maximum number of hops the packet should travel on its way to the destination network address before a router should abort the transmission of the packet. Frequently, when a router aborts the packet transmission, it sends a response packet back to the initial sender. Therefore, based on the packet sent by the router, the initial sender can determine the network address of the router. Accordingly, issuing a ping command with a time-to-live parameter set to one may be one way of determining the network address of a router or gateway device (first gateway device) that is one hop away from a sending computing device.
Regardless of the manner in block 208 of obtaining an IP address for the first gateway device, in block 210, a test is performed on the device at the obtained IP address to determine the type of the first gateway device specified by the IP address. More details of this step are provided in connection with
In some embodiments of the invention, including the embodiment illustrated by
In block 212, the process may then check the results of the NAT device test performed in block 210. If the results of the NAT device test indicate that the first gateway device is not a NAT device on the private network, the process may proceed to termination block 214, in which it may be determined that the computing environment does not include a double NAT configuration.
Otherwise, if the results of the NAT device test indicate that the first gateway device is a NAT device on the private network, the process may then proceed to block 216, in which the process may obtain a list of IP addresses that may possibly correspond to a second gateway device. The IP addresses may be obtained in any suitable way. More details of this process may be provided by the flowcharts illustrated in
The process may then proceed to block 218 in which it may perform the NAT device test using as input the list of possible IP addresses for the second gateway device. In some embodiments of the invention, as illustrated in
In some embodiments of the invention, the process may run the NAT device tests separately on each device in the list until the NAT device test determines that one of the IP addresses corresponds to a NAT device on the private network. More details of the NAT device test are provided in connection with
Also, in some embodiments, based on the result of running the NAT device test in block 218, (e.g., if a device tested is not a NAT device suitable for a home network) the process may involve obtaining via a different method (e.g., a process illustrated by
At block 220, a tool implementing the process may then check the results of performing the NAT device test on the list of devices. If the NAT device test indicated that at least one of the IP addresses corresponds to a NAT device on the private network, then the process may proceed to termination block 222, in which the process has determined that a double NAT configuration involving two NAT devices is present in the private network. Otherwise, if it is determined at block 220 that the NAT device test did not detect that any IP address in the list is a NAT device in the private network, the process may then proceed to termination block 214, in which it is determined that a double NAT configuration with respect to a private network was not detected. In either case, the process illustrated by
The process starts at block 300. At block 302, a tool implementing the process checks whether the IP address provided as input to the process is a private address. Certain ranges of IP addresses are known to a person of skill in the art to be private IP addresses, such as addresses with the subnet prefix 192.168.x.x, 172.16.x.x, 172.31.x.x, or 10.x.x.x. If the address is not a private IP address, then the device specified by the IP address is not a NAT device on the private network, and the process may proceed to termination block 304, in which it has determined that the device is not an appropriate type of NAT device.
Otherwise, if it is determined at block 302 that the device has a private IP address, the process may proceed to block 306, in which it is determined whether the device responds to any protocols which a NAT device on the private network would respond to, but a NAT device that is not on the private network, such as a device that provides NAT services for an ISP, would not respond to. Examples of such protocols include UPnP™ (Universal Plug and Play), LLTD (Link Layer Topology Discovery Protocol), NAT-PMP (NAT Port Mapping Protocol), and WSD (Web Services on Devices), although other protocols are possible. If the device at the specified IP address responds with the expected response to a request sent according to one or more of the protocols to which a NAT device on the private network would respond to, such as one of the protocols listed above, the step at block 306 may proceed to termination block 308, and determine that the device specified at the IP address is an appropriate type of NAT device, as the process of
In other embodiments of the invention, a determination of the type of NAT device may be made by alternatively or additionally sending a request according to a protocol that a NAT device that is not on the private network, such as a device providing NAT services by an ISP, would respond to with an expected response, but that a NAT device that is on the private network would not respond to, or would not provide the expected response. In this scenario, the set of protocols to which a NAT device on a private network is expected to respond is disjoint from the set of protocols to which a device on an ISP network or other network that may be coupled to the private network is expected to respond. The request may be sent according to any suitable such protocol. For example, some embodiments may employ the SSH protocol for this purpose, because that protocol would typically be supported by devices providing NAT services from an ISP, but not be supported by NAT devices on the private network. Though, if there is more than one suitable protocol, the request may be repeated in accordance with one or more of the protocols to determine whether the NAT device responds to any of the protocols of the set.
If the process did not determine in block 306 that the device is an appropriate type of NAT device, regardless of the type of protocol used to make that determination, the process may proceed to block 310. The device may still be a NAT device on the private network, even if it did not respond as expected to the requests sent according to the known protocols in block 306. For example, a NAT device may have been configured by an administrator or by the device supplier to have disabled the protocols tested in this process. At block 310, an additional determination is made whether the device responds to HTTP requests. Inventors have recognized that NAT devices on a private network typically run an HTTP server that provides a configuration interface for device administrators, but other types of NAT devices, such as a router operated by an ISP 108 that provides NAT services 110 to ISP customer networks, typically do not respond to HTTP requests from customers. The determination whether a device responds to HTTP requests may be done in any suitable way. In some embodiments of the invention, a device may be considered an HTTP server if a network connection can be established to a port on the device commonly used by HTTP servers, such port 80 or port 8080. The process may additionally involve sending an HTTP GET request to the device over a known HTTP port to see if it responds with a valid HTTP response, such as any response with a URL and a status code of 200, 401, or 407.
If the step at block 310 indicates that the device responds to HTTP requests, the process may proceed to termination block 308, as the process has determined that the device is a NAT device on the private network. Otherwise, the process may proceed to termination block 304, as the process has determined that the device is not a NAT device on the private network. In either case, the process of
The process illustrated by
If the processes illustrated in
Regardless of the manner of obtaining the external address of the first NAT device in block 422, at block 424, the process attempts to guess an IP address of the second NAT device based on the external address just obtained for the first NAT device. This may be done in any suitable way. In some embodiments of the invention, including that illustrated by
If the processes illustrated in
In some embodiments of the invention, the process of
As another example, if the process of
As discussed above, in some embodiments of the invention, the processes illustrated by
For example, if as a result of a computer communications problem on the private network, a user places a service call to a NAT device manufacturer or to an operating systems provider, a service technician may ask the user to invoke the tool as part of the troubleshooting process. If the tool indicates that a double NAT configuration with respect to a private network was detected, the service technician may be able to offer practical suggestions, such as those discussed in conjunction with
The tool may provide any suitable interface to a user, including a command-line interface suitable for automation and scripting, or a graphical user interface, or a combination of the two. In some embodiments of the invention, the tool may automatically be invoked by a software component, such as a component of an operating system, when the software component detects a communication failure between two devices with private network addresses. The tool may indicate the existence of a double NAT configuration with respect to a private network in any suitable way, including via e-mail or pop-up dialog window.
With reference to
Computer 610 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 610 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes both volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by computer 610. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer readable media.
The system memory 630 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 631 and random access memory (RAM) 632. A basic input/output system 633 (BIOS), containing the basic routines that help to transfer information between elements within computer 610, such as during start-up, is typically stored in ROM 631. RAM 632 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 620. By way of example, and not limitation,
The computer 610 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computer 610 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 680. The remote computer 680 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 610, although only a memory storage device 681 has been illustrated in
When used in a LAN networking environment, the computer 610 is connected to the LAN 671 through a network interface or adapter 670. When used in a WAN networking environment, the computer 610 typically includes a modem 672 or other means for establishing communications over the WAN 673, such as the Internet. The modem 672, which may be internal or external, may be connected to the system bus 621 via the user input interface 660, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 610, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
Having thus described several aspects of at least one embodiment of this invention, it is to be appreciated that various alterations, modifications, and improvements will readily occur to those skilled in the art.
Such alterations, modifications, and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the invention. Accordingly, the foregoing description and drawings are by way of example only.
Further, it should be appreciated that, though exemplary embodiments have been described in which a NAT device, such as an Internet gateway device, provides an interface between address spaces, a double NAT configuration with respect to a private network can arise even if the device is not connected to an external network. Accordingly, a device that merely assigns private addresses may be regarded as a NAT device in some scenarios.
For example, in the embodiment of
However, because NAT device 112 still is behind NAT device 104, the private network 102 still has a double NAT configuration with respect to a private network, and computing devices behind the NAT device 112 on sub-network 113 may be obscured from other computing devices in the private network 102, such as desktop computer 106. Thus, because of the presence of the NAT device 112, the invention may still be applied to network environments in which the NAT device 104 does not provide an interface to an external network, as long as the NAT device 104 is capable of being detected as being a type of NAT device suitable for a home environment.
The above-described embodiments of the present invention can be implemented in any of numerous ways. For example, the embodiments may be implemented using hardware, software or a combination thereof. When implemented in software, the software code can be executed on any suitable processor or collection of processors, whether provided in a single computer or distributed among multiple computers.
Further, it should be appreciated that a computer may be embodied in any of a number of forms, such as a rack-mounted computer, a desktop computer, a laptop computer, or a tablet computer. Additionally, a computer may be embedded in a device not generally regarded as a computer but with suitable processing capabilities, including a Personal Digital Assistant (PDA), a smart phone or any other suitable portable or fixed electronic device.
Also, a computer may have one or more input and output devices. These devices can be used, among other things, to present a user interface. Examples of output devices that can be used to provide a user interface include printers or display screens for visual presentation of output and speakers or other sound generating devices for audible presentation of output. Examples of input devices that can be used for a user interface include keyboards, and pointing devices, such as mice, touch pads, and digitizing tablets. As another example, a computer may receive input information through speech recognition or in other audible format.
Such computers may be interconnected by one or more networks in any suitable form, including as a local area network or a wide area network, such as an enterprise network or the Internet. Such networks may be based on any suitable technology and may operate according to any suitable protocol and may include wireless networks, wired networks or fiber optic networks.
Also, the various methods or processes outlined herein may be coded as software that is executable on one or more processors that employ any one of a variety of operating systems or platforms. Additionally, such software may be written using any of a number of suitable programming languages and/or programming or scripting tools, and also may be compiled as executable machine language code or intermediate code that is executed on a framework or virtual machine.
In this respect, the invention may be embodied as a computer readable medium (or multiple computer readable media) (e.g., a computer memory, one or more floppy discs, compact discs, optical discs, magnetic tapes, flash memories, circuit configurations in Field Programmable Gate Arrays or other semiconductor devices, or other tangible computer storage medium) encoded with one or more programs that, when executed on one or more computers or other processors, perform methods that implement the various embodiments of the invention discussed above. The computer readable medium or media can be transportable, such that the program or programs stored thereon can be loaded onto one or more different computers or other processors to implement various aspects of the present invention as discussed above.
The terms “program” or “software” are used herein in a generic sense to refer to any type of computer code or set of computer-executable instructions that can be employed to program a computer or other processor to implement various aspects of the present invention as discussed above. Additionally, it should be appreciated that according to one aspect of this embodiment, one or more computer programs that when executed perform methods of the present invention need not reside on a single computer or processor, but may be distributed in a modular fashion amongst a number of different computers or processors to implement various aspects of the present invention.
Computer-executable instructions may be in many forms, such as program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Typically the functionality of the program modules may be combined or distributed as desired in various embodiments.
Also, data structures may be stored in computer-readable media in any suitable form. For simplicity of illustration, data structures may be shown to have fields that are related through location in the data structure. Such relationships may likewise be achieved by assigning storage for the fields with locations in a computer-readable medium that conveys relationship between the fields. However, any suitable mechanism may be used to establish a relationship between information in fields of a data structure, including through the use of pointers, tags or other mechanisms that establish relationship between data elements.
Various aspects of the present invention may be used alone, in combination, or in a variety of arrangements not specifically discussed in the embodiments described in the foregoing and is therefore not limited in its application to the details and arrangement of components set forth in the foregoing description or illustrated in the drawings. For example, aspects described in one embodiment may be combined in any manner with aspects described in other embodiments.
Also, the invention may be embodied as a method, of which an example has been provided. The acts performed as part of the method may be ordered in any suitable way. Accordingly, embodiments may be constructed in which acts are performed in an order different than illustrated, which may include performing some acts simultaneously, even though shown as sequential acts in illustrative embodiments.
Use of ordinal terms such as “first,” “second,” “third,” etc., in the claims to modify a claim element does not by itself connote any priority, precedence, or order of one claim element over another or the temporal order in which acts of a method are performed, but are used merely as labels to distinguish one claim element having a certain name from another element having a same name (but for use of the ordinal term) to distinguish the claim elements.
Also, the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including,” “comprising,” or “having,” “containing,” “involving,” and variations thereof herein, is meant to encompass the items listed thereafter and equivalents thereof as well as additional items.
This application is a continuation of U.S. application Ser. No. 12/371,481, filed Feb. 13, 2009 incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5185860 | Wu | Feb 1993 | A |
7043564 | Cook et al. | May 2006 | B1 |
7302496 | Metzger | Nov 2007 | B1 |
7881231 | Qian | Feb 2011 | B2 |
20060291443 | Harrington et al. | Dec 2006 | A1 |
20070058567 | Harrington et al. | Mar 2007 | A1 |
20070064696 | Min | Mar 2007 | A1 |
20070130286 | Hopmann et al. | Jun 2007 | A1 |
20070177499 | Gavrilescu et al. | Aug 2007 | A1 |
20070204231 | Cunningham et al. | Aug 2007 | A1 |
20080052384 | Marl et al. | Feb 2008 | A1 |
20090186575 | Perpinya et al. | Jul 2009 | A1 |
Number | Date | Country |
---|---|---|
WO 2008020233 | Feb 2008 | WO |
Number | Date | Country | |
---|---|---|---|
20110125897 A1 | May 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12371481 | Feb 2009 | US |
Child | 13018067 | US |