X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavutil%2Fadler32.c;h=8dfe2ce451ef14b2446c4913fe08562783a3e4ac;hb=1146bb3babca3973e88005d267cd06210d6ac075;hp=a4c3810e05deafff899032cae851b5fa178d180e;hpb=bfe3676feb5548993292b806de45a1cbc746c05f;p=ffmpeg diff --git a/libavutil/adler32.c b/libavutil/adler32.c index a4c3810e05d..8dfe2ce451e 100644 --- a/libavutil/adler32.c +++ b/libavutil/adler32.c @@ -21,52 +21,45 @@ * 3. This notice may not be removed or altered from any source distribution. */ -#include "common.h" +/** + * @file + * Computes the Adler-32 checksum of a data stream + * + * This is a modified version based on adler32.c from the zlib library. + * @author Mark Adler + * @ingroup lavu_adler32 + */ + +#include "config.h" #include "adler32.h" #define BASE 65521L /* largest prime smaller than 65536 */ -#define DO1(buf) {s1 += *buf++; s2 += s1;} +#define DO1(buf) { s1 += *buf++; s2 += s1; } #define DO4(buf) DO1(buf); DO1(buf); DO1(buf); DO1(buf); #define DO16(buf) DO4(buf); DO4(buf); DO4(buf); DO4(buf); -unsigned long av_adler32_update(unsigned long adler, const uint8_t *buf, unsigned int len) +unsigned long av_adler32_update(unsigned long adler, const uint8_t * buf, + unsigned int len) { unsigned long s1 = adler & 0xffff; unsigned long s2 = adler >> 16; - while (len>0) { + while (len > 0) { #if CONFIG_SMALL - while(len>4 && s2 < (1U<<31)){ - DO4(buf); len-=4; + while (len > 4 && s2 < (1U << 31)) { + DO4(buf); + len -= 4; + } #else - while(len>16 && s2 < (1U<<31)){ - DO16(buf); len-=16; -#endif + while (len > 16 && s2 < (1U << 31)) { + DO16(buf); + len -= 16; } +#endif DO1(buf); len--; s1 %= BASE; s2 %= BASE; } return (s2 << 16) | s1; } - -#ifdef TEST -#include "log.h" -#define LEN 7001 -volatile int checksum; -int main(void){ - int i; - char data[LEN]; - av_log_level = AV_LOG_DEBUG; - for(i=0; i>3) + 123*i; - for(i=0; i<1000; i++){ - START_TIMER - checksum= av_adler32_update(1, data, LEN); - STOP_TIMER("adler") - } - av_log(NULL, AV_LOG_DEBUG, "%X == 50E6E508\n", checksum); - return 0; -} -#endif