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 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
|
<?xml version='1.0' encoding='iso-8859-1'?>
<!doctype html public '-//W3C//DTD XHTML 1.0 Strict//EN' 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'>
<html xmlns='http://www.w3c.org/1999/xhtml' lang='en-us'>
<head>
<title>
SHA256Write.c
</title>
<meta http-equiv='content-type' content='text/html;iso-8859-1'/>
<meta name='generator' content='motley-tools 1.9.4 13:40:33 Feb 18 2015'/>
<meta name='author' content='cmaier@cmassoc.net'/>
<meta name='robots' content='noindex,nofollow'/>
<link href='toolkit.css' rel='stylesheet' type='text/css'/>
</head>
<body>
<div class='headerlink'>
[<a href='SHA256Reset.c.html' title=' SHA256Reset.c '>PREV</a>]
[<a href='toolkit.html' title=' Index '>HOME</a>]
[<a href='SignalToNoise1.c.html' title=' SignalToNoise1.c '>NEXT</a>]
</div>
<pre>
/*====================================================================*
*
* void SHA256Write (struct sha256 * sha256, void const * memory, size_t extent);
*
* SHA256.h
*
* write a block of data to an SHA256 digest; this function behaves
* like function write() but returns no value and does not fail; an
* unlimited amount of data may be written using successive writes;
*
* to start a new digest, use function SHA266Reset(); to read the
* digest, use function SHA256Fetch();
*
* Read standard FIPS180-2 sec 5.3.2 for an explanation;
*
* Motley Tools by Charles Maier <cmaier@cmassoc.net>;
* Copyright (c) 2001-2006 by Charles Maier Associates;
* Licensed under the Internet Software Consortium License;
*
*--------------------------------------------------------------------*/
#ifndef SHA256WRITE_SOURCE
#define SHA256WRITE_SOURCE
#include "../key/SHA256.h"
void SHA256Write (struct sha256 * sha256, void const * memory, size_t extent)
{
if (extent)
{
uint8_t * buffer = (uint8_t *)(memory);
unsigned left = sha256->count [0] & 0x3F;
unsigned fill = sizeof (sha256->block) - left;
sha256->count [0] += (uint32_t)(extent);
sha256->count [0] &= 0xFFFFFFFF;
if (sha256->count [0] < extent)
{
sha256->count [1]++;
}
if ((left) && (extent >= fill))
{
memcpy (sha256->block + left, buffer, fill);
SHA256Block (sha256, sha256->block);
extent -= fill;
buffer += fill;
left = 0;
}
while (extent >= sizeof (sha256->block))
{
SHA256Block (sha256, buffer);
extent -= sizeof (sha256->block);
buffer += sizeof (sha256->block);
}
if (extent)
{
memcpy (sha256->block + left, buffer, extent);
}
}
return;
}
#endif
</pre>
<div class='footerlink'>
[<a href='SHA256Reset.c.html' title=' SHA256Reset.c '>PREV</a>]
[<a href='toolkit.html' title=' Index '>HOME</a>]
[<a href='SignalToNoise1.c.html' title=' SignalToNoise1.c '>NEXT</a>]
</div>
</body>
</html>
|