SHA256Write.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*====================================================================*
  2. *
  3. * void SHA256Write (struct sha256 * sha256, void const * memory, size_t extent);
  4. *
  5. * SHA256.h
  6. *
  7. * write a block of data to an SHA256 digest; this function behaves
  8. * like function write() but returns no value and does not fail; an
  9. * unlimited amount of data may be written using successive writes;
  10. *
  11. * to start a new digest, use function SHA266Reset(); to read the
  12. * digest, use function SHA256Fetch();
  13. *
  14. * Read standard FIPS180-2 sec 5.3.2 for an explanation;
  15. *
  16. * Motley Tools by Charles Maier;
  17. * Copyright (c) 2001-2006 by Charles Maier Associates;
  18. * Licensed under the Internet Software Consortium License;
  19. *
  20. *--------------------------------------------------------------------*/
  21. #ifndef SHA256WRITE_SOURCE
  22. #define SHA256WRITE_SOURCE
  23. #include "../key/SHA256.h"
  24. void SHA256Write (struct sha256 * sha256, void const * memory, size_t extent)
  25. {
  26. if (extent)
  27. {
  28. uint8_t * buffer = (uint8_t *)(memory);
  29. unsigned left = sha256->count [0] & 0x3F;
  30. unsigned fill = sizeof (sha256->block) - left;
  31. sha256->count [0] += (uint32_t)(extent);
  32. sha256->count [0] &= 0xFFFFFFFF;
  33. if (sha256->count [0] < extent)
  34. {
  35. sha256->count [1]++;
  36. }
  37. if ((left) && (extent >= fill))
  38. {
  39. memcpy (sha256->block + left, buffer, fill);
  40. SHA256Block (sha256, sha256->block);
  41. extent -= fill;
  42. buffer += fill;
  43. left = 0;
  44. }
  45. while (extent >= sizeof (sha256->block))
  46. {
  47. SHA256Block (sha256, buffer);
  48. extent -= sizeof (sha256->block);
  49. buffer += sizeof (sha256->block);
  50. }
  51. if (extent)
  52. {
  53. memcpy (sha256->block + left, buffer, extent);
  54. }
  55. }
  56. return;
  57. }
  58. #endif