The present invention relates to a method for protecting one or more computer systems using the same secret key cryptographic algorithm, a utilization of the method and the computer system.
More precisely, the purpose of the method is to make the way in which a calculation is performed dependent on secret data, which data can be different depending on the computer system involved or the secret key used. The objective is to enable computer systems not to be vulnerable to a certain type of physical attack known as “Differential Key Differential Power Analysis,” abbreviated DKDPA, which seeks to obtain information on a secret key by studying the electric power consumption of the computer system or systems during several executions of the calculation performed with different secret keys, at least one of which is known by the attacker (for example if he has been able, for at least one of these calculations, to set the secret key himself).
The cryptographic algorithms considered herein use a secret key to calculate a piece of output information from a piece of input information; this can involve an encryption, decryption, signature, signature verification, authentication or non-repudiation operation. They are constructed so that an attacker who knows the inputs and the outputs cannot in practice deduce any information on the secret key itself.
The invention herein is therefore interested in a broader class than the one traditionally designated by the expression secret key photographic algorithms, or symmetric algorithms. In particular, all of what is described in the present patent application also applies to so-called public key or asymmetric algorithms, which actually include two keys, one public, the other secret, the latter being the one sought by the attacks described below.
Attacks of the Power Analysis type, developed by Paul Kocher and Cryptographic Research (see the document “Introduction to Differential Power Analysis and Related Attacks” by Paul Kocher, Joshua Jaffe, and Benjamin Jun, Cryptography Research, 870 Market St., Suite 1008, San Francisco, Calif. 94102, a publication of the HTML document incorporated into the present application as a reference), start with the assumption that in reality, the attacker can acquire information other than just the input and output data during the execution of the calculation, such as for example the electric power consumption of the microcontroller or the electromagnetic radiation emitted by the circuit.
Differential Power Analysis, abbreviated DPA, is an attack that makes it possible to obtain information on the secret key contained in the computer system by performing a statistical analysis of the power consumption measurements performed on a large number of calculations with this same key.
As a non-limiting example, the case of the DES (Data Encryption Standard) algorithm, will be considered. A description can be found in any of the following documents:
The above-mentioned documents are incorporated into the present application as references.
The DES algorithm is implemented in 16 steps called rounds, represented in
From the construction of the DES algorithm, we see in
The result obtained by applying the function F is combined in an exclusive-OR either with the other 32 bits of the message, or with the 32 bits of the result supplied in step i-2, in order to satisfy the relation Ri=Ri-2⊕F(Ri-1, Ki),
The DPA type attack on the DES can be performed on the DES in the following way:
1st step: Power consumption measurements are made on the first round, for 1,000 DES calculations. The input values of these 1,000 calculations are notated E[1], . . . , E[1,000]. The corresponding 1,000 power consumption curves measured during these calculations are notated C[1], . . . , C[1,000]. The average-curve CM of the 1,000 consumption curves is also calculated.
2nd step: For example, let us consider the first output bit of the first S-box during the first round. Let b be the value of this bit. It is easy to see that b depends only on the 6 bits of the secret key. The attacker forms a hypothesis on the 6 bits in question. He calculates, from each of these 6 bits and the E[i], the expected theoretical values for b. This makes it possible to separate the 1,000 inputs E[1], . . . , E[1,000] into two categories: those that yield b=0 and those that yield b=1.
3rd step: Next the average CM′ of the curves corresponding to inputs in the first category, i.e. for which b=0, is calculated. If CM and CM′ have a notable difference, the values retained for the 6 key bits are considered to be the correct ones. If CM and CM′ do not have any appreciable difference in the statistical sense, i.e., no difference that is substantially greater than the standard deviation of the noise measured, the 2nd step is repeated with another choice for the 6 bits.
4th step: Steps 2 and 3 are repeated with a target bit b output from the second S-box, then from the third S-box, and so on through the eighth S-box. Thus, the 48 bits of the secret key are eventually obtained.
5th step: The 8 remaining bits can be found through an exhaustive search.
This attack does not require any knowledge on the individual power consumption of each instruction, or on the time position of each of these instructions. It applies in the same way if we assume that the attacker knows some outputs of the algorithm and the corresponding consumption curves. It is based solely on the fundamental hypothesis according to which:
Fundamental hypothesis: there exists an intermediate variable, appearing during the calculation of the algorithm, such that the knowledge of several key bits, in practice less than 32 bits, makes it possible to decide whether or not two inputs, or respectively two outputs, yield the same value for this variable.
All the algorithms that use S-boxes, such as DES, are potentially vulnerable to DPA, since the usual embodiments generally fall within the category of the hypothesis mentioned above.
The attacks known as High-Order Differential Power Analysis, abbreviated HO-DPA, are a generalization of the DPA attack described above. They can use several different sources of information; in addition to power consumption, they can perform measurements of electromagnetic radiation, temperature, etc., and implement statistical operations that are more sophisticated than the simple notion of averaging, and intermediate variables (generalizing the bit b defined above) that are less elementary. Nevertheless, they are based on exactly the same fundamental hypothesis as DPA.
One solution for eliminating the risk of DPA or HO-DPA attacks consists, for a cryptographic calculation process using a secret key Ks, of modifying the implementation of the algorithm so that the aforementioned fundamental hypotheses is no longer verified, since there is no longer any calculated intermediate variable that depends on the knowledge of an easily accessible subset of the secret key.
To this end, the cryptographic calculation process is first separated in the computer system into several distinct calculation process parts PPC1 through PPCk (
This separation is performed by the modified calculation algorithm, which replaces each intermediate variable v occurring during the calculation and depending on the input (or output) data with k variables v1, v2, . . . , Vk, such that v1, v2, . . . , and vk make it possible, as necessary, to reconstitute v. More precisely, this means that there exists a function f that makes it possible to determine v, such that v=f(v1, v2, . . . , Vk) and such that the separation performed by the modified algorithm satisfies this function. It is also assumed that f preferably satisfies the following first condition:
Condition No. 1: Let i be a subscript (in the broad sense) between 1 and k. The knowledge of a value v never makes it possible, in practice, to deduce information on all of the values vi such that there exists a (k−1)-tuple (v1, . . . , vi−1, vi+1, . . . , vk) that satisfies the equation f(v1, . . . , vk)=v.
The algorithm is then “translated” by replacing each intermediate variable V depending on input (or output) data with the k variables v1, v2, . . . , vk.
In order to guarantee the maximum security of the modified algorithm in its new form, the following additional condition (Condition No. 2) is imposed on the function f:
Condition No. 2: The function f is such that the transformations to be performed on v1, v2, . . . , or vk during the calculation in place of the transformations normally performed on v, can be implemented without having to recalculate v.
Let us return to the example of the DES algorithm. A concrete implementation of the method described above consists of constructing the modified calculation algorithm DESM so that it separates each intermediate variable v occurring during the calculation and depending on input or output data into, for example, two variables v1 and v2, which means that we take k=2. Let us consider the function f(v1, v2)=v=v1⊕v2 in the above example No. 1, which satisfies Condition No. 1 by construction. From the construction of the DES algorithm, it is easy to see that the transformations it performs on v can always fall into one of the following five categories:
The first two categories correspond to linear transformations on the bits of the variable v. For these categories, Condition No. 2 is very easy to verify, and it is sufficient to perform, in place of the transformation normally performed on v, the permutation or expansion on v1, then on v2, and the relation f(v1, v2)=v that was true before the transformation remains equally true afterwards.
Likewise, in the third case, it is sufficient to replace the calculation v″=v⊕v′ with v″1=v1⊕v′1 and v″2=v2⊕v′2. The relations f(v1, v2)=v and f(v′1, v′2)=v′ yield f(v″1, v″2)=v″ and Condition No. 2 is again verified.
In the exclusive-OR of v with a variable c that is dependent only on the key or a subkey, Condition No. 2 is also very easy to satisfy: it is sufficient to replace the calculation of v⊕c with v1⊕c, or v2 ⊕c, which fulfills Condition No. 2.
Finally, in place of the given nonlinear transformation of the prior art v′=S(v), represented in
(v′1, v′2)=S′(v1, v2)=(A(v1, v2), S(v1⊕v2)⊕A(v1, v2))
i.e. v′1=A(v1, v2) and v′2=S(v1⊕v2)⊕A(v1, v2)
where A designates a secret, random transformation of 12 bits into 4 bits. The first S-box (S′1,
The transformation or conversion tables can be stored in a ROM of the microcomputer card when the computer system is constituted by a microcomputer card.
Thus, for a computational step of the nonlinear transformation type implemented by a standard cryptographic calculation process like DES, the separation, as represented in
In the above example of DES and in relation to
In a first variant, in order to save space in the ROM, it is entirely possible to use the same random function A for each of the eight S-boxes of the conventional description of DES, which makes it possible to have only nine new S-boxes to store instead of sixteen.
A second variant, called Variant No. 2, will be described in connection with
In order to reduce the size of the ROM required to store the S-boxes, it is also possible, in place of each nonlinear transformation v′=S(v) of the initial implementation expressed in the form of an S-box (which in the example of DES accepts 6-bit inputs and yields 4-bit outputs), to use the following method, which in this second variant performs the transformation (v′1, v′2)=S′(v1, v2) by means of two S-boxes (S′1; S′2), each containing a table of 6 bits into 4 bits. The initial implementation of the calculation of v′=S(v) is replaced in the modified algorithm by the following two successive calculations:
v0=φ(v1⊕v2)
which uses a secret, bijective function of 6 bits into 6 bits, and
(v′1, v′2)=S′(v1, v2)=(A(v0), S(φ−1(v0))⊕A(v0))
i.e. v′1=A(v0), v′2=S(φ−1(v0))⊕A(v0)
where A designates a secret, random transformation of 6 bits into 4 bits. The first S-box (referenced S′1 in
As in the first example above, and in connection with
Moreover, in a simplified version, the bijective functions φ1 through φk are identical.
In order for Condition No. 2 to be satisfied, it is necessary to choose the bijective transformation φ or bijective functions φ1 through φk such that the calculation of v0=φ(v1⊕v2) can be done without having to recalculate v1⊕v2. Two examples of choices for the function φ are given below:
A secret, linear bijective function of 6 bits into 6 bits is chosen for φ. Within the framework of such a choice, all of the 6-bit values are considered as a vectorial space of dimension 6 in the finite body F2 with two elements. In practice, choosing φ amounts to choosing a random invertible 6×6 matrix whose coefficients equal 0 or 1. With this choice of φ, it is easy to see that Condition No. 2 is satisfied. In essence, to calculate φ(v1⊕v2), it is sufficient to calculate φ(v1), then φ(v2), and finally to calculate the “exclusive-OR” of the two results obtained.
For example, the matrix
is invertible. It corresponds to the linear bijection of 6 bits into 6 bits defined by:
φ(u1, u2, u3, u4, u5, u6)=(u1⊕u2u4, u1⊕u2⊕u4⊕u6, u2⊕u3⊕u5, u1⊕u2⊕u3⊕u5, u2⊕u3⊕u4⊕u5, u3⊕u4⊕u6)
If we take v1=(v1,1, v1,2, v1,3, v1,4, v1,5, v1,6) and v2=(v2,1, v2,2, v2,3, v2,4, v2,5, v2,6), then in order to calculate φ(v1⊕v2), we successively calculate:
φ(v1)=(v1,1⊕v1,2⊕v1,4, v1,1⊕v1,2⊕v1,4⊕v1,6, v1,2⊕v1,3⊕v1,5, v1,1⊕v1,2⊕v1,3⊕v1,5, v1,2⊕v1,3⊕v1,4⊕v1,5, v1,3⊕v1,4⊕v1,6);
φ(v2)=(v2,1⊕v2,2⊕v2,4, v2,1⊕v2,2⊕v2,4⊕v2,6, v2,2⊕v2,3⊕v2,5, v2,1⊕v2,2⊕v2,3⊕v2,5, v2,2 ⊕v2,3⊕v2,4⊕v2,5, v2,3⊕v2,4⊕v2,6).
Then we calculate the “exclusive-OR” of the two results obtained.
A secret quadratic bijective function of 6 bits into 6 bits is chosen for φ. The term “quadratic” in this case means that each output value bit of the function φ is expressed by a polynomial function of degree two of the 6 input bits, which are identified with 6 elements of the finite body F2. In practice, it is possible to choose the function φ defined by the formula φ (x)=t(s(x)5, where s is a secret linear bijective application of (F2)6 into L, t is a secret linear bijective application of L into (F2)6, and L designates an algebraic extension of degree 6 of the finite body F2. The bjiective characteristic of this function φ results from the fact that a·a5 is a bijection on the extension L (the inverse of which is b·b38). In order to establish that Condition No. 2 is still satisfied, it is sufficient to note that it is possible to write:
φ(v1⊕v2)=ψ(v1, v1)⊕ψ(v1, v2)⊕ψ(v2, v1)
For example, if we identify L with F2[X]/(X6+X+1), and if we take s and t of respective matrices
and
relative to the base (1, X, X2, X3, X4, X5) of L over F2 nd to the canonic base of (F2)6 over F2, we obtain the following quadratic bijection φ of 6 bits into 6 bits:
φ(u1, u2, u3, u4, u5, u6)=(u2u5⊕u1u4⊕u4⊕u6⊕u6u2⊕u4u6⊕u2⊕u5⊕u3⊕u4u3, u2u5⊕u5u1⊕u1u4⊕u4 ⊕u6⊕u4u5⊕u2⊕u3⊕u3u1, u2u5⊕u5u1⊕u6u5⊕u1u4⊕u3u5⊕u1⊕u4u6⊕u6u3⊕u4u3⊕u3u1, u1u4⊕u2u3⊕u6u1⊕u4u6⊕u5⊕u6u3⊕u4u3, u5u1⊕u1u4⊕u6⊕u3u5⊕u4u5⊕u1⊕u6u1⊕u4u6⊕u3⊕u6u3⊕u4u2, u4⊕u6⊕u3u5⊕u1⊕u4u6⊕u6u3).
To calculate φ(v1⊕v2), we use the function ψ(x, y)=t(s(x)4·s(y)) of 12 bits into 6 bits, which yields the 6 output bits as a function of the 12 input bits in accordance with the following rules:
ψ(x1, x2, x3, x4, x5, x6, y1, y2, y3, y4, y5, y6)=(x3y5⊕x6y2⊕x6y3⊕x6y4⊕x3y1⊕x6y1⊕x1y3⊕x1y5⊕x5y2⊕x5y5⊕x5y1⊕x6y6⊕x1y6⊕x1y2⊕x1y4⊕x2y1⊕x2y2⊕x4y4⊕x3y3⊕x3y6⊕x4y3⊕x5y3, x4y5⊕x3y1⊕x6y1⊕x2y5⊕x5y1⊕x6y6⊕x1y2⊕x2y1⊕x2y2⊕x4y1⊕x4y4⊕x3y3, x6y2⊕x6y3⊕x6y4⊕x6y5⊕x3y1⊕x6y1⊕x2y5⊕x5y1⊕x1y6⊕x1y1⊕x1y2⊕x1y4⊕x2y1⊕x2y4⊕x2y6⊕x3y4⊕x2y5⊕x5y1⊕x1y6⊕x1y1⊕x1y2⊕x1y4⊕x2y1⊕x2y4⊕x2y6⊕x3y4⊕x5y3, x3y1⊕x6y2⊕x2y2⊕x5y3⊕x5y4⊕x5y6⊕x6y3⊕x2y3⊕x4y6⊕x6y5⊕x1y3⊕x5y5⊕x2y4⊕x4y2⊕x4y5⊕x3y5⊕x4y3⊕x6y1⊕x4y1, x3y1⊕x6y6⊕x5y3⊕x5y6⊕x5y2⊕x1y5⊕x1y1⊕x1y2⊕x2y1⊕x2y3⊕x3y6⊕x6y5⊕x1y3⊕x2y4⊕x3y3⊕x4y5⊕x2y5⊕x6y1⊕x4y1⊕x6y4⊕x3y2, x6y6⊕x4y4⊕x5y4⊕x5y6⊕x6y3⊕x1y6⊕x1y1⊕x1y2⊕x2y1⊕x6y5⊕x2y4⊕x4y2⊕x4y5⊕x3y5⊕x6y1⊕x6y4).
Using these formulas, we successively calculate:
Then we calculate the “exclusive-OR” of the four results obtained. In a third variant, again in order to reduce the size of the ROM required to store the S-boxes, it is possible to simultaneously apply the ideas of the two preceding variants, Variant No. 1 and Variant No. 2: Variant No. 2 is used with the same secret bijection φ (of 6 bits into 6 bits) and the same secret random function A (of 6 bits into 6 bits) in the new implementation of each nonlinear transformation expressed in the form of an S-box.
The disadvantage of the solution described above for warding off DPA attacks is that is vulnerable to a DKDPA attack.
The utilization of the protection method described above makes it possible to render DPA or HO-DPA attacks ineffective. However, the new implementation of the secret key cryptographic algorithm may be vulnerable to another attack, which will hereinafter be called Differential Key and Differential Power Analysis, abbreviated DKDPA, even when the standard DPA attack fails. We will now describe the general principle of this attack.
Let us assume that the attacker has in his possession a small number of computer systems, for each of which he knows the secret key of the cryptographic algorithm it uses. For each computer system, even though he already knows the secret key, he applies the DPA attack exactly as though he did not know the secret key. Using the principle described above, he forms a hypotheses on 6 bits of the key, and for each choice of these 6 bits, he obtains 64 curves representing differences from the average consumption curves.
For certain implementations of the algorithm, it is possible for the DPA to reveal unusual phenomena for certain choices of these 6 key bits (i.e., unusual peaks or dips for one of the 64 curves). Of course, this particular choice of 6 key bits does not correspond to the true key, but the “exclusive-OR” between these 6 bits (lets call them the K′) and the 6 corresponding bits of the true key (let's call them the K) is often found to be a constant C, which means that there is always K⊕K′=C for each computer system for which the attacker knows the secret key.
If this is actually the case, then the attacker can easily find the bits of a real unknown key: he applies the standard DPA attack, then notes the particular choices K′ of the 6 bits that yield an unusual curve, and finally deduces K from it by calculating K⊕K′=C, where C has been obtained previously.
One of the objects of the invention is to eliminate this vulnerability of computer systems to DKDPA attacks.
A more precise examination shows that the attacks of the DKDPA type described above are made possible by the fact that the implementation of the cryptographic calculation process used by the computer system or systems is always the same, no matter what the electronic element involved and no matter what the secret key used by the cryptographic process.
The object of the method that is the subject of the present invention is to eliminate the risk of DKDPA attacks on data processing or computer systems using a secret key cryptographic process.
The method for protecting one or more computer systems using a secret key cryptographic calculation process, which is the subject of the present invention, is remarkable in that the implementation of the secret key cryptographic calculation process is dependent on secret data.
According to another characteristic, for each computer system and for each secret key, the way in which said secret data is used to perform said cryptographic calculation is public.
According to another characteristic, there are at least two pieces of secret data used by said computer systems.
According to another characteristic, each of the computer systems contains at least one specific piece of secret data.
Consequently, another subject of the present invention is a way of performing the cryptographic calculation that can easily be made different from one computer system to another, or for the same computer system, from the utilization of one secret key to another.
This object is achieved through the fact that in each of the computer systems, there are at least two pieces of secret data, corresponding to the various secret keys used by this computer system.
According to another characteristic, in each of the computer systems, each secret key used by said cryptographic calculation corresponds to a specific piece of secret data.
According to another characteristic, the method, which uses a cryptographic calculation process using nonlinear transformations of km bits into kn bits described by k conversion tables of km bits into n bits in which n output bits of the transformation are read at an address that is a function of the km input bits, is characterized in that for each of these nonlinear transformations, said k tables are part of the secret data.
According to another characteristic, the method for protecting one or more computer systems uses a cryptographic calculation process using nonlinear transformations of km bits into kn bits described by k conversion tables of km bits into n bits in which n output bits of the transformation are read at an address obtained by applying a secret bijective function to an m-bit value, itself obtained by applying a public function of the km input bits of the nonlinear transformation, characterized in that for each of these nonlinear transformations, the k tables are part of the secret data.
According to another characteristic, for each of the nonlinear transformations, the secret bijective function is also part of the secret data.
According to another characteristic, the secret data is stored in the E2PROM memory of said microcomputer card.
According to another characteristic, a conversion table calculation program is stored in each computer system and activated by a given event in order to calculate the tables and store all or part of these tables in the secret data.
According to another characteristic, the given event is the exceeding of a given value by a counter.
Another object of the invention is a utilization of this method.
This object is achieved through the fact that the method is used to protect a cryptographic calculation process supported by the DES, Triple DES and RSA algorithms.
A final object of the invention is to define one or more computer systems that resist DPA and DKDPA attacks.
This object is achieved through the fact that the computer system that implements the protection process, comprising means for storing a modified cryptographic algorithm that adheres to the computational phases of the standard cryptographic algorithm and uses a secret encryption key contained in a secret area of storage means, and means for executing this modified cryptographic algorithm, is characterized in that the computer system comprises first secret means for replacing each intermediate variable required for the computational phases of the standard algorithm with a plurality (k) of partial intermediate variables, second means for applying a nonlinear transformation table to each of these partial intermediate variables, and third means for reconstituting the final result corresponding to the utilization of the standard encryption algorithm from results obtained on the partial variables.
According to another characteristic, the secret data of the computer system includes at least one first random variable v1 constituting at least one secret partial variable, and the modified algorithm determines at least one other partial variable, for example v2, by applying a first secret function to the intermediate variable v and the secret partial variable or variables v1.
According to another characteristic, the modified algorithm applies the nonlinear transformations to the partial variables v1 and v2 by using tables, at least one of which A, formed by random selection, is stored in the secret data Ds, the other tables required for the calculations being able to be stored in the nonvolatile memory, the various computational rounds of the standard algorithm are executed, each time using the tables on the partial variables, and in the last round, the algorithm calculates the result by combining the partial variables in accordance with a second secret function.
According to another characteristic, the first secret means of the modified algorithm are constituted by a function f, linking the partial intermediate variables and each intermediate variable (v), such that the knowledge of one value of this intermediate variable never makes it possible to deduce all of the particular partial values vi such that there exists a (k−1)-tuple (v1, . . . , vi−1, vi+1, . . . vk) that satisfies the equation f(v1, . . . , vi, . . . , vk)=v.
According to another characteristic, the second means of the modified algorithm are constituted by k partial conversion tables and among the k partial conversion tables, k−1 partial conversion tables contain secret random variables.
According to another characteristic, the second means of the modified algorithm comprise k conversion tables, each of these conversion tables receiving as input a value obtained by applying a secret bijective function φ1 to said function f(v1, . . . , vk) of the partial intermediate variables in accordance with the relation φj of(v1, . . . , vk), j ε [1,k], this application φj of(v1, . . . , vk) being performed by direct evaluation of a resulting value, this resulting value, applied to the input of the conversion table, making it possible to read n output bits of the transformation at an address that is a function of these m input bits.
According to another characteristic, the second means of the modified algorithm replace each nonlinear transformation applied to an intermediate variable of the standard cryptographic calculation process, without a separation, with a partial nonlinear transformation of km bits into kn bits applied to all of the partial intermediate variables, (k−1)n of said output bits of this transformation being calculated as a polynomial function of the km input bits, and the n remaining bits of said output bits being obtained by reading a conversion table in which the n remaining bits are read at an address that is a function of the km input bits.
According to another characteristic, the operations performed by the modified algorithm in the various parts resulting from the separation of the cryptographic calculation process into several distinct calculation process parts are executed sequentially.
According to another characteristic, the operations performed in the various parts resulting from the separation of the cryptographic calculation process into several distinct calculation process parts are executed in interleaved fashion.
According to another characteristic, the operations performed in the various parts resulting from the separation of the cryptographic calculation process into several distinct calculation process parts are executed simultaneously in the event of multiprogramming.
According to another characteristic, the operations performed in the various parts resulting from the separation of the cryptographic calculation process into several distinct calculation process parts are executed simultaneously in various processors working in parallel.
According to another characteristic, the computer system includes a conversion table calculation program stored in each computer system and means for the activation by a given event of the calculation of the tables and for the storage of all or part of these tables in the secret data.
According to another characteristic, a counter stores a value that is incremented with each cryptographic calculation so as to constitute the given event for activating the calculation of the tables when a given value is exceeded.
Other characteristics and advantages of the present invention will be more clearly understood with the reading of the description given in reference to the drawings below, in which:
The invention will be described below in connection with
A computer system can be constituted by a computer security module installed in a larger device, such as for example a server or a terminal. This computer system can be constituted by one or more integrated circuits incorporated into the larger device or even by a chip card, generally called a “smart card” when it includes a microprocessor or microcontroller connected to the larger device by a connector with or without contact. A standard encryption algorithm, such as for example DES, can be installed in the nonvolatile memory, for example a ROM (7), of the computer system (1). The microprocessor (2) of this computer system (1) executes this algorithm by reading, through the bus (4) that links it to the various memories, the instructions contained in the ROM (7) in order to perform the steps of the encryption method described in connection with
The invention consists of modifying the algorithm used for the encryption in order to construct a modified algorithm (DESM) that adheres to the same phases as the calculation process of the standard algorithm (DES). Thus, in the case of DES, the modified algorithm performs a separation of the cryptographic calculation process of the standard DES into several distinct calculation process parts executed in parallel and using partial intermediate results (called partial variables) distinct from those of the standard cryptographic calculation, and this separation is performed by using secret data (Ds) contained in the secret area (60) of the memory (6) of the computer system (1). This modified algorithm produces a result Mc by reconstituting the final value from the partial intermediate results, such that Mc=DESM(E,Ks,Ds)=DES(E,Ks), equal to the result that would have been obtained by the standard algorithm. It will be noted that the computer systems thus obtained are entirely compatible with those having a standard encryption (hereinafter called standard systems) and can therefore be used in place of standard systems in applications or places where the standard systems would risk being exposed to an attack, without any need to change those that are in secure locations.
This modified algorithm includes secret means for replacing each intermediate variable of the standard algorithm with several partial intermediate variables, and means for applying a nonlinear transformation table to each of these partial intermediate variables, and secret means for reconstituting the final result corresponding to the utilization of the standard encryption algorithm from the results obtained on the partial variables. Thus, since a hacker no longer knows the relation between the partial variables and the final result, he is no longer capable of discovering the secret encryption key (Ks) through a DPA attack.
For example, in the case of the protection method of the DES algorithm described above, the implementation of the modified cryptographic calculation process is made dependent on the data of the k conversion tables used to calculate each nonlinear transformation of km bits into kn bits. These k tables constitute the secret data (Ds). Moreover, in the case of variants 2 and 3, the implementation of the cryptographic calculation process is made dependent on the data of the secret bijective applications φ1, φ2, . . . , φk, which are also part of the secret data.
Thus, the modified algorithm uses the secret bijective function contained in the secret data (Ds) in the computational phases where this is necessary, and uses the conversion tables, also contained in the secret data, in other the computational phases.
In the case of the example of the DES algorithm described above, the way in which this secret data is used is public.
It is quite clear that the invention has been illustrated in the case of the encryption algorithm called DES, but the same principle and the same method can be used with any other known encryption method, such as triple DES or RSA.
In order to make attacks of the DKDPA type ineffective on the computer system or systems, it is also necessary to choose a piece of secret data (Ds) that is not always the same from one computer system to another or from the utilization of one secret key to another. For this reason, it is preferable to place it in a programmable memory in order to be able to change it easily from one computer system to another. In the above example of DES, it is clear that it is easy to choose a new value for the secret data from the k conversion tables used to calculate each nonlinear transformation of km bits into kn bits; it is possible, for example, to randomly choose (k−1) tables, then deduce the kth table through a simple calculation. Likewise, in the case of variants 2 and 3, it is possible to choose (k−1) tables randomly, and the secret bijective applications φ1, φ2, . . . , φk equally randomly, then deduce the kth table from them, again through a simple calculation.
In the case where the computer systems are one or more microcomputer cards, the secret data (Ds) on which the implementation of the secret key cryptographic process depends can be stored in the E2PROM memory (6). This makes it possible to change it from one card to another in the process of customizing the card, during which one or more secret keys are generally entered in the E2PROM of said card. It is also possible to change this secret data written in the E2PROM memory when it is necessary to change one or more of the secret keys contained in the card.
In the strongest version of the invention, the secret data depends on both the microcomputer card in question and the secret key used by the cryptographic calculation process. For example, the secret data is chosen randomly each time a secret key is entered into a card. This actually amounts to entering a pair (secret key Ks, secret data Ds) into the E2PROM memory of the microcomputer card each time, instead of entering only the secret key. In a variant of embodiment of the invention, given as an illustrative but non-limiting example, the secret data includes at least one first random variable v1 constituting at least one secret partial variable, and the modified algorithm determines at least one other partial variable, for example v2, by applying a secret function to the intermediate variable v and the secret partial variable or variables v1. This secret function can be, for example, an exclusive-OR such as:
v2=v1⊕v.
The modified algorithm applies the nonlinear transformations to the partial variables v1 and v2 by using tables, at least one of which A, formed by random selection, is stored in the secret data Ds, the other tables required for the calculations being able to be stored in the nonvolatile memory. The various computational rounds of the standard algorithm are executed, each time using the tables on the partial variables, and in the last round the algorithm calculates the result by combining the partial variables in accordance with a second secret function, which can be the inverse of the preceding one.
All of the variants described in reference to
In another variant of embodiment of the invention, the program for calculating the S-boxes or conversion tables, normally present in customized machines, can be downloaded or written during a pre-customization phase into the secret area (61) of the programmable nonvolatile E2PROM memory (6) and activated during a customization phase by an order from the outside, executable only once during the customization phase. Once the order is executed, the calculation program either sets a lock in nonvolatile memory that denies access to this program unless a specific key is presented, or in another embodiment, triggers the automatic erasure of this secret area (61). This variant makes it possible to implement the invention even with unmodified customized machines. The calculation of the S-boxes or conversion tables is performed by adhering to the principles mentioned above and by using, as a diversifier, a piece of information specific to the card in the process of being customized, such as the serial number of the card that was recorded in the pre-customization phase, the values obtained by this calculation being written into the secret data (60) of the secret area of the nonvolatile memory (6).
In another additional variant, the card includes an additional counter (62) in nonvolatile memory, which is incremented by the DESM algorithm with each execution of a DES calculation by the latter. The operating system of the card is capable of comparing the content of this counter to a given value n with each power-up of the card and to call the calculation program (61) in order to calculate new S-boxes or conversion tables in the event that the value n is exceeded. The operating system of the card or the calculation program handles the storage of the S-boxes in the secret data in accordance with a procedure defined by the calculation program (61) or the operating system and resets the counter. In addition, in this variant the DESM algorithm, prior to performing a DES calculation, verifies that the additional counter (62) has not exceeded the given value increased by a constant (n+c), in which c is a defined constant. If it has been exceeded, the algorithm assumes an attempted fraud and resets the card to zero.
Finally, it is clear that in all the embodiments described, the way in which the cryptographic calculation is performed depends on the modification of the DESM algorithm, which itself depends on the elements contained in the secret storage area.
Any combination of the different variants presented is also part of the invention.
While this invention has been described in conjunction with specific embodiments thereof, it is evident that many alternatives, modifications and variations will be apparent to those skilled in the art. Accordingly, the preferred embodiments of the invention as set forth herein, are intended to be illustrative, not limiting. Various changes may be made without departing from the true spirit and full scope of the invention as set forth herein and defined in the claims.
Number | Date | Country | Kind |
---|---|---|---|
99 04441 | Apr 1999 | FR | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/FR00/00902 | 4/7/2000 | WO | 00 | 12/8/2000 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO00/62473 | 10/19/2000 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
4993068 | Piosenka et al. | Feb 1991 | A |
5588059 | Chandos et al. | Dec 1996 | A |
5850443 | Van Oorschot et al. | Dec 1998 | A |
6314409 | Schneck et al. | Nov 2001 | B1 |
6480959 | Granger et al. | Nov 2002 | B1 |
6658569 | Patarin et al. | Dec 2003 | B1 |
Number | Date | Country |
---|---|---|
2 672 402 | Aug 1992 | FR |
WO 98 52319 | Nov 1998 | WO |