mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-11-24 02:05:01 +00:00
Refactor and restructure reference code into individual self-contain modules. I have revamped the way the code is structured to make it easy to determine which parts belong in the firmware and which are used by userland tools. common/ - common utilities and stub functions (Firmware) cryptolib/ - crypto library (Firmware) misclibs/ - miscellaneous userland libraries (Userland) sctips/ - Miscellaenous scripts (Userland) tests/ - Tests (Userland) vfirmware/ - Verified Firmware Implementation vfirmware/firmware_image_fw.c (Firmware) vfirmware/firmware_image.c (Userland) vkernel/ - Verified Kernel Implementation vkernel/kernel_image_fw.c (Firmware) vkernel/kernel_image.c (Userland) Review URL: http://codereview.chromium.org/1581005
129 lines
3.8 KiB
C
129 lines
3.8 KiB
C
/* Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
/* SHA-1, 256 and 512 functions. */
|
|
|
|
#ifndef VBOOT_REFERENCE_SHA_H_
|
|
#define VBOOT_REFERENCE_SHA_H_
|
|
|
|
#ifndef VBOOT_REFERENCE_CRYPTOLIB_H_
|
|
#error "Do not include this file directly. Use cryptolib.h instead."
|
|
#endif
|
|
|
|
#include <stdint.h>
|
|
|
|
#define SHA1_DIGEST_SIZE 20
|
|
#define SHA1_BLOCK_SIZE 64
|
|
|
|
#define SHA256_DIGEST_SIZE 32
|
|
#define SHA256_BLOCK_SIZE 64
|
|
|
|
#define SHA512_DIGEST_SIZE 64
|
|
#define SHA512_BLOCK_SIZE 128
|
|
|
|
typedef struct SHA1_CTX {
|
|
uint64_t count;
|
|
uint32_t state[5];
|
|
#if defined(HAVE_ENDIAN_H) && defined(HAVE_LITTLE_ENDIAN)
|
|
union {
|
|
uint8_t b[64];
|
|
uint32_t w[16];
|
|
} buf;
|
|
#else
|
|
uint8_t buf[64];
|
|
#endif
|
|
} SHA1_CTX;
|
|
|
|
typedef struct {
|
|
uint32_t h[8];
|
|
uint32_t tot_len;
|
|
uint32_t len;
|
|
uint8_t block[2 * SHA256_BLOCK_SIZE];
|
|
uint8_t buf[SHA256_DIGEST_SIZE]; /* Used for storing the final digest. */
|
|
} SHA256_CTX;
|
|
|
|
typedef struct {
|
|
uint64_t h[8];
|
|
uint32_t tot_len;
|
|
uint32_t len;
|
|
uint8_t block[2 * SHA512_BLOCK_SIZE];
|
|
uint8_t buf[SHA512_DIGEST_SIZE]; /* Used for storing the final digest. */
|
|
} SHA512_CTX;
|
|
|
|
|
|
void SHA1_init(SHA1_CTX* ctx);
|
|
void SHA1_update(SHA1_CTX* ctx, const uint8_t* data, uint64_t len);
|
|
uint8_t* SHA1_final(SHA1_CTX* ctx);
|
|
|
|
void SHA256_init(SHA256_CTX* ctx);
|
|
void SHA256_update(SHA256_CTX* ctx, const uint8_t* data, uint64_t len);
|
|
uint8_t* SHA256_final(SHA256_CTX* ctx);
|
|
|
|
void SHA512_init(SHA512_CTX* ctx);
|
|
void SHA512_update(SHA512_CTX* ctx, const uint8_t* data, uint64_t len);
|
|
uint8_t* SHA512_final(SHA512_CTX* ctx);
|
|
|
|
/* Convenience function for SHA-1. Computes hash on [data] of length [len].
|
|
* and stores it into [digest]. [digest] should be pre-allocated to
|
|
* SHA1_DIGEST_SIZE bytes.
|
|
*/
|
|
uint8_t* SHA1(const uint8_t* data, uint64_t len, uint8_t* digest);
|
|
|
|
/* Convenience function for SHA-256. Computes hash on [data] of length [len].
|
|
* and stores it into [digest]. [digest] should be pre-allocated to
|
|
* SHA256_DIGEST_SIZE bytes.
|
|
*/
|
|
uint8_t* SHA256(const uint8_t* data, uint64_t len, uint8_t* digest);
|
|
|
|
/* Convenience function for SHA-512. Computes hash on [data] of length [len].
|
|
* and stores it into [digest]. [digest] should be pre-allocated to
|
|
* SHA512_DIGEST_SIZE bytes.
|
|
*/
|
|
uint8_t* SHA512(const uint8_t* data, uint64_t len, uint8_t* digest);
|
|
|
|
|
|
/*---- Utility functions/wrappers for message digests. */
|
|
|
|
#define SHA1_DIGEST_ALGORITHM 0
|
|
#define SHA256_DIGEST_ALGORITHM 1
|
|
#define SHA512_DIGEST_ALGORITHM 2
|
|
|
|
/* A generic digest context structure which can be used to represent
|
|
* the SHA*_CTX for multiple digest algorithms.
|
|
*/
|
|
typedef struct DigestContext {
|
|
SHA1_CTX* sha1_ctx;
|
|
SHA256_CTX* sha256_ctx;
|
|
SHA512_CTX* sha512_ctx;
|
|
int algorithm; /* Hashing algorithm to use. */
|
|
} DigestContext;
|
|
|
|
/* Wrappers for message digest algorithms. These are useful when the hashing
|
|
* operation is being done in parallel with something else. DigestContext tracks
|
|
* and stores the state of any digest algorithm (one at any given time).
|
|
*/
|
|
|
|
/* Initialize a digest context for use with signature algorithm [algorithm]. */
|
|
void DigestInit(DigestContext* ctx, int sig_algorithm);
|
|
void DigestUpdate(DigestContext* ctx, const uint8_t* data, uint64_t len);
|
|
|
|
/* Caller owns the returned digest and must free it. */
|
|
uint8_t* DigestFinal(DigestContext* ctx);
|
|
|
|
/* Returns the appropriate digest for the data in [input_file]
|
|
* based on the signature [algorithm].
|
|
* Caller owns the returned digest and must free it.
|
|
*/
|
|
uint8_t* DigestFile(char* input_file, int sig_algorithm);
|
|
|
|
/* Returns the appropriate digest of [buf] of length
|
|
* [len] based on the signature [algorithm].
|
|
* Caller owns the returned digest and must free it.
|
|
*/
|
|
uint8_t* DigestBuf(const uint8_t* buf, uint64_t len, int sig_algorithm);
|
|
|
|
|
|
#endif /* VBOOT_REFERENCE_SHA_H_ */
|