The present invention relates to data management systems. Particularly, the invention relates to novel methods and devices for establishing by a handshake procedure a group temporal key for securing group communication.
In data communication, a term handshaking can be determined e.g. as referring to a sequence of events governed by hardware or software, requiring mutual agreement of the state of the operational modes prior to information exchange. The handshaking may also be used to verify that the other party is what it claims to be.
Various kinds of handshaking procedures are known in both wired and wireless environments. A typical way to implement a derivation of a session key for securing further communication is to use pairwise handshake procedures. The pairwise handshake procedures are executed between two parties. If group communication is desirable, each group member has to execute pairwise handshake procedures separately with every other group member, thus resulting a common pairwise temporal key between the two parties performing the handshake.
The established pairwise temporal keys may be used to distribute a session key, that is, a group temporal key, to other members in the same group. The session key establishment of group communication is significantly cumbersome as the number of members or member devices in the group grows. The session keys may be sender-specific, and the number of session keys for a group may be equal to the number of members in the group. For example, if a group consists of eight members, each member has to perform a pairwise handshaking procedure with the remaining seven group members. After that, each member has to distribute its session key to each other member in the group by using the pairwise temporal keys.
Based on the above there is an obvious need to simplify the usage and establishment of the session keys.
According to a first aspect of the invention, there is provided a method for establishing, by a handshake procedure, a group temporal key for group communication. The method comprises providing a handshake initiator with a shared group key, a group key identifier and a group identifier, the group identifier identifying the group members, wherein the group comprises at least three members; generating a group temporal key identifier; generating an initiator random number; creating an initiating message comprising the group identifier, the group key identifier, the group temporal key identifier, and the initiator random number; sending the initiating message to other group members; receiving a response message from at least one group member, the response message comprising a random number of the sender of the response message; determining, whether response messages have been received from a predetermined set of group members; and calculating the group temporal key with at least a key derivation function, the shared group key identified by the group key identifier, and at least one random number from a set of the initiator random number and the received random numbers, when a response message have been received from the predetermined set of group members.
The first aspect of the invention may further comprise one of the following embodiments separately or in combination with at least one other embodiment.
In one embodiment, when determining that response messages have not been received from the predetermined set of group members, the first aspect further comprises: reinitiating the handshake procedure, and aborting the handshake procedure.
In one embodiment, in the group temporal key calculation random numbers of all the group members belonging to the predetermined set of group members are used.
In one embodiment, the predetermined set of group members comprises all the group members.
In one embodiment, the predetermined set of group members comprises a subgroup of all the group members.
In one embodiment, the handshake procedure is reinitiated, when detecting a group member from which a response message was not received.
In one embodiment, the first aspect further comprising: sending a message comprising random numbers used in calculating the group temporal key to the group.
In one embodiment, the first aspect further comprises: sending a message comprising random numbers used in calculating the group temporal key and sender information of the received random numbers to the group.
In one embodiment, the first aspect further comprises: sending a message comprising random numbers used in calculating the group temporal key, the group key identifier and the group identifier to at least one group member from which a response message was not received.
In one embodiment, the first aspect further comprises: indicating in the message whether the order of the initiator random number and the random numbers used in calculating the group temporal key is significant.
In one embodiment, the group key identifier and the group identifier are comprised in a single identifier.
In one embodiment, the handshake procedure is performed in the data link layer.
In one embodiment, the handshake procedure is performed above the data link layer, and the first aspect further comprises: transporting the calculated group temporal key to the data link layer.
According to a second aspect of the invention, there is provided a method for establishing, by a handshake procedure, a group temporal key for group communication. The method comprises: providing a handshake responder with a shared group key, a group key identifier and a group identifier, the group identifier identifying the group members, wherein the group comprises at least three members; receiving an initiating message from a handshake initiator, the initiating message comprising the group identifier, a group temporal key identifier, and an initiator random number; receiving a response message from at least one group member, the message comprising a random number of the sender of the message; determining, whether response messages have been received from a predetermined set of group members; and calculating the group temporal key with at least a key derivation function, the shared group key identified by the group key identifier, and at least one random number from a set of the initiator random number and the received random numbers in the at least one received response message, when a response message has been received from the predetermined set of group members.
The second aspect of the invention may further comprise one of the following embodiments separately or in combination with at least one other embodiment.
In one embodiment, the second aspect further comprises: generating a responder random number; creating a response message that comprises at least the responder random number; and sending the response message to other members of the group.
In one embodiment, when determining that response messages have not been received from the predetermined set of group members, the second aspect further comprises: aborting the handshake procedure.
In one embodiment, in the group temporal key calculation random numbers of all the group members belonging to the predetermined set of group members are used.
In one embodiment, the predetermined set of group members comprises all the group members.
In one embodiment, the predetermined set of group members comprises a subgroup of all the group members.
In one embodiment, the second aspect further comprises: receiving, from the handshake initiator, a key calculation message comprising random numbers used by the handshake initiator in calculating the group temporal key; checking, whether the handshake responder has received the same random numbers as comprised in the key message; using in calculating the group temporal key the random numbers comprised in the key message, when the result of the checking is affirmative; and aborting the handshake procedure, when the result of the checking is negative.
In one embodiment, the second aspect further comprises: receiving, from the handshake initiator, a key calculation message comprising random numbers used in calculating the group temporal key and corresponding sender information of the random numbers; checking, whether the handshake responder has received the same random numbers from the same senders as comprised in the key message; using in calculating the group temporal key the random numbers comprised in the key message, when the result of the checking is affirmative; and aborting the handshake procedure, when the result of the checking is negative.
In one embodiment, the group key identifier and the group identifier are comprised in a single identifier.
In one embodiment, the handshake procedure is performed in the data link layer.
In one embodiment, the handshake procedure is performed above the data link layer, and wherein the second aspect further comprises: transporting the calculated group temporal key to the data link layer.
According to a third aspect of the invention, there is provided a method for establishing, by a handshake procedure, a group temporal key for group communication. The method comprises: providing a group member with a shared group key, a group key identifier and a group identifier, the group identifier identifying the group members, wherein the group comprises at least three members; receiving, from a handshake initiator, a key calculation message comprising a group temporal key identifier, a group identifier and random numbers of those group members which were used in calculating the group temporal key; and calculating the group temporal key with at least a key derivation function, the shared group key identified by the group key identifier, the group identifier, and the received random numbers.
In one embodiment, the third aspect further comprises: indicating in the key calculation message whether the order of the random numbers in calculating the group temporal key is significant.
According to a fourth aspect of the invention, there is provided a device for establishing, by a handshake procedure, a group temporal key for group communication. The device comprises a transceiver configured to communicate with other group members over a wired or wireless connection; and a handshake unit comprising a shared group key, a group key identifier and a group identifier, the group identifier identifying the group members, wherein the group comprises at least three members; wherein the handshake unit is configured to: generate a group temporal key identifier; generate an initiator random number; create an initiating message comprising the group identifier, the group key identifier, the group temporal key identifier, and the initiator random number; send the initiating message to other group members; receive a response message from at least one group member, the response message comprising a random number of the sender of the response message; determine, whether response messages have been received from a predetermined set of group members; and calculate the group temporal key with at least a key derivation function, the shared group key identified by the group key identifier, and at least one random number from a set of the initiator random number and the received random numbers, when a response message have been received from the predetermined set of group members.
According to a fifth aspect of the invention, there is provided a device for establishing, by a handshake procedure, a group temporal key for group communication. The device comprises a transceiver configured to communicate with other group members over a wired or wireless connection; and a handshake unit comprising a shared group key, a group key identifier and a group identifier, the group identifier identifying the group members, wherein the group comprises at least three members; wherein the handshake unit is configured to: receive an initiating message from a handshake initiator, the initiating message comprising the group identifier, a group temporal key identifier, and an initiator random number; receive a response message from at least one group member, the message comprising a random number of the sender of the message; determine, whether response messages have been received from a predetermined set of group members; and calculate the group temporal key with at least a key derivation function, the shared group key identified by the group key identifier, and at least one random number from a set of the initiator random number and the received random numbers in the at least one received response message, when a response message has been received from the predetermined set of group members
According to sixth aspect of the invention, there is provided a device for establishing, by a handshake procedure, a group temporal key for group communication. The device comprises a transceiver configured to communicate with other group members over a wired or wireless connection; and a handshake unit comprising a shared group key, a group key identifier and a group identifier, the group identifier identifying the group members, wherein the group comprises at least three members; wherein the handshake unit is configured to: receive, from a handshake initiator, a key calculation message comprising a group temporal key identifier, a group identifier and random numbers of those group members which were used in calculating the group temporal key; and calculate the group temporal key with at least a key derivation function, the shared group key identified by the group key identifier, the group identifier, and the received random numbers.
According to a seventh aspect of the invention, there is provided a computer program for establishing, by a handshake procedure, a group temporal key for group communication, the group comprising at least three members, embodied on a computer-readable medium. The computer program is configured to perform the following when executed on a data-processing device: generating a group temporal key identifier; generating an initiator random number; creating an initiating message comprising a group identifier, a group key identifier, a group temporal key identifier, and the initiator random number; sending the initiating message to other group members; receiving a response message from at least one group member, the response message comprising a random number of the sender of the response message; determining, whether response messages have been received from a predetermined set of group members; and calculating the group temporal key with at least a key derivation function, a shared group key identified by the group key identifier, and at least one random number from a set of the initiator random number and the received random numbers, when a response message have been received from the predetermined set of group members.
According to an eight aspect of the invention, there is provided a computer program for establishing, by a handshake procedure, a group temporal key for group communication, the group comprising at least three members, embodied on a computer-readable medium. The computer program is configured to perform the following when executed on a data-processing device: receiving an initiating message from a handshake initiator, the initiating message comprising a group identifier, a group temporal key identifier, and an initiator random number; receiving a response message from at least one group member, the message comprising a random number of the sender of the message; determining, whether response messages have been received from a predetermined set of group members; and calculating the group temporal key with at least a key derivation function, a shared group key identified by the group key identifier, and at least one random number from a set of the initiator random number and the received random numbers in the at least one received response message, when a response message has been received from the predetermined set of group members
According to a ninth aspect of the invention, there is provided a computer program for establishing, by a handshake procedure, a group temporal key for group communication, the group comprising at least three members, embodied on a computer-readable medium. The computer program is configured to perform the following when executed on a data-processing device: receiving, from a handshake initiator, a key calculation message comprising a group temporal key identifier, a group identifier and random numbers of those group members which were used in calculating the group temporal key; and calculating the group temporal key with at least a key derivation function, the shared group key identified by the group key identifier, the group identifier, and the received random numbers.
The advantages of the invention relate to improved efficiency in the handshake procedure.
The accompanying drawings, which are included to provide a further understanding of the invention and constitute a part of this specification, illustrate embodiments of the invention and together with the description help to explain the principles of the invention. In the drawings:
Reference will now be made in detail to the embodiments of the present invention, examples of which are illustrated in the accompanying drawings.
The following embodiment is described using a radio Media Access Control (MAC) layer solution as an example. The Institute of Electrical and Electronics Engineers (IEEE) Wireless Local Access Network (WLAN) specification and the ECMA-368 Ultra Wide Band standard are examples in which the invention may be used. These solutions specify a procedure what is called Group Key Handshake for distribution of temporary session keys for multicast.
In both of the above specifications the group handshake procedures take place between a pair of devices after they have performed a pairwise handshake procedure for derivation of pairwise temporary session keys.
The handshake initiator 100 initiates a group handshake by composing and sending a multicast message to the responders. First the handshake initiator generates a group temporal key identifier (GTKID) (step 104) and a random number (step 106). In one embodiment, the random number is a 128-bit cryptographic random number. The initiating message comprises a proposition for the group temporal key identifier (GTKID) for the group temporal key to be derived, and the above generated random number (denoted as R0), which is freshly generated each time the initiator starts a new handshake. In the initiating message the handshake initiator specifies also a group identity (GroupID). The group identity specifies the group in question to the receivers of the initiating message (step 108). In one embodiment, the GroupID identifier both the group and also the group key (the pre-shared key) to be used. In another embodiment, the handshake initiator separately includes in the initiating message the group identity (GroupID) and the group key identity (GKID).
The handshake initiator broadcasts the initiating message to other members of the group.
The handshake initiator 100 receives the response message comprising the random number R1 (step 114). Similarly, it receives also other random numbers generated by the remaining group members. In step 116, the handshake initiator 100 calculates the group temporal key and optionally also a key confirmation key by using an appropriate function. In one embodiment, the function used is a pseudorandom function and it takes e.g. the following parameters:
The following function can be written:
GTK∥KCK=PRF(GK, GroupID, R0, g(R1,R2, . . . ,R{n−1}),
where the output of PRF is of required size, typically 256 bits. The PRF can be implemented e.g. as HMAC using SHA-256 with the group key (GK) as the key and the rest of the PRF input as the input data. The latter part (128 bits) of the outcome of the PRF function forms the key confirmation key (KCK). It can be used in confirming that the group temporal key (GTK) was properly generated. The PRF function may take also other additional inputs not disclosed above. One additional input may be a string “group_key”, which merely indicates that the result of the PRF function is a group key.
Each of the group members (other than the handshake initiator) performs the same group temporal key (GTK) generation procedure (steps 118, 120). As described above, since the handshake initiator 100 identified the group key (GK) to be used in the initiating message by the group key identity, each of the group members (responders) is able to retrieve the group key using the group key identifier. The calculation of the group temporal key (GTK) is performed exactly in the same manner as in the case of the handshake initiator. The group temporal key (GTK) can then be used to secure multicast traffic from a sending device to a group of recipient devices.
In the above, a g function was used within the PRF function. To avoid ordering and numbering of the group members the function g may be commutative, that is, the output of g is independent of the order of the inputs. An example of a commutative function is:
g(R1,R2, . . . ,R{n−1})=R1⊕R2⊕ . . . ⊕R{n−1}.
If this function is used, a responder can force the output of g to any selected value by waiting others to send their responder random numbers first, and then selecting its own responder nonce appropriately. This does not cause problems if the handshake initiator always selects a fresh random number R0. If this cannot be assumed then it is possible to select g to have sufficient one-way properties to prevent forcing the output to a selected value. Examples of such functions are e.g. a cryptographic accumulator and an exponent function. The cryptographic accumulator may be e.g. the following:
g(R1,R2, . . . ,R{n−1})=prf(R1)prf(R2) . . . prf(R{n−1}),
where is the bitwise “and” of the strings prf(Ri) of suitable length.
Correspondingly, the exponent function may be e.g. the following:
g(R1,R2, . . . ,R{n−1})=αR1·R2· . . . ·R{n−1}mod p.
The solution disclosed in
While the embodiment disclosed in
In step 208 it is determined whether responses have been received from the required group members. However, the term “required” may have different meanings in different embodiments of the invention.
In one embodiment, the group temporal key is not calculated until a random number is received from every group member. Since the handshake initiator and also other group members are aware of the group structure, the handshake initiator is able to determine whether response messages (and thus random numbers) have been received from every group member. Correspondingly, since each handshake responder is aware of the group structure, it is able to determine whether response messages (and thus random numbers) have been received from every group member. If each group member has provided its own random number, the handshake initiator and the handshake responders are able to calculate the group temporal key, step 210, as already discussed in
If a random number has not been received from every group member, the handshake initiator may reinitiate the handshake procedure. An absence of at least one random number also means that all group members were not present when the handshake procedure was initiated. The handshake initiator may reinitiate the handshake procedure again with the same configuration as in the previous case. Another option for the handshake initiator is to reinitiate the handshake procedure with those handshake responders which provided the other members of the group with its own random number.
In one embodiment, there may a parameter that determines the maximum number of reinitiations in a case that a random number is not received from a handshake responder. If the maximum number of reinitiations is reached, and if the handshake procedures are implemented in a MAC layer, the MAC layer may forward a notification to upper layers that the handshake procedure failed. A user acting as a handshake initiator may then decide how to proceed with the handshake procedure.
In another embodiment of
In another embodiment of
In the embodiments disclosed above, it is possible equip the group members with configuration information e.g. when creating the group, the configuration information determining rules e.g. how to proceed when all group members are not present when a handshake procedure is initiated.
The handshake responder receives from at least one other handshake responder similarly broadcast response messages (step 406). Each response message comprises a random number generated by the handshake responder who sent the response message. In step 408 it is determined whether responses have been received from the required group members. However, the term “required” may have different meanings in different embodiments of the invention.
In one embodiment, every group member has to send its own random number for the group temporal key calculation. Therefore, the handshake responder checks whether it has received a response message from all the group members. In this embodiment, each group member has been configured with information that determines the group. In other words, each group member knows those members belonging to this particular group. If the handshake responder has not received a response message from all the group members, it executes a predetermined action (step 412). The predetermined action may e.g. be aborting the handshake procedure. If the handshake responder has received a response message from all the group members, it calculates the group temporal key (step 410). The calculation process of the group temporal key was as already discussed in
In another embodiment, the handshake responder has been provided with configuration information that determines predetermined members of the group as a core part of the group. Therefore, if in step 408 it is determined that all the members in the core part has sent their random numbers in step 406, the handshake responder calculates the group temporal key and uses only random numbers from those group members belonging to the core part in the group temporal key calculation. Correspondingly, if all the group members in the core part have not sent their random numbers, a predetermined action is executed (step 412). The predetermined action may e.g. be aborting the handshake procedure.
The handshake responder receives a broadcast message (initiating message) from a handshake initiator (step 420). Since the handshake responder does not belong to the core part, it does not send a response message in response to receiving the initiating message from the handshake initiator. However, the handshake responder receives from at least one other handshake responder a response message (step 422). In this embodiment, only those group members belonging to the core part broadcast a response message to other group members. Each response message comprises a random number generated by the handshake responder who sent the response message.
In step 424 it is determined whether responses have been received from the required group members. In this embodiment, the handshake responder checks whether it has received response messages from all of the group members belonging to the core part. If it has not, the handshake responder executed a predetermined action (step 412). The predetermined action may e.g. be aborting the handshake procedure.
If the handshake responder has received response messages from all of the group members belonging to the core part, it calculates the group temporal key (step 426) and uses only random numbers from those group members belonging to the core part in the group temporal key calculation. The calculation process of the group temporal key was as already discussed in
In step 448, the handshake responder receives from a handshake initiator a broadcast message comprising a list. In one embodiment, the list comprises those random numbers that the handshake initiator uses in calculating the group temporal key. In another embodiment, the list identifies also which random number relates to which group member. Next, the handshake responder compares (step 450) the list with the random number it received in step 440 from the handshake initiator and in step 446 from other group members.
If the list comprised only random numbers used by the handshake initiator to calculate the group key, the handshake responder checks that it has received the same random numbers in the broadcast messages (response messages) from other members of the group. If the list identifies also the senders of the random numbers, the handshake responder may check that it received response messages (each response message comprising a random number) from the same senders and that a random number of a sender is that same than the random number of the sender in the list.
In one embodiment, the comparison is acceptable only if all random numbers received from the handshake initiator equal with the random numbers received in the broadcast messages. In another embodiment, it may not be necessary that all random numbers received by the handshake responder equal with the random number in the list from the handshake initiator.
If the result of the comparison is acceptable, the handshake responder calculates the group temporal key (step 454) and uses the random numbers in the list in the group temporal key calculation. The calculation process of the group temporal key was as already discussed in
Although not disclosed in
The handshake initiator broadcasts a verification message to the group. In the message, the initiator includes the same random number (R0) as contained in message the initiating message and a cryptographic check code GTK MIC (Group Temporal Key Message Integrity Code) computed for this message using the newly derived Key Confirmation Key (KCK). On the reception of the aforementioned message, the handshake responders shall perform the following two steps.
Correspondingly, the handshake responder broadcasts a verification message the group (step 2 above). In the message, the handshake responder includes the same random number in the response message created in step 112 and a cryptographic check code GTK MIC computed for this message using the newly derived KCK.
On reception of the above message, the handshake initiator and other handshake responders verify the GTK MIC for this message using the KCK. If the calculated GTK MIC does not match with the GTK MIC field in the message, the message is discarded and the handshake is aborted.
When the handshake initiator and the handshake responders have received and accepted all the verification messages, they install the GTK and GTKID for the group.
Although it was disclosed above that the handshake responders wait for a verification message from the handshake initiator and that the handshake responders first verify the message, and only then the handshake responders send their corresponding verification messages, in another embodiment it is possible that that members of a group start the verification procedure at the same time. In other words, when a group member has calculated the group temporal key (GTK) and the Key Confirmation Key (KCK), the group member (both the handshake initiator and the handshake responders) may then start the verification process by sending a verification message that comprises the original random number of the group member and a cryptographic check code GTK MIC computed for the message using the newly derived KCK.
The above verification procedure is only one possible alternative and other methods may also be used.
In step 464, the handshake responder receives from a handshake initiator a broadcast message comprising a list. In one embodiment, the list comprises those random numbers that the handshake initiator uses in calculating the group temporal key. In another embodiment, the list identifier also which random number relates to which group member. Next, the handshake responder compares (step 466) the list with the random number it received in step 460 from the handshake initiator and in step 462 from other group members.
If the list comprised only random numbers used by the handshake initiator to calculate the group key, the handshake responder checks that it has received the same random numbers in the broadcast messages (response messages) from other members of the group. If the list identifies also the senders of the random numbers, the handshake responder may check that it received response messages (each response message comprising a random number) from the same senders and that a random number of a sender is that same than the random number of the sender in the list.
If the result of the comparison is acceptable, the handshake responder calculates the group temporal key (step 470) and uses the random numbers in the list in the group temporal key calculation. The calculation process of the group temporal key was as already discussed in
In the receiving step 480 information, sent in step 304 in
In one embodiment of
The operation of the handshake procedure is controlled by a program logic 500. Some of the information needed in the handshake procedure is received from upper application layers, namely, group-specific information 508. The MAC layer 510 comprises also a group temporal key identity (GTKID) generator 502, a random number generator 504 and a group temporal key (GTK) generator 506.
The operation of the handshake procedure is controlled by a program logic 520. The upper layer 530 comprises also a group temporal key identity (GTKID) generator 522, a random number generator 524, a group temporal key (GTK) generator 526, and group-specific information 528. The group-specific information comprises e.g. a predetermined shared group key, a group key identifier and a group identifier.
When the group temporal key 534 has been derived, the key is provided to the data link layer 532. The key may then be used to secure communication between the group members.
The operation of the handshake procedure is controlled by a program logic 600. Some of the information needed in the handshake procedure is received from upper application layers, namely, group-specific information 606. The MAC layer 608 comprises also a random number generator 602 and a group temporal key (GTK) generator 604.
The operation of the handshake procedure is controlled by a program logic 620. The upper layer 628 comprises also a random number generator 622, a group temporal key identity (GTKID) generator 624, and group-specific information 626. The group-specific information comprises e.g. a predetermined shared group key, a group key identifier and a group identifier.
The dashed block line of the random number generator 602 and 622 means that the random number generator 602 and 622 is an optional feature. Depending on the implementation, the handshake responder may or may not comprise the random number generator 602 and 622.
When the group temporal key 632 has been derived, the key is provided to the data link layer 630. The key may then be used to secure communication between the group members.
The advantages of the invention relate to improved efficiency achieved e.g. by the reduction of number of messages needed to establish a secret session key. Furthermore, in some prior art solutions group members had to first create a pairwise temporary key in order to be able to distribute a group member specific group temporal key to other group members. In other words, each group member has a group member specific group temporal key that has to be distributed among the group members before group communication. The invention introduces a way to establish a single group temporal key common for all group members to secure group communication. It is also evident that the solution also simplifies the idea of using a group temporal key since there is no need to establish separate pairwise temporal keys at all.
It is also evident that amount of information, that is the amount of different temporary keys, needed reduces significantly since there is no need to create or store any pairwise temporary keys. For example, let's assume that a group comprises six members. Each member has to establish a pairwise temporal key with every other group member. Furthermore, every group member has a member-specific group temporal key. As a summary, each group member has five pairwise temporal keys and six group temporal keys (an own group temporal key and five group temporal keys from the other group members). The invention enables to use only one group temporal key common for all group members instead of the multiple pairwise temporal keys and group temporal keys used in prior art.
The exemplary embodiments may be implemented into any device that can be part of a group. The transmission path between the group devices may be a wired or a wireless connection.
Although it was disclosed above that the invention may be used in the IEEE WLAN solutions and the ECMA-368 Ultra Wide Band standard, the disclosed solution is applicable into any architecture that needs group temporal keys to secure group communication. For example, the invention may be applied in the WiNet standard for networking of ultra wide band radio devices by WiMedia consortium. The standard specifies the WiNet Association Model (WAM) procedure, which takes place above the MAC layer and in which a long term Group Key (GK) is distributed to all devices belonging to the group. The session keys, Group Temporary Keys (GTK) for group communication (multicast), are then derived using the MAC layer procedures.
One of the benefits of the invention is that is avoids pairwise handshakes. Furthermore, it decreases the amount of messages between group members. Moreover, the group temporal key is established substantially simultaneously by all group members. Furthermore, since pairwise handshakes and thus pairwise temporal keys are not needed, memory consumption in group member's devices decreases.
It is to be understood that the exemplary embodiments are for exemplary purposes, as many variations of the specific hardware used to implement the exemplary embodiments are possible, as will be appreciated by those skilled in the hardware and/or software art(s). For example, the functionality of one or more of the components of the exemplary embodiments can be implemented via one or more hardware and/or software devices.
The exemplary embodiments can store information relating to various processes described herein. This information can be stored in one or more memories, such as a hard disk, optical disk, magneto-optical disk, RAM, and the like. One or more databases can store the information used to implement the exemplary embodiments of the present inventions. The databases can be organized using data structures (e.g., records, tables, arrays, fields, graphs, trees, lists, and the like) included in one or more memories or storage devices listed herein. The processes described with respect to the exemplary embodiments can include appropriate data structures for storing data collected and/or generated by the processes of the devices and subsystems of the exemplary embodiments in one or more databases.
All or a portion of the exemplary embodiments can be conveniently implemented using one or more general purpose processors, microprocessors, digital signal processors, micro-controllers, and the like, programmed according to the teachings of the exemplary embodiments of the present inventions, as will be appredated by those skilled in the computer and/or software art(s). Appropriate software can be readily prepared by programmers of ordinary skill based on the teachings of the exemplary embodiments, as will be appreciated by those skilled in the software art. In addition, the exemplary embodiments can be implemented by the preparation of application-specific integrated circuits or by interconnecting an appropriate network of conventional component circuits, as will be appreciated by those skilled in the electrical art(s). Thus, the exemplary embodiments are not limited to any specific combination of hardware and/or software.
Stored on any one or on a combination of computer readable media, the exemplary embodiments of the present inventions can include software for controlling the components of the exemplary embodiments, for driving the components of the exemplary embodiments, for enabling the components of the exemplary embodiments to interact with a human user, and the like. Such software can include, but is not limited to, device drivers, firmware, operating systems, development tools, applications software, and the like. Such computer readable media further can include the computer program product of an embodiment of the present inventions for performing all or a portion (if processing is distributed) of the processing performed in implementing the inventions.
As stated above, the components of the exemplary embodiments can include computer readable medium or memories for holding instructions programmed according to the teachings of the present inventions and for holding data structures, tables, records, and/or other data described herein. Computer readable medium can include any suitable medium that participates in providing instructions to a processor for execution. Such a medium can take many forms, including but not limited to, non-volatile media, volatile media, transmission media, and the like. Non-volatile media can include, for example, optical or magnetic disks, magneto-optical disks, and the like. Volatile media can include dynamic memories, and the like. Common forms of computer-readable media can include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other suitable magnetic medium, a CD-ROM, CDR, CD-RW, DVD, DVD-ROM, DVD±RW, DVD±R, any other suitable optical medium, punch cards, paper tape, optical mark sheets, any other suitable physical medium with patterns of holes or other optically recognizable indicia, a RAM, a PROM, an EPROM, a FLASH-EPROM, any other suitable memory chip or cartridge, a carrier wave or any other suitable medium from which a computer can read.
While the present inventions have been described in connection with a number of exemplary embodiments, and implementations, the present inventions are not so limited, but rather cover various modifications, and equivalent arrangements, which fall within the purview of prospective claims.