1/* crypto/sha/sha256t.c */ 2/* ==================================================================== 3 * Copyright (c) 2004 The OpenSSL Project. All rights reserved. 4 * ==================================================================== 5 */ 6#include <stdio.h> 7#include <string.h> 8#include <stdlib.h> 9 10#include <openssl/sha.h> 11#include <openssl/evp.h> 12 13#if defined(OPENSSL_NO_SHA) || defined(OPENSSL_NO_SHA256) 14int main(int argc, char *argv[]) 15{ 16 printf("No SHA256 support\n"); 17 return (0); 18} 19#else 20 21unsigned char app_b1[SHA256_DIGEST_LENGTH] = { 22 0xba, 0x78, 0x16, 0xbf, 0x8f, 0x01, 0xcf, 0xea, 23 0x41, 0x41, 0x40, 0xde, 0x5d, 0xae, 0x22, 0x23, 24 0xb0, 0x03, 0x61, 0xa3, 0x96, 0x17, 0x7a, 0x9c, 25 0xb4, 0x10, 0xff, 0x61, 0xf2, 0x00, 0x15, 0xad 26}; 27 28unsigned char app_b2[SHA256_DIGEST_LENGTH] = { 29 0x24, 0x8d, 0x6a, 0x61, 0xd2, 0x06, 0x38, 0xb8, 30 0xe5, 0xc0, 0x26, 0x93, 0x0c, 0x3e, 0x60, 0x39, 31 0xa3, 0x3c, 0xe4, 0x59, 0x64, 0xff, 0x21, 0x67, 32 0xf6, 0xec, 0xed, 0xd4, 0x19, 0xdb, 0x06, 0xc1 33}; 34 35unsigned char app_b3[SHA256_DIGEST_LENGTH] = { 36 0xcd, 0xc7, 0x6e, 0x5c, 0x99, 0x14, 0xfb, 0x92, 37 0x81, 0xa1, 0xc7, 0xe2, 0x84, 0xd7, 0x3e, 0x67, 38 0xf1, 0x80, 0x9a, 0x48, 0xa4, 0x97, 0x20, 0x0e, 39 0x04, 0x6d, 0x39, 0xcc, 0xc7, 0x11, 0x2c, 0xd0 40}; 41 42unsigned char addenum_1[SHA224_DIGEST_LENGTH] = { 43 0x23, 0x09, 0x7d, 0x22, 0x34, 0x05, 0xd8, 0x22, 44 0x86, 0x42, 0xa4, 0x77, 0xbd, 0xa2, 0x55, 0xb3, 45 0x2a, 0xad, 0xbc, 0xe4, 0xbd, 0xa0, 0xb3, 0xf7, 46 0xe3, 0x6c, 0x9d, 0xa7 47}; 48 49unsigned char addenum_2[SHA224_DIGEST_LENGTH] = { 50 0x75, 0x38, 0x8b, 0x16, 0x51, 0x27, 0x76, 0xcc, 51 0x5d, 0xba, 0x5d, 0xa1, 0xfd, 0x89, 0x01, 0x50, 52 0xb0, 0xc6, 0x45, 0x5c, 0xb4, 0xf5, 0x8b, 0x19, 53 0x52, 0x52, 0x25, 0x25 54}; 55 56unsigned char addenum_3[SHA224_DIGEST_LENGTH] = { 57 0x20, 0x79, 0x46, 0x55, 0x98, 0x0c, 0x91, 0xd8, 58 0xbb, 0xb4, 0xc1, 0xea, 0x97, 0x61, 0x8a, 0x4b, 59 0xf0, 0x3f, 0x42, 0x58, 0x19, 0x48, 0xb2, 0xee, 60 0x4e, 0xe7, 0xad, 0x67 61}; 62 63int main(int argc, char **argv) 64{ 65 unsigned char md[SHA256_DIGEST_LENGTH]; 66 int i; 67 EVP_MD_CTX evp; 68 69 fprintf(stdout, "Testing SHA-256 "); 70 71 EVP_Digest("abc", 3, md, NULL, EVP_sha256(), NULL); 72 if (memcmp(md, app_b1, sizeof(app_b1))) { 73 fflush(stdout); 74 fprintf(stderr, "\nTEST 1 of 3 failed.\n"); 75 return 1; 76 } else 77 fprintf(stdout, "."); 78 fflush(stdout); 79 80 EVP_Digest("abcdbcde" "cdefdefg" "efghfghi" "ghijhijk" 81 "ijkljklm" "klmnlmno" "mnopnopq", 56, md, NULL, EVP_sha256(), 82 NULL); 83 if (memcmp(md, app_b2, sizeof(app_b2))) { 84 fflush(stdout); 85 fprintf(stderr, "\nTEST 2 of 3 failed.\n"); 86 return 1; 87 } else 88 fprintf(stdout, "."); 89 fflush(stdout); 90 91 EVP_MD_CTX_init(&evp); 92 EVP_DigestInit_ex(&evp, EVP_sha256(), NULL); 93 for (i = 0; i < 1000000; i += 160) 94 EVP_DigestUpdate(&evp, "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" 95 "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" 96 "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" 97 "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" 98 "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" "aaaaaaaa", 99 (1000000 - i) < 160 ? 1000000 - i : 160); 100 EVP_DigestFinal_ex(&evp, md, NULL); 101 EVP_MD_CTX_cleanup(&evp); 102 103 if (memcmp(md, app_b3, sizeof(app_b3))) { 104 fflush(stdout); 105 fprintf(stderr, "\nTEST 3 of 3 failed.\n"); 106 return 1; 107 } else 108 fprintf(stdout, "."); 109 fflush(stdout); 110 111 fprintf(stdout, " passed.\n"); 112 fflush(stdout); 113 114 fprintf(stdout, "Testing SHA-224 "); 115 116 EVP_Digest("abc", 3, md, NULL, EVP_sha224(), NULL); 117 if (memcmp(md, addenum_1, sizeof(addenum_1))) { 118 fflush(stdout); 119 fprintf(stderr, "\nTEST 1 of 3 failed.\n"); 120 return 1; 121 } else 122 fprintf(stdout, "."); 123 fflush(stdout); 124 125 EVP_Digest("abcdbcde" "cdefdefg" "efghfghi" "ghijhijk" 126 "ijkljklm" "klmnlmno" "mnopnopq", 56, md, NULL, EVP_sha224(), 127 NULL); 128 if (memcmp(md, addenum_2, sizeof(addenum_2))) { 129 fflush(stdout); 130 fprintf(stderr, "\nTEST 2 of 3 failed.\n"); 131 return 1; 132 } else 133 fprintf(stdout, "."); 134 fflush(stdout); 135 136 EVP_MD_CTX_init(&evp); 137 EVP_DigestInit_ex(&evp, EVP_sha224(), NULL); 138 for (i = 0; i < 1000000; i += 64) 139 EVP_DigestUpdate(&evp, "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" 140 "aaaaaaaa" "aaaaaaaa" "aaaaaaaa" "aaaaaaaa", 141 (1000000 - i) < 64 ? 1000000 - i : 64); 142 EVP_DigestFinal_ex(&evp, md, NULL); 143 EVP_MD_CTX_cleanup(&evp); 144 145 if (memcmp(md, addenum_3, sizeof(addenum_3))) { 146 fflush(stdout); 147 fprintf(stderr, "\nTEST 3 of 3 failed.\n"); 148 return 1; 149 } else 150 fprintf(stdout, "."); 151 fflush(stdout); 152 153 fprintf(stdout, " passed.\n"); 154 fflush(stdout); 155 156 return 0; 157} 158#endif 159