1. Technical Field
The present disclosure relates generally to wireless networks and, more specifically, to a method of adding a client device or service to a wireless network.
2. Description of the Related Art
Home networks, in which multiple computing and/or peripheral devices are communicatively linked together in a consumer's home, are becoming increasingly ubiquitous. A home environment may include one or more computers, a wireless router, a DSL modem, and one or more other client devices capable of connecting to the home network. Conventionally, each device in the home network must be individually configured to connect to the network and, once configured, may then communicate with each of the other devices attached to the home network.
In practice, procedures for associating client devices and provisioning services on a home network are typically too involved for the majority of home network users to implement reliably. For example, a network user may need to manually reconfigure the home network router, determine a network IP address and/or hostname for each client device, establish network credentials, register the various services for each device, and manually track which network IP address is associated with which client device or service in order to configure client devices to communicate on the home network.
The involved configuration procedures described above make it a challenge for unsophisticated users to reliably setup a home network and associate client devices or services on the home network. Accordingly, there is a need in the art for systems and methods that enable the user of a home network to conveniently and securely connect one or more devices or services to the home network.
So that the manner in which the above recited features of the present invention can be understood in detail, a more particular description of the invention may be had by reference to example embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only example embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.
For clarity, identical reference numbers have been used, where applicable, to designate identical elements that are common between figures. It is contemplated that features of one example embodiment may be incorporated in other example embodiments without further recitation.
In the following description, numerous specific details are set forth to provide a more thorough understanding of various example embodiments of the invention. However, it will be apparent to one of skill in the art that certain embodiments of the invention may be practiced without one or more of these specific details. In other instances, well-known features have not been described in order to avoid obscuring the invention.
One example embodiment of the present invention sets forth a method that comprises obtaining identification information and an authorization credential associated with a client device or service, receiving a registration request from the client device or service that includes the identification information, wherein the registration request is for registering the client device or service with a wireless home network, in response, determining that the client device or service is currently associated with the wireless home network, initiating a secure password authentication protocol with the client device or service, and, after completing the secure password authentication protocol, registering the client device or service with the wireless home network.
Another example embodiment of the present invention sets forth a computer-readable medium including instructions that, when executed by a processing unit, cause the processing unit to perform the steps of obtaining identification information and an authorization credential associated with a client device or service, receiving a registration request from the client device or service that includes the identification information, wherein the registration request is for registering the client device or service with a wireless home network, in response, determining that the client device or service is currently associated with the wireless home network, initiating a secure password authentication protocol with the client device or service, and, after completing the secure password authentication protocol, registering the client device or service with the wireless home network.
Yet another example embodiment of the present invention sets forth a system comprising a smart network host device located within a wireless home network that is configured to obtain identification information and an authorization credential associated with a client device or service, receive a registration request from the client device or service that includes the identification information, wherein the registration request is for registering the client device or service with the wireless home network, in response, determine that the client device or service is currently associated with the wireless home network, initiate a secure password authentication protocol with the client device or service, and, after completing the secure password authentication protocol, register the client device or service with the wireless home network.
A portal application 172, residing within the computer 170, is configured to access the network state model 178 to determine which client devices 130 are available within the smart network 102, which services the client devices 130 provide, and to access and use the services. The portal application 172 may include one or more applets 174, configured to extend functionality of the portal application 172. A given applet 174 may be associated with a specific client device 130 and may facilitate specific usage models for the client device 130 via the extended functionality. When a new client device 130 registers with the smart network 102, a most recent version of a corresponding applet 174 may not be available within the portal application 172. However, the portal application 172 may retrieve the corresponding applet 174 or version of the corresponding applet 174 from the applet store 116.
The applet store 116 is configured to facilitate access to applets 174 by the portal application 172. The applet store 116 provides storage for applets 174 corresponding to client devices 130 and makes the applets 174 available for download to the portal application 172 via the external network 110. In one embodiment, the applet store 116 occupies a well-known location, such as a universal resource locator (URL) associated with the external network 110. Any technically feasible technique may be used to identify a particular applet 174 as corresponding to a particular client device 130. Furthermore, any technically feasible technique may be used to download the particular applet 174 an incorporate the functionality of the applet 174 to the portal 172.
The smart network host device 120 implements a wireless network interface coupled to antenna 122, which is configured to convert electrical signals to electromagnetic signals for transmitting data packets, and electromagnetic signals to electrical signals for receiving data packets. The antenna 122 may comprise plural independent radiator structures, each having a separate radiation pattern for implementing spatial multiplexing. In one embodiment, the wireless network interface implements one or more well-known standards, such as the Institute of Electrical and Electronics Engineers (IEEE) standard 802.11, which defines a system for wireless local area networking. The antenna 122 is configured establish wireless client links 134 to antennas 132 coupled to corresponding client devices 130. The smart network host device 120 implements layer 2 forwarding (bridging) for wireless data packets forwarded among client devices 130 as well as Internet protocol (IP) layer 3 routing between an IP domain associated with the smart network 102 and the external network 110. In this configuration, the smart network host device 120 provides related services and protocols, such as dynamic host configuration protocol (DHCP), network address translation (NAT), and the like.
The smart network host device 120 acts as a central authentication authority for the smart network 102 and implements authentication services for devices registering with the smart network 102. In one embodiment, authentication is implemented via Identification (ID) devices 136 that are uniquely paired with corresponding client devices 130. For example, client device 130(0) may be uniquely paired with ID device 136(0) by a manufacturer of the client device 130(0). An ID device 136(0) is physically presented to the smart network host device 120 as an authentication credential to allow a client device 130(0) paired to the ID device 136(0) to join the smart network 102. Furthermore, the client device 130(0) is able to authenticate the smart network 102 as a trusted network by accessing credentials for the corresponding ID device 136(0) specifically via the smart network 102. In one embodiment, the ID devices 136 are implemented as near field radio frequency identification (RFID) tags. Each one of the RFID tags is configured to retain authentication credentials necessary to uniquely associate the one RFID tag with one instance of the client device 130. In this way, an RFID tag may be paired with a given client device 130. Persons skilled in the art will recognize that any technique may be implemented to generate and represent authentication credentials without departing the scope and spirit of the present invention. For example, in another embodiment, the ID devices 136 could be implemented as a physical token that includes a printed bar code on a face of the token. The bar code may encode authentication credentials for a corresponding client device 130. In such an embodiment, the smart network host device 120 may include an optical scanner capable of reading the printed bar code from the physical token. In alternative embodiments, other forms of ID devices 136 may implement storage of the authentication credentials. For example, a universal serial bus (USB) storage device may be used to present authentication credentials to the smart network host device 120 for authenticating a related device, such as the computer 170. In other alternative embodiments, a user may manually authenticate a client device 130 with the smart network host device 120. For example, the user may log onto a management web page generated by the smart network host device 120 and manually enter authentication credentials, such as a printed code associated with the client device 130.
In one usage scenario involving ID device 136, the user wishes to add a new device, such as a smart network-enabled printer to the smart network 102. The printer includes an ID device 136 implemented as an RFID tag that is paired to the printer. The user places the ID device 136 in close physical proximity to the smart network host device 120, which is the able to read the ID device 136 and authenticate the printer. The printer registers with the smart network host device 120 and is then available for use by devices connected within the smart network 102. Upon successfully reading the ID device 136, the smart network host device 120 may indicate success to the user by flashing a light-emitting diode (LED), or by generating any technically feasible indication.
In addition to previously described functionality, the smart network host device 120 is also configured to detect one or more smart network extender devices 140 and to establish a bridge link 128 to each of the one or more smart network extender devices 140. Each smart network extender device 140 is configured to act as a network bridge between a client device 130 and the smart network host device 120. For example, client devices 130(1) through 130(N) may be physically located such that they are able to connect to the smart network extender device 140, but not to the smart network host device 120. Furthermore, the smart network extender device 140 is able to connect to the smart network host device 120 via bridge link 128. Data packets transmitted by client devices 130(1) through 130(N) and destined to the external network 110 are received by the smart network extender device 140 and retransmitted by the smart network extender device 140 via bridge link 128 to the smart network host device 120, which then forwards the data packets to the external network 110. Similarly, data packets from the external network 110 that are destined to any of the client devices 130(1) through 130(N) are transmitted via bridge link 128 to the smart network extender device 140, which retransmits the data packets via wireless client links 134(1)-134(N). Persons skilled in the art will understand that wireless client links 134(1)-134(N) may each be configured to operate on a separate channel or band, or a common channel or band. Furthermore, bridge link 128 may operate on a separate channel or band with respect to the wireless client links 134.
In one embodiment, each smart network extender device 140 is paired to an ID device 136, which is presented as an authentication credential to the smart network host device 120 to enable the smart network extender device 140 to participate within the smart network 102.
In this embodiment, the smart network host device 120 is configured to operate similarly with respect to
Network data traffic between client device 130(N) and the external network 110 traverses wireless client link 134(N), bridge link 128, and backhaul link 158. This network data traffic is also forwarded by smart network extender device 140, smart network host device 120, and smart network connector device 150. A client device 130 may connect directly to any one of the network extender device 140, smart network host device 120, or smart network connector device 150. As shown, client device 130(0) is connected to smart network connector device 150 via wireless client link 134(0), client device 130(1) is connected to smart network host device 120 via wireless client link 134(1), and client device 130(N) is connected to smart network extender device 140 via wireless client link 134(N).
In one embodiment, the smart network connector device 150 is paired to an ID device 136, which is presented as an authentication credential to the smart network host device 120 to enable the smart network connector device 150 to participate within the smart network 102. In an alternative embodiment, the smart network connector device 150 and the smart network host device 120 are paired during a manufacturing step, eliminating the need for a separate ID device 136.
The processor complex 160 comprises a central processing unit (CPU), non-volatile memory for storing persistent programs, program state, and configuration information, random access memory (RAM) for storing temporary or volatile data, and an interface to the interconnect 165. In one embodiment, the processor complex 160 is configured to execute an operating system and applications that provide routing services. The routing services may include, for example, data packet forwarding between the network interface 118 and the wireless network interface 162. The packet forwarding services may include, without limitation, bridging among the one or more network devices via the wireless network interface 162.
The ID device reader 164 is configured to read data from an associated ID device 136. In one embodiment, the ID device reader 164 is configured to read data from RFID tags comprising the ID device 136. The ID device reader 164 may also include a USB reader. In another embodiment, the ID device reader 164 may be implemented as an optical scanner for reading ID devices 136 that encode data via a printed bar code. In yet other embodiments, the ID device reader 164 may be configured to read data from other types of interfaces, such as other types of flash memories like an SD flash card.
In certain embodiments, the smart network host device 120 comprises one or more integrated circuits that implement respective functions of the smart network host device 120. For example, the processor complex 160, wired network interface 166, and wireless network interface 162 may be integrated into a single integrated circuit.
Persons skilled in the art will recognize that the smart network extender device 140 may be implemented using the basic architecture of the smart network host device 120, with the exception that the ID device reader 164 and wired network interface 166 are not required for the smart network extender device 140. Similarly, the smart network connector device 150 may be implemented using the basic architecture of the smart network host device 120, with the exception that the ID device reader 164 is not required for the smart network connector device 150.
The runtime server 180 comprises a network provisioning module 182, a service and discovery provisioning (SDP) module 184, an event module 186, and a network configuration module 188. The event module 186 tracks different network events, such as a network device advertising presence or updating status within the smart network 102. The SDP module 184 maintains a persistent view of different network devices and related services, based on data from the event module 186 and on data from the network devices. The network provisioning module 182 provides authentication and authorization for network devices within the smart network 102. Authentication credentials may be presented via a given ID device 136. The network provisioning module 182 may also facilitate certain network services, such as DHCP leases. The network configuration module 188 includes hardware platform-specific implementation methods for network configuration and management. The persistent view comprises the network state model 178 of
Persons skilled in the art will recognize that the smart network connector device 150 and smart network extender device 140 may be implemented using an appropriate subset of the system software architecture 104 described above in conjunction with
Embodiments of the invention provide systems and methods for automatically registering a device or service with a wireless network, such as the smart network 102. Specifically, a host device obtains identification information and an authorization credential associated with a specific device or service that can be registered with a wireless network. When the host device receives a registration request from the device or service, registration is performed automatically once the host device confirms the device or service has been associated with the wireless network and the secure password authentication protocol is successfully performed by the host device and the device or service. The secure password authentication protocol is based on the authorization credential obtained by the host device prior to the registration request.
The host device obtains the identification information and authorization credential from a network association apparatus that is associated with the specific device or service to be registered with the wireless network. The network association apparatus is configured to automatically provide the identification information and the authorization credential in a secure fashion to the host device of the wireless network when brought into close proximity to or physically connected with the host device. In some example embodiments, the network association apparatus comprises one or more of ID devices 136(1)-136(N) described above in conjunction with
In the example embodiment illustrated in
The UUID 230 includes a unique reference number used as an identifier for the client device 130(N) that enables the smart network host device 120 to differentiate the client device 130(N) from other devices and services found in the network system 100. In some example embodiments, the UUID 230 is similar in format to globally unique identifiers (GUIDs), however, other formats known in the art suitable for the UUID 230 may be utilized without departing from the scope of the invention. For example, the UUID 230 may include the media access control address (MAC address) of the client device 130(N), in order to uniquely identify the client device 130(N). The MAC address of the client device 130(N) is a unique identifier that has no risk of name conflicts with any other devices in the smart network 102 or the network system 100. Thus, the ID device 136(N) can be permanently associated with the client device 130(N) via the UUID 230. In alternative embodiments, the ID device 136(N) may be configured such that UUID 230 may be written to the ID device 136(N) by the smart network host device 120 or other device, and therefore can be associated with a different client device 130(N) at a later time as desired by the user. For example, a UUID associated with the smart network 102 may be written to the ID device 136(N), and the ID device 136(N) may then be used to associate the smart network 102 with other smart networks on the network system 100.
The authorization credential 240, when obtained from the ID device 136(N) by the smart network host device 120, provides a layer of security to the smart network 102 when the smart network host device 120 sets up a secure connection between the smart network 102 and the client device 130(N). The authorization credential 240 may be an encrypted key for device-to-device authentication, in this case between the smart network host device 120 and the client device 130(N), and may be stored in or permanently written to the ID device 136(N) when the ID device 136(N) is manufactured. Thus, in some embodiments, the authorization credential 240 is stored in a write-protected storage medium, such as the write-protected encrypted bits of a USB drive or RFID tag, the manufactured key of an optical disk or SD memory card, or the like. The data included in the authorization credential 240 may be stored in any format known in the art suitable for authorization credentials without departing from the scope of the invention. In one example embodiment, the authorization credential 240 includes at least a portion of the MAC address of the client device 130(N). In some embodiments, the authorization credential 240 is a high-entropy key, such as a 128-bit key.
How the ID device 136(N) provides the UUID 230 and the authorization credential 240 to the smart network host device 120 depends on the configuration of the ID device 136(N). For example, when the ID device 136(N) comprises a USB drive with write-protected encrypted bits, the ID device 136(N) is detected by the smart network host device 120 when the ID device 136(N) is inserted into an appropriate USB port of the smart network host device 120, and the smart network host device 120 can obtain the UUID 230 and the authorization credential 240 using any technically feasible protocol. When the ID device 136(N) includes a bar code, the ID device 136(N) is scanned across a suitable bar code reader coupled to the smart network host device 120. When the ID device 136(N) comprises an RFID tag, connection to the smart network host device 120 can be as straight-forward as physically presenting the ID device 136(N) to the smart network host device 120. Thus, as soon as the ID device 136(N) is within a working radius of ID device reader 164 disposed in the smart network host device 120, e.g., within about 10 cm, the smart network host device 120 detects the ID device 136(N) and reads the UUID 230 and the authorization credential 240 from the ID device 136(N). Alternatively, the RFID reader in the smart network host device 120 may be configured to read information only from an RFID tag that is within the working radius of the RFID reader and also has a prescribed orientation with respect to the smart network host device 120, or is physically mounted in a specific location on the smart network host device 120. In such an example embodiment, faking of an RFID tag output signal is difficult to simulate, thereby preventing unwanted devices and/or services from being registered on the smart network 102 by the smart network host deice 120. Whether the ID device 136(N) comprises an RFID tag, a device that is physically connected to the smart network host device 120, or a bar code that is scanned in to the smart network host device 120, once the connection is made between the ID device 136(N) and the smart network host device 120, user involvement is no longer required for the client device 130(N) to be associated with the smart network 102 by the smart network host device 120.
In some example embodiments of the invention, the ID device 136(N) includes a visual identifier 250 that is disposed on an outer surface of the ID device 136(N). The visual identifier 250 provide symbolic and/or numeric markings which indicate to the user the specific client device 130 or service that is associated with the ID device 136(N). The visual identifier 250 may include a logo of a company associated with the client device 130(N) or service associated with the ID device 136(N), an icon that represents the client device 130(N) or service, a serial number associated with the client device 130(N) or service, and/or a bar code that uniquely identifies the client device 130(N) or service. Thus, a user can quickly determine from multiple ID devices 136, which ID device 136(N) is associated with a specific client device 130. In order to conveniently differentiate between the ID devices 136 associated with similar client devices (e.g., multiple digital cameras), the visual identifier 250 may include both an iconic and a numeric component.
In operation, ID device 136(N) enables the smart network host device 120 to associate a specific client device 130(N) with the smart network 102. The ID device 136(N) is a physical representation of the client device 130(N) that greatly simplifies the role of a user of the smart network 102 when adding the client device 130(N) or a service to the smart network 102, since the UUID 230 and the authorization credential 240 are automatically obtained by the smart network host device 120. Further, an additional layer of security is provided to the smart network 102 since the UUID 230 and the authorization credential 240 can only be obtained by the smart network host device 120 when a suitable ID device 136(N) is positioned in close proximity to or physically connected to the smart network host device 120. In this way, the smart network host device 120 obtains the UUID 230 and the authorization credential 240 in a convenient and secure fashion, and can automatically associate the client device 130(N) that is paired to the ID device 136(N) with the smart network 102 with little risk of the authorization credential 240 being spoofed, or an unauthorized UUID being accepted by the smart network host device 120. In some example embodiments, as an added layer of security, the smart network host device 120 is configured to automatically disassociate the client device 130(N) or service associated with the ID device 136(N) and the smart network 102 when the ID device 136(N) is detected to be no longer in close proximity to or physically connected to the smart network host device 120.
As shown, the method 300 begins at step 301, where the smart network host device 120 detects the presence of the ID device 136(N), which is associated with the client device 130(N) or a service that can be connected to smart network 102. In one embodiment, the ID device 136(N) may be detected when mounted in a prescribed fashion on a surface of the smart network host device 120 and ID device reader 164 in the smart network host device 120 detects the presence of an RFID tag included in the ID device 136(N) once the ID device 136(N) is within the near field of the reader. In another example embodiment, the ID device 136(N) may be swiped near the ID device reader 164. In yet another example embodiment, a bar code included in the ID device 136(N) is read by an optical scanner coupled to the smart network host device 120.
In step 302, the smart network host device 120 automatically obtains from the ID device 136(N) the UUID 230 and the authorization credential 240 for the client device 130(N) or service associated with the ID device 136(N). The UUID 230 and the authorization credential 240 may be obtained placing the ID device 136(N) near the smart network host device 120, or by physically connecting the ID device 136(N) to the smart network host device 120 via a USB port or other technically feasible connection mechanism. In an alternative embodiment, the UUID 230 and the authorization credential 240 may be encoded in a printable medium, such as a bar code, and read by swiping the bar code under an optical scanner included in the smart network host device 120.
In step 303, the smart network host device 120 updates the network state model 178 to include the new device or service for which the smart network host device 120 has obtained the UUID 230 and the authorization credential 240, thereby associating the client device 130(N) or service with the smart network 102.
As shown, the method 400 begins at step 401, where the smart network host device 120 receives a registration request from the client device 130(N) or a service associated with the ID device 136(N). Such a registration request may take place when the client device 130(N) is first powered up, rebooted, etc. within the operational radius of the antenna 122 of the smart network host device 120. The registration request includes the UUID 230 associated with the client device 130(N). In an alternative embodiment, the registration request from the client device 130(N) may be received by any access point of the smart network 102, including the smart network extender device 140 and the smart network connector device 150. In such an embodiment, the smart network extender device 140 communicates the registration request to the smart network host device 120 via the bridge link 128, and the smart network connector device 150 communicates the registration request to the smart network host device 120 via the backhaul link 158.
In step 402, the smart network host device 120 determines whether the client device 130(N) or service requesting registration with the smart network 102 has been previously associated with the smart network 102. The smart network host device 120 performs the determination of step 402 by confirming that the UUID 230 received from the client device 136(N) in step 401 matches an entry in the network state model 178. The presence of the UUID 230 in the network state model 178 confirms that a user has previously presented the ID device 136(N) to the smart network host device 120, and the smart network host device 120 proceeds to step 403 of method 400. If the UUID 230 is not present in the network state model 178, the smart network host device 120 knows that the client device 130(N) has not been previously associated with the smart network 102 via a suitable ID device 136(N) and therefore cannot be an authorized client device on the smart network 102. Consequently, the smart network host device 120 will not respond to the client device 130(N) or service making the registration request, and the client device 130(N) or service will neither be aware of nor have the ability to connect to the smart network 102. In an alternative example embodiment, the smart network host device 120 also checks for the presence of the ID device 136(N) connected to or in the proximity of the smart network host device 120 before proceeding to step 403 of method 400. The presence of the ID device 136(N) disposed on or near the smart network host device 120 provides an additional layer of security for the smart network 102 that prevents unauthorized devices from even attempting to access or register with the smart network 102.
In step 403, based on the determination that the client device 130(N) or service making the registration request has been previously associated with the smart network 102 via the ID device 136(N), the smart network host device 120 initiates a secure password authentication protocol with the client device 130(N) or service. The secure password authentication protocol is a protocol handshake between the client device 130(N) and the smart network host device 120, and is used to set up a secure connection between the smart network host device 120 and the client device 136(N). Such a protocol includes a dual challenge mechanism, in which the authorization credential 240 is never broadcast between the client device 130(N) and the smart network host device 120. Instead, using encryption algorithms known in the art, the client device 130(N) proves to the smart network host device 120 that the client device 130(N) has the authorization credential 240 and the smart network host device 120 proves to the client device 130(N) that the smart network host device 120 also has the authorization credential 240. If either device fails to provide the correct information during such a protocol handshake, the other device terminates the session and no network connection will be established therebetween. Upon successful completion of the secure password authentication protocol, method 400 proceeds to step 404.
In step 404, the smart network host device 120 registers the client device 130(N) or service with the smart network 102. Upon registration of the client device 130(N), the smart network host device 120 and the client device 130(N) each create a session key based on the authorization credential 240, which is known to both. Since an identical authorization credential 240 is used by both the smart network host device 120 and the client device 130(N), the session key created by each is identical to the other. Thus, all subsequent messages between the smart network host device 120 and the client device 130(N) can be encrypted based on this session key, so that a secure connection is maintained between the smart network host device 120 and the client device 130(N). Specifically, for the duration of the session, both the smart network host device 120 and the client device 130(N) only accept messages correctly encrypted with this session key. It is noted that the session key created in step 404 is not broadcast or otherwise transmitted between the smart network host device 120 and the registered client device 130(N) or service, and is only used as an encryption key for encrypting and decrypting messages between the smart network host device 120 and the registered client device 130(N) or service.
In some example embodiments, an additional step 405 is performed when a user has removed the ID device 136(N) from close proximity to the smart network host device 120 and/or physically disconnected the ID device 136(N) from the smart network host device 120. In step 405, the smart network host device 120 detects that the ID device 136(N) is no longer present, and, in response, automatically terminates the association of the client device 130(N) with the smart network 102. Thus, in such example embodiments, a user may disconnect a client device or service by simply removing the associated ID device 136(N) from the smart network host device 120. In other example embodiments, the smart network host device 120 does not terminate the association of the client device 130(N) with the smart network 102 upon detecting the removal or disconnection of the ID device 136(N) from the smart network host device 120.
In sum, example embodiments of the invention provide systems and methods for automatically registering a client device or service with a smart network. A network association apparatus automatically provides identification information and an authorization credential that are associated with the client device or service to be connected to a wireless network. The network association apparatus advantageously enables the host device of the wireless network to automatically associate the client device or service to the wireless network with little or no user involvement required, while providing an additional layer of security to the process of accessing the wireless network. The added security layer stems from the required possession of the network association apparatus and its proximity to the smart network host device in order to associate a client device or service to the smart network.
One embodiment of the invention may be implemented as a program product for use with a computer system. The program(s) of the program product define functions of the embodiments (including the methods described herein) and can be contained on a variety of computer-readable storage media. Illustrative computer-readable storage media include, but are not limited to: (i) non-writable storage media (e.g., read-only memory devices within a computer such as CD-ROM disks readable by a CD-ROM drive, flash memory, ROM chips or any type of solid-state non-volatile semiconductor memory) on which information is permanently stored; and (ii) writable storage media (e.g., floppy disks within a diskette drive or hard-disk drive or any type of solid-state random-access semiconductor memory) on which alterable information is stored.
While the foregoing is directed to certain example embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof. Therefore, the scope of the present invention is determined by the claims that follow.
This application claims benefit of U.S. provisional patent application Ser. No. 61/327,072 (Attorney Docket No. CPOL970592), filed Apr. 22, 2010, which is herein incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61327072 | Apr 2010 | US |