| .. | .. |
|---|
| 1 | 1 | // SPDX-License-Identifier: GPL-2.0 |
|---|
| 2 | +#include <openssl/evp.h> |
|---|
| 2 | 3 | #include <openssl/sha.h> |
|---|
| 3 | 4 | #include <openssl/md5.h> |
|---|
| 4 | 5 | |
|---|
| 5 | 6 | int main(void) |
|---|
| 6 | 7 | { |
|---|
| 7 | | - MD5_CTX context; |
|---|
| 8 | + EVP_MD_CTX *mdctx; |
|---|
| 8 | 9 | unsigned char md[MD5_DIGEST_LENGTH + SHA_DIGEST_LENGTH]; |
|---|
| 9 | 10 | unsigned char dat[] = "12345"; |
|---|
| 11 | + unsigned int digest_len; |
|---|
| 10 | 12 | |
|---|
| 11 | | - MD5_Init(&context); |
|---|
| 12 | | - MD5_Update(&context, &dat[0], sizeof(dat)); |
|---|
| 13 | | - MD5_Final(&md[0], &context); |
|---|
| 13 | + mdctx = EVP_MD_CTX_new(); |
|---|
| 14 | + if (!mdctx) |
|---|
| 15 | + return 0; |
|---|
| 16 | + |
|---|
| 17 | + EVP_DigestInit_ex(mdctx, EVP_md5(), NULL); |
|---|
| 18 | + EVP_DigestUpdate(mdctx, &dat[0], sizeof(dat)); |
|---|
| 19 | + EVP_DigestFinal_ex(mdctx, &md[0], &digest_len); |
|---|
| 20 | + EVP_MD_CTX_free(mdctx); |
|---|
| 14 | 21 | |
|---|
| 15 | 22 | SHA1(&dat[0], sizeof(dat), &md[0]); |
|---|
| 16 | 23 | |
|---|