123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- <?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>
|