signature=31c4aa8d5646dc53c705b68fb9a6fc3e,Method for designing public key cryptosystems against fau...

BACKGROUND OF THE INVENTION

1. The Field of the Invention

The present invention relates to public key cryptosystems, and more particularly to a method for designing public key cryptosystems against fault-based attacks since protection of the secret information stored in a tamperproof device is very important to an electronic cash system. A new fault-resistant method and system for countering information leakage to resist both the memory and computational fault-based attacks has been developed. The fault-resistant system can be readily implemented in public key cryptosystems and will achieve a high performance in computation.

2. Description of the Related Art

A smart card, which involves public-key or secret-key cryptosystems in a tamperproof device to ensure the security, is held as an important invention to provide people with a more convenient life style. The security of the public-key based smart card systems depends on the supposed difficulty of a factorization or discrete logarithm problem. For a tamperfree device, however, the secret information stored in a memory or register may induce random transient faults due to the attacks by applying stress, electromagnetic waves, ionization, etc. The transient faults can be further divided into memory faults and computational faults, and those attacks, which are called memory and computational fault-based attacks, break various public-key cryptosystems by taking the advantage of random hardware faults, and so endanger many network security products and systems.

A memory fault denotes an original information bit stored in the memory or register spontaneously changed from 1 to 0, or vice versa. In this case, there is no additional information obtained from the error to attack the cryptosystem. This is because the system now behaves like the one with a different secret key.

Furthermore, some secret information may be revealed by using the faulty output if the stored secret key is correct but is randomly caused to become faulty when it was fetched from the memory. However, if the information is verified successfully after it is fetched from the memory, the memory fault attack can be prevented.

A computational fault indicates that a fault is generated during a cryptographic computation. Since a processor must access the memory and perform the cryptographic computation frequently, the computational fault may occur with a higher probability than the memory fault.

One computational fault-based attack on an RSA public-key cryptosystem is described as follows. Let N=pq and ed=1 (mod .Yen.(N)), where p and q are large primes, (e,N) and d are public and secret keys, respectively; and .Yen.() is the Euler totient function. For an RSA digital signature s=md (mod N), sp =md (mod p) and sq =md (mod q) are first computed and the signature s is subsequently obtained by using the Chinese Remainder Theory (CRT), that is, s=crt (N,p,q,sp,sq).

