The present invention relates to a method for protecting an electronic system implementing an algorithm involving a modular exponentiation, in which the exponent is secret. More precisely, the purpose of the method is to create a version of such an algorithm that is not vulnerable to a certain type of physical attack—called Differential Power Analysis or High-Order Differential Power Analysis, (abbreviated DPA or HO-DPA)—which tries to obtain information on the secret key from a study of the electric power consumption of the electronic system during the execution of the calculation.
The cryptographic algorithms considered herein use a secret key to calculate a piece of output information based on a piece of input information; this can involve an encryption, decryption, signature, signature verification, authentication, non-repudiation or key-exchange operation. They are constructed in such a way that a hacker, knowing the inputs and the outputs, cannot in practice deduce any information on the secret key itself.
We are therefore interested in a class larger than that traditionally designated by the expression secret key algorithms or symmetrical algorithms. In particular, everything described in the present patent application also applies to so-called public key or asymmetrical algorithms, which actually include two keys: one public, the other private and not divulged, the latter being the one targeted 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; HTML edition of the document available at the URL address: http://www.cryptography.com/dpa/technical/index.html) start with the observation that in reality the hacker can acquire information other than simply the input and output data during the execution of the calculation, such as for example the power consumption of the microcontroller or the electromagnetic radiation emitted by the circuit.
Differential power analysis is an attack that makes it possible to obtain information on the secret key contained in the electronic system, by performing a statistical analysis of the power consumption records, performed on a large number of calculations with this same key.
This attack does not require any knowledge of the individual power consumption of each instruction, or on the temporal position of each of these instructions. It applies in the same way assuming that the hacker knows some of the outputs of the algorithm and the corresponding consumption curves. It is based solely on the fundamental hypothesis according to which:
Fundamental hypothesis: There is an intermediate variable appearing during the calculation of the algorithm, such that the knowledge of a few key bits, in practice less than 32 bits, makes it possible to decide whether or not two inputs, respectively two outputs, give the same value for this variable.
The so-called high-order power analysis attacks are a generalization of the DPA attack described above. They can use several different sources of information: in addition to the consumption, they can use measurements of electromagnetic radiation, temperature, etc., performing statistical operations that are more sophisticated than the simple notion of an average, and intermediate variables that are less elementary than a simple bit or a simple byte. Nevertheless, they are based on exactly the same fundamental hypothesis as DPA.
The object of the method that is the subject of the present invention is to eliminate the risk of DPA or HO-DPA attacks on electronic systems with secret or private key cryptography involving modular exponentiation in which the exponent is secret.
Another object of the present invention is consequently to modify the cryptographic calculation process implemented by protected electronic cryptographic systems, in such a way that the aforementioned fundamental hypothesis is not longer verified, i.e. that there is no intermediate variable that depends on the consumption of a sub-system easily accessible by the secret or private key, attacks of the DPA or HO-DPA thus being rendered ineffective.
First example: the RSA algorithm
RSA is the most famous of the asymmetrical cryptographic algorithms. It was developed by Rivest, Shamir and Adleman in 1978. For a more detailed description of this algorithm, it may be useful to refer to the following document:
The RSA algorithm uses a whole number n that is the product of two large prime numbers p and q, and a whole number e, prime with ppcm(p−1, q−1), and such that e·±1 mod ppcmp−1, q−1). The whole numbers n and e constitute the public key. The public key calculation uses the function g of Z/nz in Z/nz defined by g(x)=xe mod n. The secret key calculation uses the function g−1(y)=yd mod n, where d is the secret exponent (also called the secret or private key) defined by ed·1 mod ppcm(p−1, q-1).
Attacks of the DPA or HO-DPA type can pose a threat to the standard implementations of the RSA algorithm. In essence, the latter very often use the so called square and multiply principle to perform the calculation of xd mod n.
This principle consists of writing the breakdown
d=bm−·2m−1+bm−2·2m−2+ . . . +b1·21+b02·0
of the secret exponent d in base 2, the performing the calculation in the following way:
In this calculation, it is clear that among the successive values assumed by the variable z, the prime numbers depend on only a few bits of the secret key d. The fundamental hypothesis that makes the DPA attack possible is therefore fulfilled. It is thus possible to guess, for example, the 10 high-order bits of d by concentrating on the consumption measurements in the part of the algorithm that corresponds to i running from m−1 to m−10, which makes it possible to find the next ten bits of d, and so on. Eventually, all the bits of the secret exponent d are found.
A First Protection Method, and its Disadvantages
A conventional method (proposed by Ronald Rivest in 1995) for protecting the RSA algorithm against DPA type attacks consists of using a “blinding” principle. This uses the fact that:
xd mod n=(x×re)d×r−1 mod n
Thus, the calculation of y=xd mod n is broken down into four steps:
The disadvantage of this method is that it makes it necessary, for each calculation, to calculate the modular inverse r−1 of the random value r, this operation generally being time-consuming (the duration of such a calculation is on the same order as that of a modular exponentiation such as ud mod n). Consequently, this new implementation (protected against DPA attacks) of the calculation of xd mod n takes about twice as long as the initial implementation (not protected against DPA attacks). In other words, this protection of RSA against DPA attacks increases the calculation time by approximately 100% (assuming that the public exponent e is very small, for example e=3; if the exponent e is larger, this calculation time is even longer).
A Second Method: The Method of the Present Invention
According to the invention, a method for protecting an electronic system implementing a cryptographic calculation process involving a modular exponentiation of a quantity (x), said modular exponentiation using a secret exponent (d), is characterized in that said secret exponent is broken down into a plurality of k unpredictable values (d1, d2, . . . , dk), the sum of which is equal to said secret exponent.
Advantageously, said values (d1, d2, . . . , dk), are obtained in the following way:
Advantageously, the calculation of the modular exponentiation is performed in the following way:
Advantageously, at least one of said (k−1) values obtained by means of a random generator has a length greater than or equal to 64 bits.
Some of the details and advantages of the present invention will emerge from the following description of some preferred but non-limiting embodiments, in reference to the sole attached figure, which represents a smart card.
According to the invention, we use the fact that:
if d=d1+d2, then xd mod n=xd
Thus, the calculation of y=x mod n is broken down into five steps:
The advantage is that, this way, there is no modular inverse to calculate. In general, the calculation time of a modular exponentiation is proportional to the size of the exponent. Thus, if we let · be the ratio between the size of d1 and the size of d2, it is clear that the total calculation time in this new implementation (protected against DPA attacks) is about (1+· ) times the calculation time in the initial implementation (not protected against DPA attacks).
Note that, in order to obtain an unpredictable value d1, it necessary for its size to be at least 64 bits.
The method thus described renders attacks of the DPA or HO-DPA type described above ineffective. In essence, in deciding whether or not two inputs (respectively two outputs) of the algorithm give the same value for an intermediate variable appearing during the calculation, it is no longer enough to know the key bits involved. It is also necessary to know the breakdown of the secret key d into k values d1, d2, . . . , dk such that d=d1+d2+ . . . +dk. Assuming that this breakdown is secret, and that at least one of the k values has a size of at least 64 bits, the hacker cannot predict the values of d1, . . . , dk, and therefore the fundamental hypothesis that would make it possible to implement a DPA or HO-DPA type attack, is no longer verified.
2. If n has a length of 1024 bits, by choosing to take a random value d1 of 64 bits, we obtain ·=1/16, which means that this protection of RSA against DPA attacks increases the calculation time by about 6.25%.
Second Example: the Rabin Algorithm
We will now consider the asymmetrical cryptographic algorithm developed by Rabin in 1979. For a more detailed description of this algorithm, it may be useful to refer to the following document:
The Rabin algorithm uses a whole number n that is the product of two large prime numbers p and q, which also verify the following two conditions:
The public key calculation uses the function g of Z/nZ in Z/nZ defined by g(x)=x2 mod n. The secret key calculation uses the function g−1(y)=yd mod n, where d is the secret exponent (also called the secret or private key) defined by d=((p−1)(q−1)/4+1)/2.
The function implemented by the secret key calculation being exactly the same as that used by the RSA algorithm, the same DPA or HO-DPA attacks are applicable and can pose the same threats to the Rabin algorithm.
Protecting the Algorithm
Since the function is exactly the same as the one in RSA, the protection method described in the RSA context is applied in the same way in the case of the Rabin algorithm. The increase in the calculation time caused by the application of this method is also the same as in the case of the RSA algorithm.
The invention can be implemented in any electronic system performing a cryptographic calculation involving a modular exponentiation, including a smart card 8 as shown in
For the chip, it is possible to use, in particular, a self-programmable microprocessor with a nonvolatile memory, as described in U.S. Pat. No. 4,382,279 assigned to the assignee of the present invention. In a variant, the microprocessor of the chip is replaced, or at least supplemented, by logical circuits installed in a semiconductor chip. In essence, such circuits are capable of performing calculations, including authentication and signature calculations, as a result of hard-wired, rather than microprogrammed, electronics. In particular, they can be of the ASIC (“Application Specific Integrated Circuit”) type. Advantageously, the chip is designed in monolithic form.
In the case of the utilization of such an electronic system, the invention consists in a method for protecting an electronic system comprising information processing means and information storage means, the method implementing a cryptographic calculation process involving a modular exponentiation of a quantity (x) stored in the information storage means, said modular exponentiation using a secret exponent (d) stored in the storage means, characterized in that, by means of said information processing means, said secret exponent read in said information storage means is broken down into a plurality of k unpredictable values (d1, d2, . . . , dk), the sum of which is equal to said secret exponent, said k unpredictable values being stored in the information storage means.
Advantageously, said values (d1, d2, . . . , dk) are obtained in the following way:
Advantageously, the calculation of the modular exponentiation is performed in the following way:
Advantageously, at least one of said (k−1) values obtained by means of a random generator has a length greater than or equal to 64 bits.
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 13507 | Oct 1999 | FR | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/FR00/02978 | 10/26/2000 | WO | 00 | 6/28/2001 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO01/31436 | 5/3/2001 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6038316 | Dwork et al. | Mar 2000 | A |
6108425 | Smith et al. | Aug 2000 | A |
6285761 | Patel et al. | Sep 2001 | B1 |
6304658 | Kocher et al. | Oct 2001 | B1 |
6307938 | Matyas et al. | Oct 2001 | B1 |
6378072 | Collins et al. | Apr 2002 | B1 |
6381699 | Kocher et al. | Apr 2002 | B2 |
6490357 | Rose | Dec 2002 | B1 |
6748410 | Gressel et al. | Jun 2004 | B1 |
Number | Date | Country |
---|---|---|
WO 98 52319 | Nov 1998 | WO |