RSA Key Generation Using the M

RSA Key Generation Using the M,第1张

Abstract: Maxim's RSA key generaTIon library provides easy-to-use interfaces to generate RSA key pairs using the MAXQ1103 microcontroller. The MAXQ1103 microcontroller is designed for financial terminal applicaTIons and has number of security features including RSA. The RSA library uses the modulo arithmeTIc accelerator (MAA) which provides cryptographic operaTIons up to 2048 bits. The MAA allows the user to compute a set of operations that are important for many cryptographic operations. The article also explains why the MAXQ1103 Evaluation (EV) Kit and the CrossWorks development environment provide an ideal platform to develop secure applications.

IntroductionThis application note demonstrates the generation of RSA key-pair sets using the MAXQ1103 secure RISC microcontroller. The article also demonstrates how to encrypt and decrypt the plain text messages using RSA key-pair sets. To demonstrate the timing of the RSA computation, the article shows data from the DS5250 high-speed, secure microcontroller which illustrates the performance improvement achieved with the MAXQ1103.

The MAXQ1103 microcontroller is designed for financial terminal applications and has number of security features including RSA. The hardware modulo arithmetic accelerator (MAA) provides cryptographic operations up to 2048 bits. The MAA allows the user to compute a set of operations that are important for many cryptographic operations. Example operations include modular exponentiation (ae mod m); modular multiplication (a × b mod m); modular square (b² mod m); modular square followed by moduar multiply ((b² mod m) × a mod m); modular addition; and modular subtraction.

The MAXQ1103 evaluation (EV) kit and CrossWorks development environment provide an ideal platform to develop these secure applications. The EV Kit comes with all the tools necessary for development: 4MB of external program memory; 4MB of external data memory; 2 serial ports; 2 smart-card chips (one full size and one SIM card); a USB connector; an LCD screen; a 16-bit keypad; and a prototyping area.

Getting Started with RSA Key-Pair GenerationThe sample application binary (rsa_1103.hex) and sample application code that generate the RSA key pair can be obtained by writing t micro.support@maxim-ic.com. The following information will help you build and execute the RSA key-pair sample application program which is written in C and uses the CrossWorks compiler for MAXQ30.

Setting Up the MAXQ1103 EV KitRefer to application note 4273, "Getting Started with the MAXQ1103 Evaluation Kit and the CrossWorks Compiler for the MAXQ30," for details on setting up the development environment for the MAXQ1103.

The MAXQ1103 EV kit is shown in Figure 1. The hardware components required to generate the RSA key pair are:
  1. MAXQ1103 EV kit board
  2. JTAG board
  3. JTAG cable (to connect the MAXQ1103 EV kit board and JTAG board)
  4. 9-pin serial cable. (to connect the PC's COM port and EV kit's serial port 0)
  5. Two regulated power supplies (5V, ±5%, 300mA, center positive); one supply is for the MAXQ1103 EV kit and the other for the JTAG board.
The jumper settings for the EV kit are shown in the table below.

Jumper Status JU1 Short JU3 Short JU4 Short

Figure 1. MAXQ1103 EV kit with JTAG board.

Follow these steps to set up the EV kit and begin using the software for this application.
  1. Install the CrossWorks compiler for MAXQ30. The tool suite is available from Rowley Associates and is version 2.0.0.2008063000.2293 at the time of this publication.
  2. Connect the serial cable between the EV kit's port 0 and the PCs COM port so you can observe the application output onto the PC.
  3. Connect the serial cable between the JTAG board and PCs COM port. This connection is used to download the application onto the EV kit board.
  4. Open the project rsa_1103.hzp.
  5. Click on Project, then Rebuild to generate the rsa_1103.hzx output file. This file will be downloaded to the MAXQ1103 EV kit. Additionally you can generate rsa_1103.hex file by modifying the project properties. Go to Project properties, then Linker Options, then additional Output Format. Choose "hex" from the dropdown list.
  6. Connect to the target using the "Connect to the target" tab in your Targets window.
  7. The application prints the results onto serial port 0 of the EV kit.

    Open the hyperterminal and configure the appropriate COM port connection for 115200, 8 data bits, parity none, 1 stop bit, and no flow control.

    OR

    You can use Maxim's Microcontroller Tool Kit (MTK) software to see the application results. Install the MTK and open the MTK in dumb terminal mode. Configure the appropriate serial port for 115200 baud rate, and open the serial connection.
  8. Click on Debug, then Run to load and run the application. This application note uses MTK to observe the results.
The application will now prompt you for some data entry with the request to "Enter key length bits to be generated:"

Enter the number (for example, 1024) and wait for the application to display the results. The application displays the execution status shown in Figure 2. It takes approximately 5 seconds to generate a 1024-bit-length RSA key pair, then encrypt and decrypt the random message. This time can vary for each execution. The average times taken to generate RSA key-pair for various bit lengths are tabulated in Table 1.

RSA Key Generation Using the M,Figure 2. Execution status and results of sample application.,第2张
Figure 2. Execution status and results of sample application.

Developing a Simple Application Using the RSA Key-Generation LibraryThe library provides easy-to-use interface functions in C to generate the key pair and encrypt/decrypt the user message using the private/public key. Refer to the rsalib_1103.h file to see the prototypes of these interfaces. This application demonstrates the use of these interface functions:
rsa_generateKeySet(...)
rsa_bignumModExp(...)
Typical uses of these interface functions follow.
{
        unsigned long exp = 0x10001;                    // public exponent
        DIGIT *c,*x;
        BIGNUM *d;
        BIGNUM *e;
        BIGNUM *pq;
        DIGIT *plain_text;

        d = rsa_newNum();
        e = rsa_newNum();
        pq = rsa_newNum();

        // generate the public and private key pair
        // 'maxq1103_rnd' is a call-back function to generate random numbers 
        using 'random number generator' (RNG) module built into the MAXQ1103 
microcontroller.

        err = rsa_generateKeySet(d,e,exp,maxq1103_rnd,pq,keylen);

        if(err != RSA_SUCCESS)
        {       printf("\nFailed to generate RSA Keysets. Error code=%d",err);
                rsa_freeNum(d);
                rsa_freeNum(e);
                rsa_freeNum(pq);
                return;
        }

        // allocate memory for 'plain_text' and 'assign values
        // allocate memory for 'x' which will contain the encrypted text

        rsa_bignumModExp(x,plain_text,e,pq);             // use public key for encryption

        // allocate memory for 'c' which will contain the decrypted/original text

        rsa_bignumModExp(c,x,d,pq);                      // use private key for decryption

}
Typical test results for different bit lengths are shown below. These numbers can vary for each execution.

Table 1. Average Time for Generating an RSA Key Pair RSA Bit Length Generated Number of Tests Run Average Time Taken per Test to Generate RSA Key Pair (seconds) MAXQ1103 EV Kit at 12MHz DS5250 EV Kit at 22.1MHz 256 60 0.84 4.8 512 60 1.71 10.76 1024 60 4.55 26.6 1536 60 9.98 63.81 2047 60 17.36 126.81

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/dianzi/2460653.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-08-04
下一篇 2022-08-04

发表评论

登录后才能评论

评论列表(0条)

保存