forked from git/git
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'ew/hash-with-openssl-evp'
Adjust to OpenSSL 3+, which deprecates its SHA-1 functions based on its traditional API, by using its EVP API instead. * ew/hash-with-openssl-evp: avoid SHA-1 functions deprecated in OpenSSL 3+ sha256: avoid functions deprecated in OpenSSL 3+
- Loading branch information
Showing
4 changed files
with
120 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
/* wrappers for the EVP API of OpenSSL 3+ */ | ||
#ifndef SHA1_OPENSSL_H | ||
#define SHA1_OPENSSL_H | ||
#include <openssl/evp.h> | ||
|
||
struct openssl_SHA1_CTX { | ||
EVP_MD_CTX *ectx; | ||
}; | ||
|
||
typedef struct openssl_SHA1_CTX openssl_SHA1_CTX; | ||
|
||
static inline void openssl_SHA1_Init(struct openssl_SHA1_CTX *ctx) | ||
{ | ||
const EVP_MD *type = EVP_sha1(); | ||
|
||
ctx->ectx = EVP_MD_CTX_new(); | ||
if (!ctx->ectx) | ||
die("EVP_MD_CTX_new: out of memory"); | ||
|
||
EVP_DigestInit_ex(ctx->ectx, type, NULL); | ||
} | ||
|
||
static inline void openssl_SHA1_Update(struct openssl_SHA1_CTX *ctx, | ||
const void *data, | ||
size_t len) | ||
{ | ||
EVP_DigestUpdate(ctx->ectx, data, len); | ||
} | ||
|
||
static inline void openssl_SHA1_Final(unsigned char *digest, | ||
struct openssl_SHA1_CTX *ctx) | ||
{ | ||
EVP_DigestFinal_ex(ctx->ectx, digest, NULL); | ||
EVP_MD_CTX_free(ctx->ectx); | ||
} | ||
|
||
static inline void openssl_SHA1_Clone(struct openssl_SHA1_CTX *dst, | ||
const struct openssl_SHA1_CTX *src) | ||
{ | ||
EVP_MD_CTX_copy_ex(dst->ectx, src->ectx); | ||
} | ||
|
||
#define platform_SHA_CTX openssl_SHA1_CTX | ||
#define platform_SHA1_Init openssl_SHA1_Init | ||
#define platform_SHA1_Clone openssl_SHA1_Clone | ||
#define platform_SHA1_Update openssl_SHA1_Update | ||
#define platform_SHA1_Final openssl_SHA1_Final | ||
|
||
#endif /* SHA1_OPENSSL_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
/* wrappers for the EVP API of OpenSSL 3+ */ | ||
#ifndef SHA256_OPENSSL_H | ||
#define SHA256_OPENSSL_H | ||
#include <openssl/evp.h> | ||
|
||
struct openssl_SHA256_CTX { | ||
EVP_MD_CTX *ectx; | ||
}; | ||
|
||
typedef struct openssl_SHA256_CTX openssl_SHA256_CTX; | ||
|
||
static inline void openssl_SHA256_Init(struct openssl_SHA256_CTX *ctx) | ||
{ | ||
const EVP_MD *type = EVP_sha256(); | ||
|
||
ctx->ectx = EVP_MD_CTX_new(); | ||
if (!ctx->ectx) | ||
die("EVP_MD_CTX_new: out of memory"); | ||
|
||
EVP_DigestInit_ex(ctx->ectx, type, NULL); | ||
} | ||
|
||
static inline void openssl_SHA256_Update(struct openssl_SHA256_CTX *ctx, | ||
const void *data, | ||
size_t len) | ||
{ | ||
EVP_DigestUpdate(ctx->ectx, data, len); | ||
} | ||
|
||
static inline void openssl_SHA256_Final(unsigned char *digest, | ||
struct openssl_SHA256_CTX *ctx) | ||
{ | ||
EVP_DigestFinal_ex(ctx->ectx, digest, NULL); | ||
EVP_MD_CTX_free(ctx->ectx); | ||
} | ||
|
||
static inline void openssl_SHA256_Clone(struct openssl_SHA256_CTX *dst, | ||
const struct openssl_SHA256_CTX *src) | ||
{ | ||
EVP_MD_CTX_copy_ex(dst->ectx, src->ectx); | ||
} | ||
|
||
#define platform_SHA256_CTX openssl_SHA256_CTX | ||
#define platform_SHA256_Init openssl_SHA256_Init | ||
#define platform_SHA256_Clone openssl_SHA256_Clone | ||
#define platform_SHA256_Update openssl_SHA256_Update | ||
#define platform_SHA256_Final openssl_SHA256_Final | ||
|
||
#endif /* SHA256_OPENSSL_H */ |