Skip to content

Latest commit

 

History

History
51 lines (32 loc) · 1.23 KB

GUID-1986A1E9-C46F-44CB-B7B8-CA086A334C7F.md

File metadata and controls

51 lines (32 loc) · 1.23 KB

CRYPT_SHA256_Finalize Function

Parent topic:MPLAB® Harmony Crypto Library

C

int CRYPT_SHA256_Finalize(
    CRYPT_SHA256_CTX* sha256, 
    unsigned char* digest
);

Description

This function finalizes the hash and puts the result into digest.

Preconditions

The SHA256 context must be initialized prior to calling this function. The context must not be modified by code outside of this function.

Parameters

Parameters Description
sha256 Pointer to CRYPT_SHA256_CTX structure which holds the hash values.
digest Pointer to byte array to store hash result.

Returns

  • BAD_FUNC_ARG - An invalid pointer was passed to the function, either in sha256 or digest.

  • 0 - An invalid pointer was not passed to the function.

Remarks

In order to preserve the validity of the SHA256 hash, nothing must modify the context holding variable between calls to CRYPT_SHA256_DataAdd and CRYPT_SHA256_Finalize.

Example

CRYPT_SHA256_CTX sha256;
uint8_t buffer[1024];
uint8_t shaSum[SHA256_DIGEST_SIZE];

CRYPT_SHA256_Initialize(&sha256);
CRYPT_SHA256_DataAdd(&sha256, buffer, sizeof(buffer));
CRYPT_SHA256_Finalize(&sha256, shaSum);