#include "zbuild.h"
#include "functable.h"
#include "adler32_p.h"
Z_INTERNAL uint32_t adler32_c(uint32_t adler, const uint8_t *buf, size_t len) {
uint32_t sum2;
unsigned n;
sum2 = (adler >> 16) & 0xffff;
adler &= 0xffff;
if (UNLIKELY(len == 1))
return adler32_len_1(adler, buf, sum2);
if (UNLIKELY(buf == NULL))
return 1L;
if (UNLIKELY(len < 16))
return adler32_len_16(adler, buf, len, sum2);
while (len >= NMAX) {
len -= NMAX;
#ifdef UNROLL_MORE
n = NMAX / 16;
#else
n = NMAX / 8;
#endif
do {
#ifdef UNROLL_MORE
ADLER_DO16(adler, sum2, buf);
buf += 16;
#else
ADLER_DO8(adler, sum2, buf, 0);
buf += 8;
#endif
} while (--n);
adler %= BASE;
sum2 %= BASE;
}
return adler32_len_64(adler, buf, len, sum2);
}