Blame view

include/sha1.h 3.1 KB
566a494f5   Heiko Schocher   [PCS440EP] u...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
  /**
   * \file sha1.h
   * based from http://xyssl.org/code/source/sha1/
   *  FIPS-180-1 compliant SHA-1 implementation
   *
   *  Copyright (C) 2003-2006  Christophe Devine
   *
   *  This library is free software; you can redistribute it and/or
   *  modify it under the terms of the GNU Lesser General Public
   *  License, version 2.1 as published by the Free Software Foundation.
   *
   *  This library is distributed in the hope that it will be useful,
   *  but WITHOUT ANY WARRANTY; without even the implied warranty of
   *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   *  Lesser General Public License for more details.
   *
   *  You should have received a copy of the GNU Lesser General Public
   *  License along with this library; if not, write to the Free Software
   *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
4ef218f6f   Wolfgang Denk   Coding style clea...
20
   *  MA	02110-1301  USA
566a494f5   Heiko Schocher   [PCS440EP] u...
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
   */
  /*
   *  The SHA-1 standard was published by NIST in 1993.
   *
   *  http://www.itl.nist.gov/fipspubs/fip180-1.htm
   */
  #ifndef _SHA1_H
  #define _SHA1_H
  
  #ifdef __cplusplus
  extern "C" {
  #endif
  
  #define SHA1_SUM_POS	-0x20
  #define SHA1_SUM_LEN	20
  
  /**
4ef218f6f   Wolfgang Denk   Coding style clea...
38
   * \brief	   SHA-1 context structure
566a494f5   Heiko Schocher   [PCS440EP] u...
39
40
41
   */
  typedef struct
  {
4ef218f6f   Wolfgang Denk   Coding style clea...
42
43
44
      unsigned long total[2];	/*!< number of bytes processed	*/
      unsigned long state[5];	/*!< intermediate digest state	*/
      unsigned char buffer[64];	/*!< data block being processed */
566a494f5   Heiko Schocher   [PCS440EP] u...
45
46
47
48
  }
  sha1_context;
  
  /**
4ef218f6f   Wolfgang Denk   Coding style clea...
49
   * \brief	   SHA-1 context setup
566a494f5   Heiko Schocher   [PCS440EP] u...
50
   *
4ef218f6f   Wolfgang Denk   Coding style clea...
51
   * \param ctx	   SHA-1 context to be initialized
566a494f5   Heiko Schocher   [PCS440EP] u...
52
53
54
55
   */
  void sha1_starts( sha1_context *ctx );
  
  /**
4ef218f6f   Wolfgang Denk   Coding style clea...
56
   * \brief	   SHA-1 process buffer
566a494f5   Heiko Schocher   [PCS440EP] u...
57
   *
4ef218f6f   Wolfgang Denk   Coding style clea...
58
   * \param ctx	   SHA-1 context
566a494f5   Heiko Schocher   [PCS440EP] u...
59
   * \param input    buffer holding the  data
4ef218f6f   Wolfgang Denk   Coding style clea...
60
   * \param ilen	   length of the input data
566a494f5   Heiko Schocher   [PCS440EP] u...
61
   */
a7d1d7657   Simon Glass   sha1: Use const w...
62
63
  void sha1_update(sha1_context *ctx, const unsigned char *input,
  		 unsigned int ilen);
566a494f5   Heiko Schocher   [PCS440EP] u...
64
65
  
  /**
4ef218f6f   Wolfgang Denk   Coding style clea...
66
   * \brief	   SHA-1 final digest
566a494f5   Heiko Schocher   [PCS440EP] u...
67
   *
4ef218f6f   Wolfgang Denk   Coding style clea...
68
   * \param ctx	   SHA-1 context
566a494f5   Heiko Schocher   [PCS440EP] u...
69
70
71
72
73
   * \param output   SHA-1 checksum result
   */
  void sha1_finish( sha1_context *ctx, unsigned char output[20] );
  
  /**
4ef218f6f   Wolfgang Denk   Coding style clea...
74
   * \brief	   Output = SHA-1( input buffer )
566a494f5   Heiko Schocher   [PCS440EP] u...
75
76
   *
   * \param input    buffer holding the  data
4ef218f6f   Wolfgang Denk   Coding style clea...
77
   * \param ilen	   length of the input data
566a494f5   Heiko Schocher   [PCS440EP] u...
78
79
   * \param output   SHA-1 checksum result
   */
a7d1d7657   Simon Glass   sha1: Use const w...
80
81
  void sha1_csum(const unsigned char *input, unsigned int ilen,
  		unsigned char *output);
566a494f5   Heiko Schocher   [PCS440EP] u...
82
83
  
  /**
215b01bba   Bartlomiej Sieka   Add support for c...
84
85
86
87
88
89
90
   * \brief	   Output = SHA-1( input buffer ), with watchdog triggering
   *
   * \param input    buffer holding the  data
   * \param ilen	   length of the input data
   * \param output   SHA-1 checksum result
   * \param chunk_sz watchdog triggering period (in bytes of input processed)
   */
a7d1d7657   Simon Glass   sha1: Use const w...
91
92
  void sha1_csum_wd(const unsigned char *input, unsigned int ilen,
  		unsigned char *output, unsigned int chunk_sz);
566a494f5   Heiko Schocher   [PCS440EP] u...
93
94
  
  /**
4ef218f6f   Wolfgang Denk   Coding style clea...
95
   * \brief	   Output = HMAC-SHA-1( input buffer, hmac key )
566a494f5   Heiko Schocher   [PCS440EP] u...
96
   *
4ef218f6f   Wolfgang Denk   Coding style clea...
97
   * \param key	   HMAC secret key
566a494f5   Heiko Schocher   [PCS440EP] u...
98
99
   * \param keylen   length of the HMAC key
   * \param input    buffer holding the  data
4ef218f6f   Wolfgang Denk   Coding style clea...
100
   * \param ilen	   length of the input data
566a494f5   Heiko Schocher   [PCS440EP] u...
101
102
   * \param output   HMAC-SHA-1 result
   */
a7d1d7657   Simon Glass   sha1: Use const w...
103
104
105
  void sha1_hmac(const unsigned char *key, int keylen,
  		const unsigned char *input, unsigned int ilen,
  		unsigned char *output);
566a494f5   Heiko Schocher   [PCS440EP] u...
106
107
  
  /**
4ef218f6f   Wolfgang Denk   Coding style clea...
108
   * \brief	   Checkup routine
566a494f5   Heiko Schocher   [PCS440EP] u...
109
   *
4ef218f6f   Wolfgang Denk   Coding style clea...
110
   * \return	   0 if successful, or 1 if the test failed
566a494f5   Heiko Schocher   [PCS440EP] u...
111
112
113
114
115
116
117
118
   */
  int sha1_self_test( void );
  
  #ifdef __cplusplus
  }
  #endif
  
  #endif /* sha1.h */