X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;ds=sidebyside;f=lib_generic%2Fmd5.c;h=81a09e3f904f3226f52c704b63bd7dc6aa28f3f1;hb=abc76eb6a6936a99811eda256222b3927427f8e2;hp=3cee431c71ebda31f8d442c89e7733189f7b0e65;hpb=20a14a42a25f72e379f38460b8a8484667536795;p=oweals%2Fu-boot.git diff --git a/lib_generic/md5.c b/lib_generic/md5.c index 3cee431c71..81a09e3f90 100644 --- a/lib_generic/md5.c +++ b/lib_generic/md5.c @@ -25,8 +25,12 @@ and to fit the cifs vfs by Steve French sfrench@us.ibm.com */ -#include -#include +#include "compiler.h" + +#ifndef USE_HOSTCC +#include +#include +#endif /* USE_HOSTCC */ #include static void @@ -272,3 +276,39 @@ md5 (unsigned char *input, int len, unsigned char output[16]) MD5Update(&context, input, len); MD5Final(output, &context); } + + +/* + * Calculate and store in 'output' the MD5 digest of 'len' bytes at 'input'. + * 'output' must have enough space to hold 16 bytes. If 'chunk' Trigger the + * watchdog every 'chunk_sz' bytes of input processed. + */ +void +md5_wd (unsigned char *input, int len, unsigned char output[16], + unsigned int chunk_sz) +{ + struct MD5Context context; +#if defined(CONFIG_HW_WATCHDOG) || defined(CONFIG_WATCHDOG) + unsigned char *end, *curr; + int chunk; +#endif + + MD5Init(&context); + +#if defined(CONFIG_HW_WATCHDOG) || defined(CONFIG_WATCHDOG) + curr = input; + end = input + len; + while (curr < end) { + chunk = end - curr; + if (chunk > chunk_sz) + chunk = chunk_sz; + MD5Update(&context, curr, chunk); + curr += chunk; + WATCHDOG_RESET (); + } +#else + MD5Update(&context, input, len); +#endif + + MD5Final(output, &context); +}