]>
git.saurik.com Git - apple/xnu.git/blob - bsd/dev/random/YarrowCoreLib/src/sha1mod.h
2 * Copyright (c) 1999, 2000-2001 Apple Computer, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * The contents of this file constitute Original Code as defined in and
7 * are subject to the Apple Public Source License Version 1.1 (the
8 * "License"). You may not use this file except in compliance with the
9 * License. Please obtain a copy of the License at
10 * http://www.apple.com/publicsource and read it before using this file.
12 * This Original Code and all software distributed under the License are
13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17 * License for the specific language governing rights and limitations
20 * @APPLE_LICENSE_HEADER_END@
25 By Steve Reid <steve@edmweb.com>
28 /* Header portion split from main code for convenience (AYB 3/02/98) */
35 Test Vectors (from FIPS PUB 180-1)
37 A9993E36 4706816A BA3E2571 7850C26C 9CD0D89D
38 "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"
39 84983E44 1C3BD26E BAAE4AA1 F95129E5 E54670F1
40 A million repetitions of "a"
41 34AA973C D4C4DAA4 F61EEB2B DBAD2731 6534016F
44 /* Apple change - define this in the source file which uses it */
45 /* #define LITTLE_ENDIAN This should be #define'd if true. */
46 #define SHA1HANDSOFF /* Copies data before messing with it. */
50 unsigned long state
[5];
51 unsigned long count
[2];
52 unsigned char buffer
[64];
55 //Function forward declerations
56 void SHA1Transform(unsigned long state
[5], unsigned char buffer
[64]);
57 void SHA1Init(SHA1_CTX
* context
);
58 void SHA1Update(SHA1_CTX
* context
, unsigned char* data
, unsigned int len
);
59 void SHA1Final(unsigned char digest
[20], SHA1_CTX
* context
);
61 #endif /* __SHA1_H__ */