Wireless sensor networks offer significant advantages in factory environments, as the cost of running wire can range from $40 to $2000 per foot. Readily available commercial sensors include radios with encryption capability. However, secure frameworks for sensor networks lack robustness, as they tend to focus on a limited number of threats. A more viable solution has to consider a greater number of security threats, and attempt to reduce the risk in as many as possible. It must also be practical and flexible to allow deployment in a variety of environments.
Conventional sensor networks present additional implementation challenges. Battery-powered sensors must limit power consumption to be practical. They also may have limited support hardware for encryption such as asymmetric keys.
On-site and off-site attacks on sensor networks may be categorized as different due to a difference in detection and response. Further, reverse engineering, devices with back doors, and physical attacks are considered as threats to sensor networks as well.
No secure framework can eliminate all threats. However, all of the threats must be considered to evaluate the effectiveness of the approach.
According to an exemplary embodiment discloses a system provides wireless network device authentication. The system comprises creating a secure communications network using one or more backend servers, one or more network gateways, a plurality of wireless routers, a plurality of leaf-node sensors, each having a unique a device key. The backend servers, network gateways, wireless routers and leaf-node sensors are connected via a communications network and the backend server and the network gateway authenticates the device key of a leaf-node sensor. The network gateway creates a device site key that is unique to the communications network and allows the backend servers, gateway servers, wireless routers and leaf-node sensors to communicate with each other. Next the network gateway authenticates the leaf-node and creates a leaf-node router key to set up a secure link between the leaf-node and the wireless router, and the wireless router creates a unique Session Key for each authenticated leaf-node thereby establishing a secure communications network.
According to another exemplary embodiment, a method provides a method for providing network device authentication. The method comprises installing a unique device key in a network device and creating a chain of keys, wherein each subsequent key is encrypted using the previous key. The method executes an authentication process for storing and issuing keys, wherein the authentication process uses the unique device key to install a device site key in the network device and uses the device site key and the unique device key to authenticate the network device for communicating with a wireless network router, wherein the wireless network router creates a unique network-device-router key. The unique network-device-router key is used to authenticate the network device for communicating over a wireless network using an encrypted network Session Key and allows encrypted link layer communication over the wireless network based on the network Session Key.
Described herein are systems and methods for providing security architecture having a secure framework for wireless sensor networks. The security architecture includes a wireless sensor network 90 shown in
The leaf-nodes 130 and wireless network routers 120 may be off-the-shelf devices. The gateway server 110 may be a desktop computer system or server running various authentication programs for communicating with the wireless network router 120 and the leaf-nodes 130. The connection to the backend server 100 is optional, as some customer sites may not have Internet access.
In exemplary embodiments, the leaf-nodes 130 may act as a router 120, which allow a wireless mesh network 150 to be established, as shown in
The wireless sensors networks 90 shown in
The leaf-node 130 is one of the most vulnerable links in the wireless network 90. It is somewhat limited in capability, being battery powered. Therefore, the mechanism the leaf-node 130 uses to authenticate itself to others and that it uses to authenticate others to itself is the major issue addressed in the embodiments described herein. In particular, the leaf-node 130 authenticates itself to the wireless network router 120 and vice versa. Oftentimes, the only link between the leaf-nodes 130 and the other components in the network 90 is the wireless link. The other major components, the wireless network router 120, gateway server 110 and back-end server 100, are hard wired devices that have other security frameworks in place.
In exemplary embodiments, the security architecture uses pair-wise encryption keys to authenticate devices. That is, when two devices wish to authenticate each other, they use a shared secret key that those two devices know. Only those devices know these key pairs, which they may share with each other over the gateway server 110. The gateway server 110 may then store all of the key pairs. In an exemplary example, the security architecture uses symmetric keys (where one key is shared between two or more systems). Because of the limitations of the leaf-nodes 130 in an exemplary embodiment, all keys used by the leaf-nodes 130 are based on the native support for encryption built into the off-the-self devices.
In exemplary embodiments, four different keys are used to authenticate a leaf-node 130 on the wireless sensor network 90. The architecture is designed so that if one of the keys is compromised, the damage is limited. In some cases the loss of security is limited to a single system rather than the whole network 90. When the loss is discovered, the key can be revoked, ensuring no loss of confidence in the integrity of the wireless sensor network 90.
The security protocol provides a way to install and transport keys, as well authenticates the devices. Each key has different life spans, and different ways to being installed in the leaf-node 130.
The leaf-node 130 has several different security states in its normal lifecycle. The diagram 200 in
The first state 210 begins when the leaf-node 130 is assembled in the factory. For example, at the manufacturing facility, a system connects to the leaf-node 130 as part of the final test. Soon after the leaf-node device 130 passes quality assurance (QA), a unique Device Key (DK) is created and stored in the leaf-node 130. The DK is a unique identification number or serial number. It may also be a unique media access control (MAC) address. After the last step in the manufacturing process, the leaf-node device 130 only has one key stored in memory. Ideally, no two leaf-nodes 130 will have the same DK. The first state 210 can also occur after a command to reset the firmware of the leaf-node device 130 to the initial state (as part of the decommission state). In an alternative embodiment, there may be one or more second device keys, which are created and installed by the customer. As the leaf-node 130 is installed in the network 90, the DK is also stored in the gateway server 110.
Wireless connections can be eavesdropped upon; therefore, man-in-the-middle attacks are possible. As an example, consider two identical devices using the same wireless network 90; there is typically no way to distinguish between these two identical leaf-nodes 130. DKs are installed in the devices ideally using a physically secured channel to ensure they are not copied and to distinguish the leaf-nodes 130 over the wireless network 90.
The DK is designed to be unique so that no two leaf-nodes 130 have the same DK. Ideally, a cryptographically strong random number generator is used to create the DK. As part of the installation, the random number generator also creates non-repeatable values called a nonce. The nonce could be a random number, a timestamp, or a monotonically increasing number. The nonce is used both to prevent old numbers from being repeated and to prevent replay attacks. In one embodiment, the DK is created using a nonce.
The customer has a mechanism to obtain the DK, without interception by others. For example, the DK might be obtained from the manufacture via a secure communication, via a CDROM, printout, etc. Also, as the device becomes more personalized by the customer, additional keys may be installed in the leaf-node 130 using the previous keys. These keys can come from one or more backend servers (sometimes called the Key Authority or the Key Distribution Centers) and are installed on the leaf-nodes 130. In general, lower (or earlier installed) keys are more valuable, but less localized. Once a key is installed, a lower (or earlier) key is required to update/refresh any new keys.
The sequence for installing the DK is described in
The key is installed using a physically secure link (such as Serial, USB, or Infrared, ideally a communication channel that protects the data from eavesdropping). The leaf-node 130 does not ever expose the DK in a plaintext (unencrypted) form over the secure interface. Therefore if the communication data was observed, the new DK would still be encrypted. In an exemplary embodiment, once the DK has been set, it cannot be changed using the physically secure interface, this prevents someone from reassigning and reusing the existing device with a new DK. Therefore, if a used leaf-node 130 is obtained, it cannot be used unless the DK is also obtained from the owner or manufacturer. This prevents the selling of stolen leaf-nodes 130 and ensures that all leaf-nodes 130 use the manufacturer's keys. This process also ensures the firmware of the leaf-nodes 130 remains unmodified.
The DK is designed to be unique and permanent. The firmware in the leaf-node 130 inhibits unauthorized persons from changing the DK. However, the device manufacturer may change the DK during firmware updates or under other conditions. In another embodiment, the vendor may provide a second DK, installed using the first DK. The secondary DK may have an expiration period. Therefore, the second key may have to be refreshed periodically by using the first DK.
As shown in the diagram in
The gateway server 110 is essentially the “keeper” of the customer keys. Therefore, the gateway server 110 can revoke the DSK of any leaf-node 130 at any time for various reasons. For example, the gateway server 110 may explicitly revoke the key to address a threat, such as direct attack on the device. The leaf-node 130 may also be decommissioned. Decommissioning of the leaf-node 130 may be temporary or permanent. If the decommission is permanent, the DSK can be erased on the gateway server 110 and optionally on the leaf-node 130. The leaf-node's 130 DSK may also be revoked if the leaf-node 130 has been engaged in unauthorized or suspicious behavior. Further, the leaf-node's 130 DSK may be revoked if the leaf-node 130 fails to communicate with the network 90 within a specified time period. The DSK is usually installed using the physically secure link rather than the wireless link. However, the DSK may be revoked over the wireless link. The gateway server 110 may also store additional information about the DSK for a specific leaf-node 130, such as the locations, networks, buildings, etc., to which the leaf-node 130 is allowed to connect to.
In an exemplary embodiment, as shown in the diagram in
Each leaf-node 130 BK pair is unique. Only three entities at each site have knowledge of this key, including for example, the gateway server 110, the wireless network router 120 and the leaf-node 130. The gateway server 110 can revoke the BK and can communicate this revocation to the wireless router 120. This process effectively revoking the secure link between the leaf-node 130 and the wireless router 120, which may occur under the same conditions as when the DSK is revoked or disabled.
The diagram in
If the wireless router 120 is used as a mesh router 150 as shown in
Referring to
Also note, the BK is transmitted to the router 120 encrypted using a RouterKey, which is a shared key known to the gateway server 110 and the router 120. If a secure TCP/IP communication channel is used, then another form of encryption could be used, including trusting the link-layer encryption was sufficient.
Once the authenticated link between the leaf-node 130 and the wireless router 120 is established, the devices are enabled to communicate with each other. However, the devices are not able to communicate using link layer encryption. Therefore, as shown in the diagram in
The SK sequence, shown in
Also, several SKs may be pre-stored in the leaf-nodes 130 before being used, to allow quick SK changes. For example, the wireless router 120 may broadcast the SK changes wirelessly. However, some leaf-nodes 130 may be asleep to conserve power. In such cases, the radio is turned off. Therefore, the SK cannot be updated until the leaf-node 130 wakes up and the wireless router 120 transmits the new SK to the leaf-node 130. To prevent a delay however, the pre-stored SKs allow the leaf-nodes 130 to communicate with the network 90 once the leaf-nodes 130 awake and become active.
In addition, the system can exclude a device from getting a SK update. For instance, if a device is under attack, it may be desirable to change the SK for all devices except the one under attack. The use of multiple SKs may allow the router 120 to act as a “honeypot” device by feeding wrong information to the leaf-node 130 that is under attack.
In one embodiment, the design uses SKs with corresponding SK numbers. The SK numbers are used to identify different keys without requiring transmission of the full SK. In one implementation, the SK number is two (2) bytes and the full SK is sixteen (16) bytes. The number of bytes may vary by application, however.
In general, the SK is installed over the radio link using the message sequence shown in
The SK update is (or can be) identical to the SK installation request, with the exception that the wireless router 120 responds to the SK request from the leaf-node 130 with the Session Key Update packet SessionKeyUpdate(E(LeafRouterKey,LeafNode-ID,Router-ID,NewSessionKey, NewSessionKeyNumber)), which contains the new SK and SK number as shown in the diagram in
Included in the encrypted packet is a SK number, which allows the wireless router 120 to send several keys to the leaf-node 130 for storage ahead of time. It also waits for the leaf-node 130 to acknowledge the SK reception. A SK update response may not change the current SK.
If the router 120 has no more SK pairs to send, it can respond to the requested SK packet with either a status packet (if the leaf-node 130 already knows the current SK) or with the SK response (which sends the current SK again).
The architecture allows the router 120 to broadcast a packet to all leaf-nodes 130 to change SKs to a new number. Alternatively, the design allows the router 120 to change SKs for leaf-nodes 130 individually. For example, as shown in
In one embodiment, the SK change is accomplished using link layer encryption as shown in the E(NewSessionKey,AckSessionKey,SessionKeyNumber) packet presented in
Note however, as shown in
It is possible to quickly change Session Keys up to the number of keys previously stored in the leaf-node 130. It also enables the wireless router 120 to skip one of the SKs in case one of the leaf-nodes 130 did not acknowledge receiving it. The router 120 can use other mechanisms to install different SKs and key numbers in the leaf-nodes 130, and choose which is the best SK to use.
The router 120 can also pre-install several SKs. That is, each leaf-node 130 has at least one “spare/unused” SK when a second SK is installed. Suppose the leaf-nodes 130 are using SK-A, and the next is SK-B. The router 120 could be in the middle of updating all the SKs to SK-C, when it is interrupted with a requirement to update all SKs immediately. It cannot change all SKs to SK-C because not all leaf-nodes 130 have acknowledged receiving this key. Therefore, it would have to update all leaf-nodes 130 to SK-B and then install SK-C on the remaining leaf-nodes 130. If a leaf-node 130 is not able to switch to SK-B (or the new SK), it can request one from the wireless router 120 using one of the previously described SK install sequences.
The sequence shown in
The protocol sequence described above prevents a compromised leaf-node 130 from learning a new SK. Therefore, the router 120 sends new SKs to all of the other leaf-nodes 130 except for the one compromised. The compromised leaf-node 130 is not updated with the new SK. Any SKs previously stored in the leaf-nodes 130 are deleted and the router 120 creates new SKs and updates all uncompromised leaf-nodes 130 with the new SKs. Alternatively, the router 120 revokes the SK for all leaf-nodes 130, forcing each leaf-node 130 to initiate a sequence to obtain a new SK. In exemplary embodiments, the wireless network router 120 and leaf-node 130 periodically query each other to make sure the other device is still listening on the network 90. If the devices are unable to communicate, the leaf-node 130 is disconnected from the network 90. If this happens for an extended period of time, the leaf-node 130 may have to re-authenticate itself, perhaps even to a different wireless router 120. Every key the leaf-node 130 has, except for the DK, may be revoked if the leaf-node 130 has been disconnected for longer than the valid timeout period set by the system administrator.
The sequence shown in
In an alternative embodiment, the heartbeat sequence shown in
Further in exemplary embodiments, if the leaf-node 130 has timed out for an extended period, the leaf-node 130 may be decommissioned. When decommissioning occurs, all keys of the leaf-node 130 are invalidated except the DK. In exemplary embodiments, this is what may occur if the gateway server 110 revokes all the keys used at a particular site. The gateway server 110 may also revoke all keys associated with a particular leaf-node 130 if the leaf-node 130 appears to be missing for a specific period of time. The leaf-node 130 may still contain the keys, however they may be invalidated at both the gateway server 110 and the wireless router 120.
Physically connecting the leaf-nodes 130 to the gateway server 110 and performing a firmware reset also may also be used to decommission the leaf-nodes 130. This process erases all keys within the leaf-nodes 130 except the DK set by the manufacture. This allows the leaf-nodes 130 to be restored back to their original state 210, shown in FIG. 3., before the customer installed leaf-nodes 130 into the wireless network. In this state, each leaf-node 130 may be resold or used by another customer. Periodically the firmware in the leaf-nodes 130 may require updating. The sequence shown in
The discussion above provides an overview of the communication links between the hardware devices. However, the architecture uses several means of data encryption. The process and method of encryption is discussed in detail below.
The process provides encryption security using existing and readily available encryption hardware. In the exemplary embodiment, an IEEE 802.15.4 wireless personal area network standard is used. The 802.15.4 packets support several MAC (Media Access Control)-layer (or link layer) encryption and authentication schemes. In one embodiment a Chipcon® CC2420 radio, utilizing hardware-based AES-CCM-128 for both data-layer and MAC encryption and authentication is used.
In exemplary embodiments, the development environment used TinyOS® to implement the algorithms. The packet format for transmitting the MAC address is shown in
The generation of a nonce value can be the same source as the MAC-layer nonce. That is, the same monotonically increasing value can be used. This simplifies the detection of replay attacks by the sensor.
In discussing the encryption technologies, the following terminology is used: leaf-node sensors (S) with unique identifier (IS) communicates to authorities (A) to obtain keys (K). Encrypted messages are indicated by { . . . }K.
Authentication is based on paired symmetric keys, where only two devices use the key to authenticate each other. The generalized key installation is shown in these three steps.
Key KN is therefore used to install key KN+1. As explained below, the encryption scheme is based upon the use of key chains. Each subsequent key is encrypted using the previous key, such that K0→K1→K2→K3→ . . . KN (or KV→KS→Kbootstrap→KMAC). The sensor verifies the key validity by checking the identification number and nonce within the encrypted response matches. The nonces N1, N2 are used to prevent replay attacks.
In exemplary embodiments, the communication channel need not be secure because data-layer encryption is used. However, if the channel allows multiple leaf-node devices 130, care has to be taken to ensure the leaf-node device 130 identification matches the device being initialized. Relays can be used to install keys. Nonce N2 is used to confirm the device received the proper key. Nonce lifetime is sufficient to allow for long-latency authentication, which allows a form of off-line authentication.
The knowledge of KN beforehand is the primary threat in this approach. Nonce predictability is an issue for the authority A in step 3, which is prevented by a cryptographically strong random number generator (RNG). The nonce for the leaf-nodes 130 is a potential problem. Trusted timestamps and RNG's require additional resources that may not be available in a leaf-node 130; therefore it is assumed that leaf-nodes 130 use a monotonically increasing number, and authentication devices that validate these numbers remember the last number used for each leaf-node 130. The symbol “→” indicates the transmission of a packet without MAC encryption, and “” indicates MAC encryption as a visual aid.
There are advantages to making this key installation mechanism generalized. While the exemplary embodiments above disclose a process with only four keys for the framework, two (or more) additional keys may be added to allow greater flexibility, as described below.
The leaf-node manufacturing facility produces nearly identical leaf-node devices 130, installing a common key K0 (=Null) into the firmware, while also installing a unique identification (DK) into the device. A key installation mechanism installs a unique key K1 (=DK) into the device. As K0 is known, this must be a private and secured communication channel:
The K1 can, if the vendor desires, be used to install a secondary vendor key K2. Key K2 can be constructed to expire after a period of time.
When the customer receives the leaf-node 130, and obtains the identification, it obtains a key KV from the vendor. Depending upon the implementation, KV can be K1 or K2. There are several mechanisms that can be used to obtain the key, such as a CD-ROM, a web server, tear-off labels, etc. The vendor can revoke keys based on ISin the case of stolen or cloned devices by refusing to tell the customer the key. The vendor can verify the identity of the device by examining N2. If KV is K2, the key can be designed to expire after a certain time period to force the customer to refresh the key. If KV is K1, once that key is obtained, the customer does not need to use the vendor services to enable the leaf-node device 130 in the future.
The customer then installs the unique-per-device site key KS.
And can optionally install an end-to-end authenticity key KA.
Battery-conserving leaf-node devices 130 typically “sleep”—with their radios disabled. Therefore, the leaf-node sensor 130 initiates all wireless protocol sequences described below. Protocol sequences typically end with a status packet from the router 120 to a leaf-node 130, which identifies pending sequences.
A leaf-node 130 joining the network 90 for the first time needs to locate and verify the identity of the nearest router 120. The router 120 has already been authenticated for the network 90, and has its own key KRouter (RouterKey) known to the site authority. A two-phase sequence is used to obtain the MAC key. The first sequence obtains the bootstrap key KBootstrap (BootstrapKey).
This sequence enables the site authority to create and install a new bootstrap key that enables the router 120 and leaf-node sensor 130 to authenticate each other. Note that the message in (15) is opaque to the router 120, which forwards the request for a BK to the site authority for authentication in (16). The site authority returns two encrypted messages in (17) and the router 120 forwards one of these to the leaf-node 130 in (18).
Once the bootstrap key is obtained, the leaf-node 130 is able to get the MAC key, KMAC, along with an 8-bit key identification number K#.
As K# is 8 bits wide, the 802.15.4 radio supports up to 256 keys for MAC encryption. These keys may be shared (broadcast, peer-to-peer communication) or unique per router-sensor pair. Note that sequences (21) and (22) use MAC (Link Layer) encryption key KMAC.
The 802.15.4 packet specifications support 256 different keys and the key number K# (which corresponds to Key# in
The status word is used to indicate pending actions for the leaf-node 130. This may include the number of keys pending, number of valid keys, and time until the current key expires. Therefore, the leaf-nodes 130 can repeat sequences 19-22 to obtain additional keys.
The router 120 keeps track of the keys known to each leaf-node 130. This allows the router 120 to change keys once it confirms that all of the leaf-nodes 130 know the new key. It also allows the router 120 to partition the knowledge of the subordinate leaf-nodes 130, allowing it to quickly exclude a compromised leaf-node 130.
At the end of each sequence, the leaf-node 130 will examine the status packet, and decide if it needs to perform additional actions. One of these actions is to ask for a new MAC key. This sequence is as follows:
Sequences 25 and 26 could also use MAC encryption as well for increased security. The router 120 can pre-load several keys in advance, and keep track of which leaf-nodes 130 know which key numbers, which allows the router 120 to smoothly switch to a new MAC key by selecting one known to all devices. It can purposely exclude or isolate devices by category if it needs to. Key changes can be synchronized by clock as well, with the status telling the sensor the time until the next key change.
If a device discovers it no longer has a valid MAC key, it can fall back to (19) or even (13) to obtain the key.
While the network 90 is in operation, devices can be physically attacked. Inhibiting these attacks is difficult. An alarm mechanism is added to the architecture sequences to respond to a detected intrusion attack, either physical or over the network 90 (i.e. brute force, replay, etc.):
When a physical attack is detected, the leaf-node 130 sends an alert to allow the router 120 and site authority (gateway server 110) to react in a series of escalations. The site authority may first change any shared KMAC. The site authority can then revoke the KBootstrap key and temporarily prevent any new key from being issued. Finally, the KV key can be revoked.
It may be possible for an attacker to physically compromise a device without detection, while the device is connected to the network 90 and obtain the keys stored within. Denial-of-service attacks are also possible. A leaf-node device 130 may also be physically removed from the network 90. To prevent such attacks, a heartbeat function is used to detect attacks on the leaf-nodes 130 as well as unavailable or missing devices.
Sequences (29) thru (32) allows the router 120 to authenticate each leaf-node 130 and check its status through a heartbeat function. Routers 120 can summarize the status information and pass it up to the site authority. The response from the site authority or router 120 to a missing leaf-node 130 can escalate in time, as mentioned earlier. Keys issued to the leaf-node 130 can be changed, temporarily prevented from re-issuing and finally revoked.
Up to this point, the framework provides link-to-link authentication. However, a trusted but compromised router 120 could also modify data en route. In one embodiment, intrusion detection devices are used to log and inspect packet contents, and optionally decrypt data. In order to enable this packet inspection, an end-to-end authenticity key KA is installed in link-layer (7)-(9). A leaf-node 130 uses this to sign and/or encrypt data in addition to MAC-encryption. Any device that knew this key could authenticate and decrypt the data, but it would be unable to join the network 90 or obtain the MAC-layer key used for that link. The routers 120 log the packets generated.
The key installation protocol is used over-the-air to update/replace the end-to-end authentication key, while giving the old key to intrusion detection devices.
TinyOS® provides a way to update software with the “Deluge” extension. In one embodiment, the firmware is transmitted using MAC encryption, and hash of the firmware H, along with the revision identification IREV, be signed by Ks:
In general, the vendor creates KV, and the customer site authority creates the other keys. Optionally the router 120 may create KMAC for efficiency reasons.
The keys can be revoked under conditions listed in Table 1. Note that if a key is revoked, the key in the row above it must be used to obtain another key.
The vendor may also revoke individual keys if desired, in high-security situations. A more practical approach is to simply let the vendor key expire.
Different sites can determine the number of KMAC keys to use. One site can use a single shared key, a second can use one key for each router 120, and a third can use unique keys for every link.
In some devices, authentication may use less power than encryption and authentication. Therefore, authentication alone may be preferable to save power. There are many other power optimization techniques that may be applied to this architecture as well.
The number of keys necessary to remember is proportional to the importance of a device in the infrastructure. Assuming the 4-key mechanism (KV, KS, KBootstrap, KMAC), an end-node sensor would need to know 2+2N keys, where N is the number of mesh routers 150 it talks to. A mesh router 150, with N peer routers 120, and M leaf-nodes 130, would need to know up to 2+2N+2M keys. Because of the limitations in the 802.15.4 framework, each router 120 or mesh router 150 is limited to 256 different MAC-layer keys. The KDC has the greatest burden, by needing to know all of the keys. The worst case would be unique KMAC keys, with every device able to communicate with every other device.
While the invention has been described with reference to only a limited number of exemplary embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted for elements thereof without departing from the scope of the invention. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the invention without departing from the essential scope thereof. Therefore, it is intended that the invention not be limited to the particular embodiment disclosed as the best mode contemplated for carrying out this invention, but that the invention will include all embodiments falling within the scope of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
11762819 | Jun 2007 | US | national |
This application claims priority to U.S. Provisional Application Ser. No. 60/832,642, filed Jul. 21, 2006 and U.S. application Ser. No. 11/762,819, filed Jun. 14, 2007 of which both are incorporated herein by reference in their entirety.
This invention was made with Government support under Contract No. DE-FC36-04GO14001 awarded by the United States Government. The Government has certain rights in the invention.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US07/73602 | 7/16/2007 | WO | 00 | 5/23/2008 |
Number | Date | Country | |
---|---|---|---|
60832642 | Jul 2006 | US |