| /* md5.h | |
| The MD5 hash function, described in RFC 1321. | |
| Copyright (C) 2001 Niels Möller | |
| This file is part of GNU Nettle. | |
| GNU Nettle is free software: you can redistribute it and/or | |
| modify it under the terms of either: | |
| * the GNU Lesser General Public License as published by the Free | |
| Software Foundation; either version 3 of the License, or (at your | |
| option) any later version. | |
| or | |
| * the GNU General Public License as published by the Free | |
| Software Foundation; either version 2 of the License, or (at your | |
| option) any later version. | |
| or both in parallel, as here. | |
| GNU Nettle is distributed in the hope that it will be useful, | |
| but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
| General Public License for more details. | |
| You should have received copies of the GNU General Public License and | |
| the GNU Lesser General Public License along with this program. If | |
| not, see http://www.gnu.org/licenses/. | |
| */ | |
| extern "C" { | |
| /* Name mangling */ | |
| /* For backwards compatibility */ | |
| /* Digest is kept internally as 4 32-bit words. */ | |
| struct md5_ctx | |
| { | |
| uint32_t state[_MD5_DIGEST_LENGTH]; | |
| uint64_t count; /* Block count */ | |
| unsigned index; /* Into buffer */ | |
| uint8_t block[MD5_BLOCK_SIZE]; /* Block buffer */ | |
| }; | |
| void | |
| md5_init(struct md5_ctx *ctx); | |
| void | |
| md5_update(struct md5_ctx *ctx, | |
| size_t length, | |
| const uint8_t *data); | |
| void | |
| md5_digest(struct md5_ctx *ctx, | |
| size_t length, | |
| uint8_t *digest); | |
| /* Internal compression function. STATE points to 4 uint32_t words, | |
| and DATA points to 64 bytes of input data, possibly unaligned. */ | |
| void | |
| nettle_md5_compress(uint32_t *state, const uint8_t *data); | |
| } | |