• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /* adler32.c -- compute the Adler-32 checksum of a data stream
2  * Copyright (C) 1995-2004 Mark Adler
3  * For conditions of distribution and use, see copyright notice in zlib.h
4  */
5 
6 /* @(#) $Id$ */
7 
8 #define ZLIB_INTERNAL
9 #include "zlib.h"
10 
11 #define BASE 65521UL    /* largest prime smaller than 65536 */
12 #define NMAX 5552
13 /* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */
14 
15 #define DO1(buf,i)  {adler += (buf)[i]; sum2 += adler;}
16 #define DO2(buf,i)  DO1(buf,i); DO1(buf,i+1);
17 #define DO4(buf,i)  DO2(buf,i); DO2(buf,i+2);
18 #define DO8(buf,i)  DO4(buf,i); DO4(buf,i+4);
19 #define DO16(buf)   DO8(buf,0); DO8(buf,8);
20 
21 /* use NO_DIVIDE if your processor does not do division in hardware */
22 #ifdef NO_DIVIDE
23 #  define MOD(a) \
24     do { \
25         if (a >= (BASE << 16)) a -= (BASE << 16); \
26         if (a >= (BASE << 15)) a -= (BASE << 15); \
27         if (a >= (BASE << 14)) a -= (BASE << 14); \
28         if (a >= (BASE << 13)) a -= (BASE << 13); \
29         if (a >= (BASE << 12)) a -= (BASE << 12); \
30         if (a >= (BASE << 11)) a -= (BASE << 11); \
31         if (a >= (BASE << 10)) a -= (BASE << 10); \
32         if (a >= (BASE << 9)) a -= (BASE << 9); \
33         if (a >= (BASE << 8)) a -= (BASE << 8); \
34         if (a >= (BASE << 7)) a -= (BASE << 7); \
35         if (a >= (BASE << 6)) a -= (BASE << 6); \
36         if (a >= (BASE << 5)) a -= (BASE << 5); \
37         if (a >= (BASE << 4)) a -= (BASE << 4); \
38         if (a >= (BASE << 3)) a -= (BASE << 3); \
39         if (a >= (BASE << 2)) a -= (BASE << 2); \
40         if (a >= (BASE << 1)) a -= (BASE << 1); \
41         if (a >= BASE) a -= BASE; \
42     } while (0)
43 #  define MOD4(a) \
44     do { \
45         if (a >= (BASE << 4)) a -= (BASE << 4); \
46         if (a >= (BASE << 3)) a -= (BASE << 3); \
47         if (a >= (BASE << 2)) a -= (BASE << 2); \
48         if (a >= (BASE << 1)) a -= (BASE << 1); \
49         if (a >= BASE) a -= BASE; \
50     } while (0)
51 #else
52 #  define MOD(a) a %= BASE
53 #  define MOD4(a) a %= BASE
54 #endif
55 
56 /* ========================================================================= */
57 
58 /*
59    The adler32 code below computes, in effect,
60 
61    uLong high = 0;
62    uLong low  = 1;
63    for (j = 0; j < len; j++) {
64      low  = (low  + buf[j]) % BASE;
65      high = (high + low) % BASE;
66    }
67    checksum = (high << 16) | low;
68 
69    Both 16-bit halves of the checksum are between 0 and BASE-1 (inclusive).
70    Hence, the minimum possible checksum value is 0, and the maximum is
71    ((BASE-1) << 16) | (BASE-1).  Applications may have reserved values
72    outside this range to carry special meanings.
73 
74    NOTE: If adler32() is changed in ANY way, be absolutely sure that the
75    change will NOT cause checksums previously stored to not match the data
76    they were originally intended to match, or expand the range in such a
77    way that values reserved by applications to carry special meanings now
78    become checksums of valid data.  Also, be sure to change adler32_range()
79    accordingly.
80 
81    This explanation and adler32_range() are not part of original software
82    distribution.  They are added at Google (2006) in accordance with the
83    copyright notice in zlib.h, which permits alteration and redistribution
84    of the original software provided, among other things, that altered
85    source versions must be plainly marked as such and not misrepresented as
86    being the original software.
87 */
88 
adler32_range(min,max)89 void ZEXPORT adler32_range(min, max)
90     uLong *min;
91     uLong *max;
92 {
93     *min = 0L;
94     *max = ((BASE-1) << 16) | (BASE-1);
95 }
96 
adler32(adler,buf,len)97 uLong ZEXPORT adler32(adler, buf, len)
98     uLong adler;
99     const Bytef *buf;
100     uInt len;
101 {
102     unsigned long sum2;
103     unsigned n;
104 
105     /* split Adler-32 into component sums */
106     sum2 = (adler >> 16) & 0xffff;
107     adler &= 0xffff;
108 
109     /* in case user likes doing a byte at a time, keep it fast */
110     if (len == 1) {
111         adler += buf[0];
112         if (adler >= BASE)
113             adler -= BASE;
114         sum2 += adler;
115         if (sum2 >= BASE)
116             sum2 -= BASE;
117         return adler | (sum2 << 16);
118     }
119 
120     /* initial Adler-32 value (deferred check for len == 1 speed) */
121     if (buf == Z_NULL)
122         return 1L;
123 
124     /* in case short lengths are provided, keep it somewhat fast */
125     if (len < 16) {
126         while (len--) {
127             adler += *buf++;
128             sum2 += adler;
129         }
130         if (adler >= BASE)
131             adler -= BASE;
132         MOD4(sum2);             /* only added so many BASE's */
133         return adler | (sum2 << 16);
134     }
135 
136     /* do length NMAX blocks -- requires just one modulo operation */
137     while (len >= NMAX) {
138         len -= NMAX;
139         n = NMAX / 16;          /* NMAX is divisible by 16 */
140         do {
141             DO16(buf);          /* 16 sums unrolled */
142             buf += 16;
143         } while (--n);
144         MOD(adler);
145         MOD(sum2);
146     }
147 
148     /* do remaining bytes (less than NMAX, still just one modulo) */
149     if (len) {                  /* avoid modulos if none remaining */
150         while (len >= 16) {
151             len -= 16;
152             DO16(buf);
153             buf += 16;
154         }
155         while (len--) {
156             adler += *buf++;
157             sum2 += adler;
158         }
159         MOD(adler);
160         MOD(sum2);
161     }
162 
163     /* return recombined sums */
164     return adler | (sum2 << 16);
165 }
166 
167 /* ========================================================================= */
adler32_combine(adler1,adler2,len2)168 uLong ZEXPORT adler32_combine(adler1, adler2, len2)
169     uLong adler1;
170     uLong adler2;
171     z_off_t len2;
172 {
173     unsigned long sum1;
174     unsigned long sum2;
175     unsigned rem;
176 
177     /* the derivation of this formula is left as an exercise for the reader */
178     rem = (unsigned)(len2 % BASE);
179     sum1 = adler1 & 0xffff;
180     sum2 = rem * sum1;
181     MOD(sum2);
182     sum1 += (adler2 & 0xffff) + BASE - 1;
183     sum2 += ((adler1 >> 16) & 0xffff) + ((adler2 >> 16) & 0xffff) + BASE - rem;
184     if (sum1 >= BASE) sum1 -= BASE;
185     if (sum1 >= BASE) sum1 -= BASE;
186     if (sum2 >= (BASE << 1)) sum2 -= (BASE << 1);
187     if (sum2 >= BASE) sum2 -= BASE;
188     return sum1 | (sum2 << 16);
189 }
190