<?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 &lt;cmaier@cmassoc.net&gt;;
 *   Copyright (c) 2001-2006 by Charles Maier Associates;
 *   Licensed under the Internet Software Consortium License;
 *
 *--------------------------------------------------------------------*/

#ifndef SHA256WRITE_SOURCE
#define SHA256WRITE_SOURCE

#include &quot;../key/SHA256.h&quot;

void SHA256Write (struct sha256 * sha256, void const * memory, size_t extent)

{
	if (extent)
	{
		uint8_t * buffer = (uint8_t *)(memory);
		unsigned left = sha256-&gt;count [0] &amp; 0x3F;
		unsigned fill = sizeof (sha256-&gt;block) - left;
		sha256-&gt;count [0] += (uint32_t)(extent);
		sha256-&gt;count [0] &amp;= 0xFFFFFFFF;
		if (sha256-&gt;count [0] &lt; extent)
		{
			sha256-&gt;count [1]++;
		}
		if ((left) &amp;&amp; (extent &gt;= fill))
		{
			memcpy (sha256-&gt;block + left, buffer, fill);
			SHA256Block (sha256, sha256-&gt;block);
			extent -= fill;
			buffer += fill;
			left = 0;
		}
		while (extent &gt;= sizeof (sha256-&gt;block))
		{
			SHA256Block (sha256, buffer);
			extent -= sizeof (sha256-&gt;block);
			buffer += sizeof (sha256-&gt;block);
		}
		if (extent)
		{
			memcpy (sha256-&gt;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>