Complete rewrite of FIPS_selftest_dsa(). Use hardcoded 2048 bit DSA key
and SHA384. Use fips_pkey_signature_test().
This commit is contained in:
		| @@ -1,59 +1,50 @@ | |||||||
| /* crypto/dsa/dsatest.c */ | /* ==================================================================== | ||||||
| /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) |  * Copyright (c) 2011 The OpenSSL Project.  All rights reserved. | ||||||
|  * All rights reserved. |  | ||||||
|  * |  | ||||||
|  * This package is an SSL implementation written |  | ||||||
|  * by Eric Young (eay@cryptsoft.com). |  | ||||||
|  * The implementation was written so as to conform with Netscapes SSL. |  | ||||||
|  *  |  | ||||||
|  * This library is free for commercial and non-commercial use as long as |  | ||||||
|  * the following conditions are aheared to.  The following conditions |  | ||||||
|  * apply to all code found in this distribution, be it the RC4, RSA, |  | ||||||
|  * lhash, DES, etc., code; not just the SSL code.  The SSL documentation |  | ||||||
|  * included with this distribution is covered by the same copyright terms |  | ||||||
|  * except that the holder is Tim Hudson (tjh@cryptsoft.com). |  | ||||||
|  *  |  | ||||||
|  * Copyright remains Eric Young's, and as such any Copyright notices in |  | ||||||
|  * the code are not to be removed. |  | ||||||
|  * If this package is used in a product, Eric Young should be given attribution |  | ||||||
|  * as the author of the parts of the library used. |  | ||||||
|  * This can be in the form of a textual message at program startup or |  | ||||||
|  * in documentation (online or textual) provided with the package. |  | ||||||
|  * |  * | ||||||
|  * Redistribution and use in source and binary forms, with or without |  * Redistribution and use in source and binary forms, with or without | ||||||
|  * modification, are permitted provided that the following conditions |  * modification, are permitted provided that the following conditions | ||||||
|  * are met: |  * are met: | ||||||
|  * 1. Redistributions of source code must retain the copyright |  * | ||||||
|  |  * 1. Redistributions of source code must retain the above copyright | ||||||
|  *    notice, this list of conditions and the following disclaimer.  |  *    notice, this list of conditions and the following disclaimer.  | ||||||
|  |  * | ||||||
|  * 2. Redistributions in binary form must reproduce the above copyright |  * 2. Redistributions in binary form must reproduce the above copyright | ||||||
|  *    notice, this list of conditions and the following disclaimer in the |  *    notice, this list of conditions and the following disclaimer in | ||||||
|  *    documentation and/or other materials provided with the distribution. |  *    the documentation and/or other materials provided with the | ||||||
|  * 3. All advertising materials mentioning features or use of this software |  *    distribution. | ||||||
|  *    must display the following acknowledgement: |  | ||||||
|  *    "This product includes cryptographic software written by |  | ||||||
|  *     Eric Young (eay@cryptsoft.com)" |  | ||||||
|  *    The word 'cryptographic' can be left out if the rouines from the library |  | ||||||
|  *    being used are not cryptographic related :-). |  | ||||||
|  * 4. If you include any Windows specific code (or a derivative thereof) from  |  | ||||||
|  *    the apps directory (application code) you must include an acknowledgement: |  | ||||||
|  *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" |  | ||||||
|  * |  * | ||||||
|  * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND |  * 3. All advertising materials mentioning features or use of this | ||||||
|  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |  *    software must display the following acknowledgment: | ||||||
|  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |  *    "This product includes software developed by the OpenSSL Project | ||||||
|  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE |  *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)" | ||||||
|  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |  * | ||||||
|  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS |  * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to | ||||||
|  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |  *    endorse or promote products derived from this software without | ||||||
|  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |  *    prior written permission. For written permission, please contact | ||||||
|  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY |  *    openssl-core@openssl.org. | ||||||
|  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |  * | ||||||
|  * SUCH DAMAGE. |  * 5. Products derived from this software may not be called "OpenSSL" | ||||||
|  |  *    nor may "OpenSSL" appear in their names without prior written | ||||||
|  |  *    permission of the OpenSSL Project. | ||||||
|  |  * | ||||||
|  |  * 6. Redistributions of any form whatsoever must retain the following | ||||||
|  |  *    acknowledgment: | ||||||
|  |  *    "This product includes software developed by the OpenSSL Project | ||||||
|  |  *    for use in the OpenSSL Toolkit (http://www.openssl.org/)" | ||||||
|  |  * | ||||||
|  |  * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY | ||||||
|  |  * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||||||
|  |  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | ||||||
|  |  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR | ||||||
|  |  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||||
|  |  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | ||||||
|  |  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||||||
|  |  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | ||||||
|  |  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, | ||||||
|  |  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | ||||||
|  |  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED | ||||||
|  |  * OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
|  * |  * | ||||||
|  * The licence and distribution terms for any publically available version or |  | ||||||
|  * derivative of this code cannot be changed.  i.e. this code cannot simply be |  | ||||||
|  * copied and put under another distribution licence |  | ||||||
|  * [including the GNU Public Licence.] |  | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #define OPENSSL_FIPSAPI | #define OPENSSL_FIPSAPI | ||||||
| @@ -65,100 +56,130 @@ | |||||||
| #include <openssl/err.h> | #include <openssl/err.h> | ||||||
| #include <openssl/evp.h> | #include <openssl/evp.h> | ||||||
| #include <openssl/bn.h> | #include <openssl/bn.h> | ||||||
|  | #include "fips_locl.h" | ||||||
|  |  | ||||||
| #ifdef OPENSSL_FIPS | #ifdef OPENSSL_FIPS | ||||||
|  |  | ||||||
| /* out_p, out_q, out_g are taken from NIST test vectors */ | static const unsigned char dsa_test_2048_p[] = { | ||||||
|  | 	0xa8,0x53,0x78,0xd8,0xfd,0x3f,0x8d,0x72,0xec,0x74,0x18,0x08, | ||||||
|  | 	0x0d,0xa2,0x13,0x17,0xe4,0x3e,0xc4,0xb6,0x2b,0xa8,0xc8,0x62, | ||||||
|  | 	0x3b,0x7e,0x4d,0x04,0x44,0x1d,0xd1,0xa0,0x65,0x86,0x62,0x59, | ||||||
|  | 	0x64,0x93,0xca,0x8e,0x9e,0x8f,0xbb,0x7e,0x34,0xaa,0xdd,0xb6, | ||||||
|  | 	0x2e,0x5d,0x67,0xb6,0xd0,0x9a,0x6e,0x61,0xb7,0x69,0xe7,0xc3, | ||||||
|  | 	0x52,0xaa,0x2b,0x10,0xe2,0x0c,0xa0,0x63,0x69,0x63,0xb5,0x52, | ||||||
|  | 	0x3e,0x86,0x47,0x0d,0xec,0xbb,0xed,0xa0,0x27,0xe7,0x97,0xe7, | ||||||
|  | 	0xb6,0x76,0x35,0xd4,0xd4,0x9c,0x30,0x70,0x0e,0x74,0xaf,0x8a, | ||||||
|  | 	0x0f,0xf1,0x56,0xa8,0x01,0xaf,0x57,0xa2,0x6e,0x70,0x78,0xf1, | ||||||
|  | 	0xd8,0x2f,0x74,0x90,0x8e,0xcb,0x6d,0x07,0xe7,0x0b,0x35,0x03, | ||||||
|  | 	0xee,0xd9,0x4f,0xa3,0x2c,0xf1,0x7a,0x7f,0xc3,0xd6,0xcf,0x40, | ||||||
|  | 	0xdc,0x7b,0x00,0x83,0x0e,0x6a,0x25,0x66,0xdc,0x07,0x3e,0x34, | ||||||
|  | 	0x33,0x12,0x51,0x7c,0x6a,0xa5,0x15,0x2b,0x4b,0xfe,0xcd,0x2e, | ||||||
|  | 	0x55,0x1f,0xee,0x34,0x63,0x18,0xa1,0x53,0x42,0x3c,0x99,0x6b, | ||||||
|  | 	0x0d,0x5d,0xcb,0x91,0x02,0xae,0xdd,0x38,0x79,0x86,0x16,0xf1, | ||||||
|  | 	0xf1,0xe0,0xd6,0xc4,0x03,0x52,0x5b,0x1f,0x9b,0x3d,0x4d,0xc7, | ||||||
|  | 	0x66,0xde,0x2d,0xfc,0x4a,0x56,0xd7,0xb8,0xba,0x59,0x63,0xd6, | ||||||
|  | 	0x0f,0x3e,0x16,0x31,0x88,0x70,0xad,0x43,0x69,0x52,0xe5,0x57, | ||||||
|  | 	0x65,0x37,0x4e,0xab,0x85,0xe8,0xec,0x17,0xd6,0xb9,0xa4,0x54, | ||||||
|  | 	0x7b,0x9b,0x5f,0x27,0x52,0xf3,0x10,0x5b,0xe8,0x09,0xb2,0x3a, | ||||||
|  | 	0x2c,0x8d,0x74,0x69,0xdb,0x02,0xe2,0x4d,0x59,0x23,0x94,0xa7, | ||||||
|  | 	0xdb,0xa0,0x69,0xe9 | ||||||
|  | }; | ||||||
|  | static unsigned char dsa_test_2048_q[] = { | ||||||
|  | 	0xd2,0x77,0x04,0x4e,0x50,0xf5,0xa4,0xe3,0xf5,0x10,0xa5,0x0a, | ||||||
|  | 	0x0b,0x84,0xfd,0xff,0xbc,0xa0,0x47,0xed,0x27,0x60,0x20,0x56, | ||||||
|  | 	0x74,0x41,0xa0,0xa5 | ||||||
|  | }; | ||||||
|  | static const unsigned char dsa_test_2048_g[] = { | ||||||
|  | 	0x13,0xd7,0x54,0xe2,0x1f,0xd2,0x41,0x65,0x5d,0xa8,0x91,0xc5, | ||||||
|  | 	0x22,0xa6,0x5a,0x72,0xa8,0x9b,0xdc,0x64,0xec,0x9b,0x54,0xa8, | ||||||
|  | 	0x21,0xed,0x4a,0x89,0x8b,0x49,0x0e,0x0c,0x4f,0xcb,0x72,0x19, | ||||||
|  | 	0x2a,0x4a,0x20,0xf5,0x41,0xf3,0xf2,0x92,0x53,0x99,0xf0,0xba, | ||||||
|  | 	0xec,0xf9,0x29,0xaa,0xfb,0xf7,0x9d,0xfe,0x43,0x32,0x39,0x3b, | ||||||
|  | 	0x32,0xcd,0x2e,0x2f,0xcf,0x27,0x2f,0x32,0xa6,0x27,0x43,0x4a, | ||||||
|  | 	0x0d,0xf2,0x42,0xb7,0x5b,0x41,0x4d,0xf3,0x72,0x12,0x1e,0x53, | ||||||
|  | 	0xa5,0x53,0xf2,0x22,0xf8,0x36,0xb0,0x00,0xf0,0x16,0x48,0x5b, | ||||||
|  | 	0x6b,0xd0,0x89,0x84,0x51,0x80,0x1d,0xcd,0x8d,0xe6,0x4c,0xd5, | ||||||
|  | 	0x36,0x56,0x96,0xff,0xc5,0x32,0xd5,0x28,0xc5,0x06,0x62,0x0a, | ||||||
|  | 	0x94,0x2a,0x03,0x05,0x04,0x6d,0x8f,0x18,0x76,0x34,0x1f,0x1e, | ||||||
|  | 	0x57,0x0b,0xc3,0x97,0x4b,0xa6,0xb9,0xa4,0x38,0xe9,0x70,0x23, | ||||||
|  | 	0x02,0xa2,0xe6,0xe6,0x7b,0xfd,0x06,0xd3,0x2b,0xc6,0x79,0x96, | ||||||
|  | 	0x22,0x71,0xd7,0xb4,0x0c,0xd7,0x2f,0x38,0x6e,0x64,0xe0,0xd7, | ||||||
|  | 	0xef,0x86,0xca,0x8c,0xa5,0xd1,0x42,0x28,0xdc,0x2a,0x4f,0x16, | ||||||
|  | 	0xe3,0x18,0x98,0x86,0xb5,0x99,0x06,0x74,0xf4,0x20,0x0f,0x3a, | ||||||
|  | 	0x4c,0xf6,0x5a,0x3f,0x0d,0xdb,0xa1,0xfa,0x67,0x2d,0xff,0x2f, | ||||||
|  | 	0x5e,0x14,0x3d,0x10,0xe4,0xe9,0x7a,0xe8,0x4f,0x6d,0xa0,0x95, | ||||||
|  | 	0x35,0xd5,0xb9,0xdf,0x25,0x91,0x81,0xa7,0x9b,0x63,0xb0,0x69, | ||||||
|  | 	0xe9,0x49,0x97,0x2b,0x02,0xba,0x36,0xb3,0x58,0x6a,0xab,0x7e, | ||||||
|  | 	0x45,0xf3,0x22,0xf8,0x2e,0x4e,0x85,0xca,0x3a,0xb8,0x55,0x91, | ||||||
|  | 	0xb3,0xc2,0xa9,0x66 | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | static const unsigned char dsa_test_2048_pub_key[] = { | ||||||
| static unsigned char out_p[] = { | 	0x24,0x52,0xf3,0xcc,0xbe,0x9e,0xd5,0xca,0x7d,0xc7,0x4c,0x60, | ||||||
| 	0xf7, 0x7c, 0x1b, 0x83, 0xd8, 0xe8, 0x5c, 0x7f, 0x85, 0x30, 0x17, 0x57, | 	0x2b,0x99,0x22,0x6e,0x8f,0x2f,0xab,0x38,0xe7,0xd7,0xdd,0xfb, | ||||||
| 	0x21, 0x95, 0xfe, 0x26, 0x04, 0xeb, 0x47, 0x4c, 0x3a, 0x4a, 0x81, 0x4b, | 	0x75,0x53,0x9b,0x17,0x15,0x5e,0x9f,0xcf,0xd1,0xab,0xa5,0x64, | ||||||
| 	0x71, 0x2e, 0xed, 0x6e, 0x4f, 0x3d, 0x11, 0x0f, 0x7c, 0xfe, 0x36, 0x43, | 	0xeb,0x85,0x35,0xd8,0x12,0xc9,0xc2,0xdc,0xf9,0x72,0x84,0x44, | ||||||
| 	0x51, 0xd9, 0x81, 0x39, 0x17, 0xdf, 0x62, 0xf6, 0x9c, 0x01, 0xa8, 0x69, | 	0x1b,0xc4,0x82,0x24,0x36,0x24,0xc7,0xf4,0x57,0x58,0x0c,0x1c, | ||||||
| 	0x71, 0xdd, 0x29, 0x7f, 0x47, 0xe6, 0x65, 0xa6, 0x22, 0xe8, 0x6a, 0x12, | 	0x38,0xa5,0x7c,0x46,0xc4,0x57,0x39,0x24,0x70,0xed,0xb5,0x2c, | ||||||
| 	0x2b, 0xc2, 0x81, 0xff, 0x32, 0x70, 0x2f, 0x9e, 0xca, 0x53, 0x26, 0x47, | 	0xb5,0xa6,0xe0,0x3f,0xe6,0x28,0x7b,0xb6,0xf4,0x9a,0x42,0xa2, | ||||||
| 	0x0f, 0x59, 0xd7, 0x9e, 0x2c, 0xa5, 0x07, 0xc4, 0x49, 0x52, 0xa3, 0xe4, | 	0x06,0x5a,0x05,0x4f,0x03,0x08,0x39,0xdf,0x1f,0xd3,0x14,0x9c, | ||||||
| 	0x6b, 0x04, 0x00, 0x25, 0x49, 0xe2, 0xe6, 0x7f, 0x28, 0x78, 0x97, 0xb8, | 	0x4c,0xa0,0x53,0x1d,0xd8,0xca,0x8a,0xaa,0x9c,0xc7,0x33,0x71, | ||||||
| 	0x3a, 0x32, 0x14, 0x38, 0xa2, 0x51, 0x33, 0x22, 0x44, 0x7e, 0xd7, 0xef, | 	0x93,0x38,0x73,0x48,0x33,0x61,0x18,0x22,0x45,0x45,0xe8,0x8c, | ||||||
| 	0x45, 0xdb, 0x06, 0x4a, 0xd2, 0x82, 0x4a, 0x82, 0x2c, 0xb1, 0xd7, 0xd8, | 	0x80,0xff,0xd8,0x76,0x5d,0x74,0x36,0x03,0x33,0xcc,0xab,0x99, | ||||||
| 	0xb6, 0x73, 0x00, 0x4d, 0x94, 0x77, 0x94, 0xef | 	0x72,0x77,0x9b,0x65,0x25,0xa6,0x5b,0xdd,0x0d,0x10,0xc6,0x75, | ||||||
| 	}; | 	0xc1,0x09,0xbb,0xd3,0xe5,0xbe,0x4d,0x72,0xef,0x6e,0xba,0x6e, | ||||||
|  | 	0x43,0x8d,0x52,0x26,0x23,0x7d,0xb8,0x88,0x37,0x9c,0x5f,0xcc, | ||||||
| static unsigned char out_q[] = { | 	0x47,0xa3,0x84,0x7f,0xf6,0x37,0x11,0xba,0xed,0x6d,0x03,0xaf, | ||||||
| 	0xd4, 0x0a, 0xac, 0x9f, 0xbd, 0x8c, 0x80, 0xc2, 0x38, 0x7e, 0x2e, 0x0c, | 	0xe8,0x1e,0x69,0x4a,0x41,0x3b,0x68,0x0b,0xd3,0x8a,0xb4,0x90, | ||||||
| 	0x52, 0x5c, 0xea, 0x34, 0xa1, 0x83, 0x32, 0xf3 | 	0x3f,0x83,0x70,0xa7,0x07,0xef,0x55,0x1d,0x49,0x41,0x02,0x6d, | ||||||
| 	}; | 	0x95,0x79,0xd6,0x91,0xde,0x8e,0xda,0xa1,0x61,0x05,0xeb,0x9d, | ||||||
|  | 	0xba,0x3c,0x2f,0x4c,0x1b,0xec,0x50,0x82,0x75,0xaa,0x02,0x07, | ||||||
| static unsigned char out_g[] = { | 	0xe2,0x51,0xb5,0xec,0xcb,0x28,0x6a,0x4b,0x01,0xd4,0x49,0xd3, | ||||||
| 	0x34, 0x73, 0x8b, 0x57, 0x84, 0x8e, 0x55, 0xbf, 0x57, 0xcc, 0x41, 0xbb, | 	0x0a,0xcb,0x67,0x37,0x17,0xa0,0xd2,0xfb,0x3b,0x50,0xc8,0x93, | ||||||
| 	0x5e, 0x2b, 0xd5, 0x42, 0xdd, 0x24, 0x22, 0x2a, 0x09, 0xea, 0x26, 0x1e, | 	0xf7,0xda,0xb1,0x4f | ||||||
| 	0x17, 0x65, 0xcb, 0x1a, 0xb3, 0x12, 0x44, 0xa3, 0x9e, 0x99, 0xe9, 0x63, | }; | ||||||
| 	0xeb, 0x30, 0xb1, 0x78, 0x7b, 0x09, 0x40, 0x30, 0xfa, 0x83, 0xc2, 0x35, | static const unsigned char dsa_test_2048_priv_key[] = { | ||||||
| 	0xe1, 0xc4, 0x2d, 0x74, 0x1a, 0xb1, 0x83, 0x54, 0xd8, 0x29, 0xf4, 0xcf, | 	0x0c,0x4b,0x30,0x89,0xd1,0xb8,0x62,0xcb,0x3c,0x43,0x64,0x91, | ||||||
| 	0x7f, 0x6f, 0x67, 0x1c, 0x36, 0x49, 0xee, 0x6c, 0xa2, 0x3c, 0x2d, 0x6a, | 	0xf0,0x91,0x54,0x70,0xc5,0x27,0x96,0xe3,0xac,0xbe,0xe8,0x00, | ||||||
| 	0xe9, 0xd3, 0x9a, 0xf6, 0x57, 0x78, 0x6f, 0xfd, 0x33, 0xcd, 0x3c, 0xed, | 	0xec,0x55,0xf6,0xcc | ||||||
| 	0xfd, 0xd4, 0x41, 0xe6, 0x5c, 0x8b, 0xe0, 0x68, 0x31, 0x47, 0x47, 0xaf, | }; | ||||||
| 	0x12, 0xa7, 0xf9, 0x32, 0x0d, 0x94, 0x15, 0x48, 0xd0, 0x54, 0x85, 0xb2, |  | ||||||
| 	0x04, 0xb5, 0x4d, 0xd4, 0x9d, 0x05, 0x22, 0x25, 0xd9, 0xfd, 0x6c, 0x36, |  | ||||||
| 	0xef, 0xbe, 0x69, 0x6c, 0x55, 0xf4, 0xee, 0xec |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| static const unsigned char str1[]="12345678901234567890"; | static const unsigned char str1[]="12345678901234567890"; | ||||||
|  |  | ||||||
| void FIPS_corrupt_dsa() | void FIPS_corrupt_dsa() | ||||||
|     { |     { | ||||||
|     ++out_q[0]; |     ++dsa_test_2048_q[0]; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| int FIPS_selftest_dsa() | int FIPS_selftest_dsa() | ||||||
|     { | 	{ | ||||||
|     DSA *dsa=NULL; | 	DSA *dsa=NULL; | ||||||
|     int ret = 0; | 	EVP_PKEY pk; | ||||||
|     EVP_MD_CTX mctx; | 	int ret = 0; | ||||||
|     DSA_SIG *dsig = NULL; |  | ||||||
|  |  | ||||||
|     FIPS_md_ctx_init(&mctx); | 	dsa = FIPS_dsa_new(); | ||||||
|  |  | ||||||
|     dsa = FIPS_dsa_new(); | 	if(dsa == NULL) | ||||||
|  | 		goto err; | ||||||
|  |  | ||||||
|     if(dsa == NULL) | 	fips_load_key_component(dsa, p, dsa_test_2048); | ||||||
| 	goto err; | 	fips_load_key_component(dsa, q, dsa_test_2048); | ||||||
|  | 	fips_load_key_component(dsa, g, dsa_test_2048); | ||||||
|  | 	fips_load_key_component(dsa, pub_key, dsa_test_2048); | ||||||
|  | 	fips_load_key_component(dsa, priv_key, dsa_test_2048); | ||||||
|  |  | ||||||
|     if (!(dsa->p = BN_bin2bn(out_p, sizeof(out_p), dsa->p))) | 	pk.type = EVP_PKEY_DSA; | ||||||
| 	goto err; | 	pk.pkey.dsa = dsa; | ||||||
|     if (!(dsa->q = BN_bin2bn(out_q, sizeof(out_q), dsa->q))) |  | ||||||
| 	goto err; |  | ||||||
|     if (!(dsa->g = BN_bin2bn(out_g, sizeof(out_g), dsa->g))) |  | ||||||
| 	goto err; |  | ||||||
|  |  | ||||||
|     DSA_generate_key(dsa); | 	if (!fips_pkey_signature_test(&pk, str1, sizeof(str1) - 1, | ||||||
|  | 					NULL, 0, EVP_sha384(), 0, | ||||||
|  | 					"DSA SHA384")) | ||||||
|  | 		goto err; | ||||||
|  | 	ret = 1; | ||||||
|  |  | ||||||
|     if (!FIPS_digestinit(&mctx, EVP_sha1())) | 	err: | ||||||
| 	goto err; | 	if (dsa) | ||||||
|     if (!FIPS_digestupdate(&mctx, str1, 20)) | 		FIPS_dsa_free(dsa); | ||||||
| 	goto err; | 	return ret; | ||||||
|     dsig = FIPS_dsa_sign_ctx(dsa, &mctx); | 	} | ||||||
|     if (!dsig) |  | ||||||
| 	goto err; |  | ||||||
|  |  | ||||||
|     if (!FIPS_digestinit(&mctx, EVP_sha1())) |  | ||||||
| 	goto err; |  | ||||||
|     if (!FIPS_digestupdate(&mctx, str1, 20)) |  | ||||||
| 	goto err; |  | ||||||
|     if (FIPS_dsa_verify_ctx(dsa, &mctx, dsig) != 1) |  | ||||||
| 	goto err; |  | ||||||
|  |  | ||||||
|     ret = 1; |  | ||||||
|  |  | ||||||
|     err: |  | ||||||
|     FIPS_md_ctx_cleanup(&mctx); |  | ||||||
|     if (dsa) |  | ||||||
| 	FIPS_dsa_free(dsa); |  | ||||||
|     if (dsig) |  | ||||||
| 	FIPS_dsa_sig_free(dsig); |  | ||||||
|     if (ret == 0) |  | ||||||
| 	    FIPSerr(FIPS_F_FIPS_SELFTEST_DSA,FIPS_R_SELFTEST_FAILED); |  | ||||||
|     return ret; |  | ||||||
|     } |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Dr. Stephen Henson
					Dr. Stephen Henson