However, the result of the cryptographic computation may be erroneous due to the computational fault. Let sp ' be a faulty partial signature, and sq be an error-free one, then a faulty signature is s'=crt(N,p,q,sp ',sq). If an attacker obtains a message m and the faulty signature s', a prime q can be successfully obtained by computing q=GCD((s')e -m,N), where GCD denotes the greatest common divisor. Thus, the RSA cryptosystem will be completely broken by using one computational fault only.

Conventional countermeasures such as recomputations and verifications, or random padding, etc. are used to resist the fault-based attacks. However, those conventional methods still have some disadvantages with respect to computational complexity.

In order to detect faults in a tamperproof device during the cryptographic computation, it is necessary to develop an efficient computation system with an error-checking ability. On public-key cryptosystems, a structure of a fault-resistant system (FRS) which is a public system being capable to detect any fault existing in modular multiplication with very high probability as well as a concrete implementation of the FRS for the RSA system are set forth as follows. This fault-resistant RSA system can also resist the memory fault-based attacks and can be readily applied to other public-key cryptosystems with the same algebraic structure.

SUMMARY OF THE INVENTION

The present invention is directed to a method for designing public key cryptosystems against fault-based attacks.

An objective of the present invention is to provide a method for designing public key cryptosystems against fault-based attacks with an implementation.

In accordance with one aspect of the invention, there is provided a method for designing public key cryptosystems against fault-based attacks, which comprises steps of: mapping a message from a ring to an extended ring by applying a mathematical equation of f(a)=aRR* (mod NR) to generate a codeword; checking the codeword by performing a generalized fast Chinese Remainder Theory (CRT) computation; and mapping the final result in the extended ring into a message in the ring.

In accordance with another aspect of the invention, there is provided a hardware structure for implementing a method for designing public key cryptosystems against fault-based attacks, which comprises a plurality of encoders for encoding input messages into codewords, a plurality of error-checking components for respectively performing error-checking operations to check the respective codewords generated by the respective encoders, a multiplier for performing a multiplication operation on the checked codewords respectively from the error-checking components, an error-checking element for performing an error-checking operation to check the multiplication result, and a decoder for decoding the multiplication result from the multiplier.

BRIEF DESCRIPTION OF THE DRAWINGS

The above objective, other features and advantages of the present invention will become more apparent by describing in detail the preferred embodiment thereof with reference to the attached drawings, in which:

FIG. 1 shows a block diagram illustrating a hardware structure for implementing a method for designing public key cryptosystems against fault-based attacks in accordance with the present invention.

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT

First, a mathematical structure of a fault-resistant system (FRS) is disclosed. A model of FRS is concisely explained and a formal mathematical description is subsequently discussed as follows.

1. Model of FRS

In most public key cryptosystems, though they can perform a modular multiplication operation only, their structure is actually a ring (ZN,+,), called a ring of an integer modulo N, which is a commutative ring with identity. In an RSA system, N is a composite, while in other public-key cryptosystems, N may be a large prime.

The error detecting/correcting ability of a common error detecting/correcting code is designed for errors which have occurred during a message transmission only. Since there is no operation between codewords in the error detecting/correcting code, there is no need for any operation structure in codeword spaces.

The error detecting ability of the FRS is designed to detect the errors which have occurred within the modular multiplication operation in ring (ZN,+,). To provide an ability for error detection, the distance between message words should be enlarged while they are being encoded into codewords. That is, a message space, a ring (ZN,+,) and an original structure of the public-key cryptosystem are mapped into a sufficiently large encoding space, ring (ZM,+,) with M>N, and a multiplication modulo N is converted into a multiplication modulo M.

For saving results of the multiplication operation, the mathematical structure of the codeword space, 0that is, an image of the ring (ZN,+,) contained therein, must be isomorphic to the original message space (ZN,+,) to ensure the final result is correct.

Thus, an FRS system should embed the original message space (ZN,+,) into an extended ring (ZM,+,) and then operate on the extended ring instead.

2. Mathematical Structure of FRS

A problem exists in what an encoding space (ZM,+,) is and how to find a suitable one. A complete description of ZM and an algorithm for implementing the FRS system will be given sequentially as follows.

Here, terminologies of algebra such as semigroup, group, ring, field, commutative semigroup, commutative ring, etc. are assumed to be known to those who are skilled in the art.

An element i in a ring (R,+,.) is said to be idempotent, if ii=i.

A mapping f of semigroup (S,) to semigroup (S',*) such that f(xy)=f(x) * f(y)

for both x and y εS, is said to be a homomorphism of S into S'. Moreover, f is called an isomorphism of S if f is injective, that is, if f(x)=f(y) implies x=y.

A mapping between two rings is called a homomorphism if it is a homomorphism to both operations of rings respectively. A homomorphism is called an isomorphism if it is injective.

A semigroup (ring) S is said to be isomorphic to a semigroup (ring) S', denoted symbolically by S≅S', if there exists an isomorphism from S onto S'.

A ring R is said to be embedded into a ring R' if there exists a subring S' of R' such that R≅S' and the isomorphism from R onto S' is called an embedded mapping and R' is an extended ring of R.

An element a in a group G having a power of n is equal to an identity e where n>0, that is, an =e. No other positive integer power of a is smaller than n and n is called an order of a which is denoted by o(a). The order of a finite group is the number of elements in the group.

It should be noted that a group homomorphism maps the identity of one group into the identity of another group and a ring homomorphism maps the zero of one ring into the zero of another ring. However, the ring homomorphism does not always map the identity of one ring R with identity into the identity of another ring R'. In fact, if f is an embedded mapping from ZN into ZM, then an image f(ZN) is an ideal of ZM. An ideal of a ring with identity contains no invertible element of the ring and consequently contains no invertible element of ZM, that is, the identity 1' of ZM is not contained in f(ZN) at all.

On the other hand, the f(ZN), being isomorphic to ZN, itself is a ring with identity and must possess multiplicative identity of its own, which is not the same as the identity of the whole ring ZM. The image f(a) of an invertible element a of ZN possesses an inverse in f(ZN) during a multiplication operation of ZM while f(a) may be not invertible in ZM.

Two questions arise, which are: what is the identity of f(ZN) and how can it be mapped. The following sets out a description to ZM.

Theorem 1: Let N, M be two positive integers with M>N. If f is a nontrivial isomorphism from a ring ZN into a ring ZM, then

(1). N│M.

(2). f(1)=1', where 1 and 1' are identities of ZN and ZM respectively.

(3). f(1)=i, where i is an idempotent element of order N.

(4). f(b)=ib, for all b in ZN.

Theorem 2: ZN can be embedded into ZM if and only if

(1). N│M.

(2). There exists an idempotent element of order N in ZM.

Lemma 3: Let a

Then a is N-preserved in ZM if and only if N≤M'.

Corollary 4: Let a

Then a in ZM is an element of order N if and only if N=M'.

Theorem 5: If GCD(R,N)=1 and RR*=1 (mod N), then i=RR* is an idempotent element of order N both in ZNR and ZNR *.

According to Theorem 2 and Theorem 5, it is clear that a mapping defined by f(a)=aRR* (mod NR) from ZN into ZNR is an embedding and an implementation of FRS should embed the RSA space ZN into a larger space ZNR to provide the ability for detecting errors.

3. Implementation of FRS

Next, an implementation of the FRS is described. In the FRS, a ring ZN is embedded into an extended ring ZNR and then operated thereon. Except the difference in a bit length, the fault-resistant addition and multiplication operations in ZNR are the same as those in ZN. Therefore, no special adder or multiplier is required in the FRS.

In the FRS, since message space ZN is embedded into ZNR and then operated therein, an encoder is needed to map a message x in ZN into a codeword X in ZNR by using X=xi (mod NR), where i is defined as in Theorem 5.

First, a message x of the FRS is sent to an input terminal of the encoder where the message x is encoded into a codeword X, and then, an output of the encoder, which is the codeword X, is checked to ensure there is no error in an encoding process by examining whether x=X (mod N) is hold or not.

After the original message x has been encoded into the codeword X successfully, the codeword X is stored into a memory or executed a further computational operation immediately. An error-checking operation should be performed to detect any possible computational errors whenever after one fundamental calculation (an addition or a multiplication operation) in the FRS is done. Such an operation is performed to check whether this result is still a codeword in ZNR, that is, whether this result can be divisible by R or not.

All computational operations in the FRS are performed in ZNR. A final result of a desired encryption/decryption should be extracted from ZNR. Accordingly, a decoder is required to inversely map the final result Z in ZNR to a z in ZN by using z=Z (mod N).

FIG. 1 shows a fault-resistant multiplier. An input x of a first encoder 10 is in a ring ZN and an output thereof is in a ring ZNR. Similarly, another input y of a second encoder 20 is also in the ring ZN and another output Y thereof is in the ring ZNR. An encoding process is made by performing an encoding operation by using a mapping equation X=xRR* (mod NR) and Y=yRR* in the encoders 10, 20, respectively. To make sure that no error has occurred during the encoding process, the output X of the first encoder 10 is sent to a first error-checking device 30 to check whether x=X (mod N) is held or not. In a similar way, the output Y of the second encoder 20 is sent to a second error-checking device 40 to check whether y=Y (mod N) is held or not. If the conditions are held, that is, there is no error found in the error-detecting devices 30 and 40, X and Y are inputted to a modular multiplier 50 after the original messages x and y are respectively encoded into codewords X and Y, but the encoding process is stopped if there is an error found.

The modular multiplier 50 performs operations in ZNR. An output Z of the modular multiplier 50 is sent to a third error-checking device 60 to check whether Z=XY (mod NR) is satisfied. Z will be decoded to z=Z (mod N)=xy (mod N) by a decoder 70 if the error-checking operation is successfully performed, and an alarm is generated otherwise.

4. The Fault-Resistant CRT Computation

To an ordinary Chinese Remainder Theory (CRT), a fast CRT algorithm for an RSA system has been carried out. A Fault-Resistant CRT computation is discussed as follows.

Suppose p and q are integers with GCD(p,q)=1, and p

1. x=(((a-(b mod p))u) mod p)q+b if a≥b (mod p),

2. x=(((a+p-(b mod p))u) mod p)q+b if a

where uq=1 (mod p).

If the CRT computation is required in the FRS, since Zp and Zq are mapped to ZpR and ZqR and GCD(pR,qR)=R=1, the fast CRT algorithm described above must be modified to a general form as follows.

5. The Generalized Fast CRT Computation

Suppose p, q and R are pairwise coprime integers with p

1. x=(((a-(b mod pR))u) mod p)qR+b if a≥b (mod pR),

2. x=(((a+pR-(b mod pR))u) mod p)qR+b if a

where uq=1 (mod p). Here, (((a-(b mod pR))u) mod p) in case 1 is computed in ring ZpR as stated in section 4 and an error checking operation is made thereafter, whereafter the result is then mapped back to ring Zp so as to preserve the error detecting ability. The last portion of a multiplication by qR and an addition to b in case 1 is made in ZRN. The computation in case 2 is similar to that in case 1.

6. The Fault-Resistant Exponential Computation

In a Fault-Resistant Exponential computation, an exponent is not encoded and the exponential computation is done by multiplying a multiplier itself iteratedly, and thus the exponent is assumed to be error-free. All the operations in the exponential computation are the same as those in an ordinary exponential computation except the difference in the length of an operand and an error checking operation which is performed after each multiplication operation is done. Therefore, the most famous method such as a square-and-multiply or sliding-windows can be applied thereto.

An integer is referred to as square-free if all of its prime divisors are not repeated. A square-free integer S has a characteristic of S│P if and only if S│P2 and P can be any integer. Therefore, if the parameter S is square-free, then the number of times of executing the error checking operation can be reduced when applying the square-and-multiply or sliding-windows method shown in the following algorithm. A preferable choice of the parameter S is 232 -1 which will be discussed in the next section. In fact, the probability of a large integer being square-free is about 0.61 and thus most integers are all square-free.

An efficient algorithm called Algorithm FRSEXP for a modular exponential computation using the square-and-multiply method is described as follows. Algorithm using the sliding-windows method can be done in a similar way. The Algorithm FRSEXP ensures the probability of failing to detect errors is 1/R when an error is generated during the computation.

Let a binary representation of a secret key be d-dl-1 dl-2 . . . d1 d0 and dl-1 =1. A signature c=md (mod NR) with d from the most significant bit (MSB) to the least significant bit (LSB) can be calculated by the aforementioned algorithm. A final result of the exponential computation can be extracted from C by c=C (mod N), if necessary. This algorithm can be easily modified to calculate the signature. Note that the algorithm can also be readily modified to compute the signature more efficiently if other fast algorithms for the exponential computation such as m-ary method and its variants are applied thereto. The modular exponential computation is shown below.______________________________________

Function FRSEXP (M,d,N,R) // INPUT M,d,N,R // OUTPUT C = Md (mod NR) i := RR*; S = iM (mod NR); P = S; For j = 1-2 down to 0 do {P = P2 (mod NR); If dj = 1 then do { If RP then output "erroneous computation" and STOP. else P = PS (mod NR); } }; If RP then output "erroneous computation" and STOP. else C = P (mod NR); }

______________________________________

7. The Fault-Resistant CRT-based exponential computation

A Fault-Resistant CRT-based exponential computation by the case of RSA is shown below.

Let Rp *, Rq *, Rp-1 and Rq-1, satisfy RRp *=1 (mod p), RRq *=1 (mod q), Rp-1 Rp *=1 (mod pR) and Rq-1 Rq *=1 (mod qR), respectively. Let dp =d (mod p) and dq =d (mod q).

The algorithm is as follows:______________________________________

Function FRSCRT-RSA (M,d,N,p,q,R) // INPUT M,d,N,p,q,R // OUTPUT C = Md (mod NR) dp = d (mod p); dq = d (mod q); x1 = FRSEXP (M,dp,p,R); // x1 = (RRp *M)dp (mod pR) y1 = x1  Rp-1 (mod pR); x2 = FRSEXP (M,dq,q,R); //x2 = (RRq *M)d (mod qR); y2 = x2  Rq-1 (mod qR); P = crt(pqR,pR,qR,y1,y2); If RP then output "erroneous computation" and STOP. else C = P (mod NR); }

______________________________________

The CRT and exponential computations required in the above algorithm have been discussed in sections 5 and 6.

Now; a fault-detecting ability of FRS is described as follows. The fault-detecting ability of FRS can be divided into a memory fault-detecting ability and a computational fault-detecting ability.

8. Detecting Ability for Memory Faults

Let x be the secret key to be stored in a memory.

At first, x is encoded to X and then stored in the memory. Assuming that memory faults exist in the memory and a fetched secret key is X'=X+E, where E denotes the memory faults. In a decoding process, if RX', that is, X' is not divisible by R, then the memory faults can be detected. However, if X' is divisible by R, then the memory faults cannot be detected. Obviously, if X' can be viewed as a random integer in ZNR, then the probability that the memory faults cannot be detected is 1/R. However, a detecting ability of a code is defined as a minimum Hamming distance of the code according to a coding theory. That is, if the detecting ability of the code is k, then every memory fault E whose weight w(E) is less than k can be detected. Thus, how to choose a parameter R in the FRS such that the detecting ability is maximized when a range of R is given is introduced.

Here, the following shows that if R is selected to be R=2k -1 for some k, then the error detecting ability of the disclosed FRS would be k-1 bits.

Let I be a set of all positive integers and let A, B, S be positive integers of n bits, and w(A) is denoted to be the Hamming weight of A. The binary representations of A, B and S are A=(an-1,an-2, . . . ,a1,a0), B=(bn-1,bn-2, . . . ,b1,b0) and S=(sn-1, sn-2, . . . ,s1,s0), respectively. Let c-1 =0 and let ci, i=0,1, . . . ,n-1, be carries of the ith bit for the addition of A+B.

#(A+B) is defined to be the total number of the carries which equal to 1 in S=A+B. That is

#(A+B)=#{ci =1│ci =(ai ♁bi)ci-1 (a1 bi), i=0,1, . . . ,n-1}

where ♁, , , are bitwise operations of XOR, AND and OR, respectively.

A carry-chain of length l is a sequence of l+1 carriessuch that ci-1 =ci+1 =0 and ci =ci+1 = . . . =ci+l-1 =1. The ci, ci+1 are referred to as the chain-head and chain-rear respectively, while cj, i

Lemma 8: Let A, B ε I .orgate. {0}, then w(A+B)+#(A+B)=w(A)+w(B)

Corollary 9: Let E=et 2kt +et-1 2k(t-1) + . . . +e1 2k +e0 for some k ε I, t ε I .orgate. {0}, and ei ε I with 0≤ei <2k, i=0,1, . . . ,t. Then ##EQU1##

Theorem 10: Let E be a positive integer and R=2k -1, for some k ε N.

If R│E, then w(E)≥k.

Theorem 11: If R is chosen to be 2k -1, then the detecting ability for the memory fault in the disclosed FRS is k-1.

In other words, the minimum Hamming distance in the disclosed FRS is k if R is chosen to be 2k -1.

9. Detecting Ability for Computational Faults

Since Z=XY (mod NR)=xyRR* (mod NR), Z will be divisible by R if no error has occurred. Assuming that computational faults have occurred, let the faulty result be Z'=Z+E. If w(E)

In the last section, the performance of the FRS and the optimal value of R are shown below.

The disclosed FRS has a low computational overhead, where the computational overhead is defined as: ##EQU2##

The Odisc and Oorg denote the computational complexity in bit operations of the disclosed FRS and the original scheme without the checking ability respectively. Supposing that N and R are l and k bits in length respectively, then Oorg for the modular multiplication is l2, while Odisc is (l+k)2, Hence the computational overhead for the modular multiplication is (2kl+k2)/l2. Note that the computational overhead for the modular exponentiation required in RSA (as well as in other cryptosystems) is the same as that for the modular multiplication since the length of an exponent is the same for the disclosed FRS and the original scheme. If l=1024 and k=32, which are reasonable assumptions since l=1024 satisfies a general security consideration and the detecting ability can be accepted, then the computational overhead is 6.3%. Therefore, the modular exponentiation can be computed correctly and efficiently through the FRS. For the selection of the optimal value of R, the FRS can detect up to k-1 bits of errors in E. Thus, the performance of the detecting ability will be enhanced with a large w(R). In this case, R=2k -1 is a good choice for a fixed length of R.

Another advantage for R=2k -1 is that the modular computations can be speeded up in this special case. Let A=at-1 2(t-1)k +at-2 2(t-2)k + . . . +a1 2k +a0, where 1≤ai <2k for 0≤i≤t-1, and t=.left brkt-top.l/k.right brkt-top., .left brkt-top. .right brkt-top. denotes a ceiling function. Then the modular computations such as S=A (mod R) will be speeded up by ##EQU3## (mod R). By repeatedly performing these processes, he modular exponential operation can be executed more quickly.

With respect to the error-detecting probability, since the probability is 1/R for an error detection failure, the performance will be enhanced for a large R. However, in this situation, the computational complexity will be increased.

Therefore, the value of R is a trade-off between the error-detecting ability and the computational complexity, but it is essential to choose a special form such as R=2k -1. A value of R=232 -1 is recommended for a bit length of 1024 bits of N.

While the present invention has been explained in relation to its preferred embodiment, it is to be understood that various modifications thereof will be apparent to those skilled in the art upon reading this specification. Therefore, it is to be understood that the invention disclosed herein is intended to cover all such modifications as fall within the scope of the appended claims.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值