File: sha256.h

package info (click to toggle)
guymager 0.8.13-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 1,768 kB
  • sloc: cpp: 17,479; makefile: 28; sh: 22
file content (73 lines) | stat: -rw-r--r-- 2,756 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
// ****************************************************************************
//  Project:        GUYMAGER
// ****************************************************************************
//  Programmer:     Guy Voncken
//                  Police Grand-Ducale
//                  Service de Police Judiciaire
//                  Section Nouvelles Technologies
// ****************************************************************************
//  Module:         SHA256 calculation
// ****************************************************************************

// Copyright 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017,
// 2018, 2019, 2020
// Guy Voncken
//
// This file is part of Guymager.
//
// Guymager is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 2 of the License, or
// (at your option) any later version.
//
// Guymager 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Guymager. If not, see <http://www.gnu.org/licenses/>.

// See also header in sha256.cpp.

#ifndef SHA256_H
#define SHA256_H

typedef unsigned int  uint32;
typedef unsigned char uint8;

#define SHA256_DIGEST_SIZE 32

#ifdef SHA256_OLD
   typedef struct
   {
      uint32 total[2];
      uint32 state[8];
      uint8 buffer[64];
   } t_SHA256Context, *t_pSHA256Context;

   void SHA256Init   (t_pSHA256Context pContext);
   void SHA256Append (t_pSHA256Context pContext, uint8 *input, uint32 length );
   void SHA256Finish (t_pSHA256Context pContext, uint8 digest[32] );
#else
   typedef struct
   {
      uint32 state[8];
      uint32 total[2];
      size_t buflen;
      uint32 buffer[32];
   } t_SHA256Context, *t_pSHA256Context;

   // Always make sure that these functions are compiled with O3 optimisation or
   // else, performance is about 5 times worse! See also SHA256ProcessBlock in sha256.cpp.
//   void SHA256Init   (t_pSHA256Context pContext)                                 __attribute__((optimize("-O3")));
//   void SHA256Append (t_pSHA256Context pContext, const void *buffer, size_t len) __attribute__((optimize("-O3")));
//   void SHA256Finish (t_pSHA256Context pContext, void *pDigest)                  __attribute__((optimize("-O3")));

   void SHA256Init   (t_pSHA256Context pContext);
   void SHA256Append (t_pSHA256Context pContext, const void *buffer, size_t len);
   void SHA256Finish (t_pSHA256Context pContext, void *pDigest);
#endif

#endif