2011-04-09 13:56:29 +00:00
|
|
|
/* SHADRIVER.C - test driver for SHA-1 (and SHA-2) */
|
|
|
|
|
2017-12-13 16:30:39 +00:00
|
|
|
/*-
|
|
|
|
* SPDX-License-Identifier: RSA-MD
|
|
|
|
*
|
|
|
|
* Copyright (C) 1990-2, RSA Data Security, Inc. Created 1990. All rights
|
2011-04-09 13:56:29 +00:00
|
|
|
* reserved.
|
|
|
|
*
|
|
|
|
* RSA Data Security, Inc. makes no representations concerning either the
|
|
|
|
* merchantability of this software or the suitability of this software for
|
|
|
|
* any particular purpose. It is provided "as is" without express or implied
|
|
|
|
* warranty of any kind.
|
|
|
|
*
|
|
|
|
* These notices must be retained in any copies of any part of this
|
|
|
|
* documentation and/or software. */
|
1999-02-26 04:25:01 +00:00
|
|
|
|
2001-09-30 21:56:22 +00:00
|
|
|
#include <sys/cdefs.h>
|
|
|
|
__FBSDID("$FreeBSD$");
|
|
|
|
|
2011-04-09 13:56:29 +00:00
|
|
|
#include <sys/types.h>
|
1999-02-26 04:25:01 +00:00
|
|
|
|
2011-04-09 13:56:29 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <time.h>
|
|
|
|
#include <string.h>
|
1999-02-26 04:25:01 +00:00
|
|
|
|
2011-04-09 13:56:29 +00:00
|
|
|
#include "sha.h"
|
2018-07-09 08:19:04 +00:00
|
|
|
#include "sha224.h"
|
2011-04-09 13:56:29 +00:00
|
|
|
#include "sha256.h"
|
2015-12-27 17:33:59 +00:00
|
|
|
#include "sha384.h"
|
2011-04-09 13:56:29 +00:00
|
|
|
#include "sha512.h"
|
2016-05-28 16:06:07 +00:00
|
|
|
#include "sha512t.h"
|
1999-02-26 04:25:01 +00:00
|
|
|
|
|
|
|
/* The following makes SHA default to SHA-1 if it has not already been
|
2011-04-09 13:56:29 +00:00
|
|
|
* defined with C compiler flags. */
|
1999-02-26 04:25:01 +00:00
|
|
|
#ifndef SHA
|
|
|
|
#define SHA 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if SHA == 1
|
2015-05-10 13:21:36 +00:00
|
|
|
#undef SHA_Data
|
1999-02-26 04:25:01 +00:00
|
|
|
#define SHA_Data SHA1_Data
|
2018-07-09 08:19:04 +00:00
|
|
|
#elif SHA == 224
|
|
|
|
#undef SHA_Data
|
|
|
|
#define SHA_Data SHA224_Data
|
2005-03-09 19:23:04 +00:00
|
|
|
#elif SHA == 256
|
2015-05-10 13:21:36 +00:00
|
|
|
#undef SHA_Data
|
2005-03-09 19:23:04 +00:00
|
|
|
#define SHA_Data SHA256_Data
|
2015-12-27 17:33:59 +00:00
|
|
|
#elif SHA == 384
|
|
|
|
#undef SHA_Data
|
|
|
|
#define SHA_Data SHA384_Data
|
2011-04-09 13:56:29 +00:00
|
|
|
#elif SHA == 512
|
2015-05-10 13:21:36 +00:00
|
|
|
#undef SHA_Data
|
2011-04-09 13:56:29 +00:00
|
|
|
#define SHA_Data SHA512_Data
|
2016-05-28 16:06:07 +00:00
|
|
|
#elif SHA == 512256
|
|
|
|
#undef SHA_Data
|
|
|
|
#define SHA_Data SHA512_256_Data
|
1999-02-26 04:25:01 +00:00
|
|
|
#endif
|
|
|
|
|
2011-04-09 13:56:29 +00:00
|
|
|
/* Digests a string and prints the result. */
|
|
|
|
static void
|
|
|
|
SHAString(char *string)
|
1999-02-26 04:25:01 +00:00
|
|
|
{
|
2011-04-09 13:56:29 +00:00
|
|
|
char buf[2*64 + 1];
|
1999-02-26 04:25:01 +00:00
|
|
|
|
2011-04-09 13:56:29 +00:00
|
|
|
printf("SHA-%d (\"%s\") = %s\n",
|
|
|
|
SHA, string, SHA_Data(string, strlen(string), buf));
|
1999-02-26 04:25:01 +00:00
|
|
|
}
|
|
|
|
|
2011-04-09 13:56:29 +00:00
|
|
|
/* Digests a reference suite of strings and prints the results. */
|
|
|
|
int
|
|
|
|
main(void)
|
1999-02-26 04:25:01 +00:00
|
|
|
{
|
2011-04-09 13:56:29 +00:00
|
|
|
printf("SHA-%d test suite:\n", SHA);
|
|
|
|
|
|
|
|
SHAString("");
|
|
|
|
SHAString("abc");
|
|
|
|
SHAString("message digest");
|
|
|
|
SHAString("abcdefghijklmnopqrstuvwxyz");
|
|
|
|
SHAString("ABCDEFGHIJKLMNOPQRSTUVWXYZ"
|
|
|
|
"abcdefghijklmnopqrstuvwxyz0123456789");
|
|
|
|
SHAString("1234567890123456789012345678901234567890"
|
|
|
|
"1234567890123456789012345678901234567890");
|
1999-02-26 04:25:01 +00:00
|
|
|
|
2011-04-09 13:56:29 +00:00
|
|
|
return 0;
|
1999-02-26 04:25:01 +00:00
|
|
|
}
|