Coverage Report

Created: 2026-06-07 06:54

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/zlib-ng/adler32_p.h
Line
Count
Source
1
/* adler32_p.h -- Private inline functions and macros shared with
2
 *                different computation of the Adler-32 checksum
3
 *                of a data stream.
4
 * Copyright (C) 1995-2011, 2016 Mark Adler
5
 * For conditions of distribution and use, see copyright notice in zlib.h
6
 */
7
8
#ifndef ADLER32_P_H
9
#define ADLER32_P_H
10
11
#include "zendian.h"
12
13
604M
#define BASE 65521U     /* largest prime smaller than 65536 */
14
1.12M
#define NMAX 5552
15
/* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */
16
#define NMAX_ALIGNED32 (NMAX & ~31)
17
/* NMAX rounded down to a multiple of 32 is 5536 */
18
19
307M
#define ADLER_DO1(sum1, sum2, buf, i)  {(sum1) += buf[(i)]; (sum2) += (sum1);}
20
3.97M
#define ADLER_DO2(sum1, sum2, buf, i)  {ADLER_DO1(sum1, sum2, buf, i); ADLER_DO1(sum1, sum2, buf, i+1);}
21
1.22M
#define ADLER_DO4(sum1, sum2, buf, i)  {ADLER_DO2(sum1, sum2, buf, i); ADLER_DO2(sum1, sum2, buf, i+2);}
22
#define ADLER_DO8(sum1, sum2, buf, i)  {ADLER_DO4(sum1, sum2, buf, i); ADLER_DO4(sum1, sum2, buf, i+4);}
23
#define ADLER_DO16(sum1, sum2, buf)    {ADLER_DO8(sum1, sum2, buf, 0); ADLER_DO8(sum1, sum2, buf, 8);}
24
25
Z_FORCEINLINE static void adler32_copy_align(uint32_t *Z_RESTRICT adler, uint8_t *dst, const uint8_t *buf, size_t len,
26
0
                                             uint32_t *Z_RESTRICT sum2, const int MAX_LEN, const int COPY) {
27
0
    Z_UNUSED(MAX_LEN);
28
0
    if (len & 1) {
29
0
        if (COPY) {
30
0
            *dst = *buf;
31
0
            dst += 1;
32
0
        }
33
0
        ADLER_DO1(*adler, *sum2, buf, 0);
34
0
        buf += 1;
35
0
    }
36
0
    if (len & 2) {
37
0
        if (COPY) {
38
0
            memcpy(dst, buf, 2);
39
0
            dst += 2;
40
0
        }
41
0
        ADLER_DO2(*adler, *sum2, buf, 0);
42
0
        buf += 2;
43
0
    }
44
0
    while (len >= 4) {
45
0
        if (COPY) {
46
0
            memcpy(dst, buf, 4);
47
0
            dst += 4;
48
0
        }
49
0
        len -= 4;
50
0
        ADLER_DO4(*adler, *sum2, buf, 0);
51
0
        buf += 4;
52
0
    }
53
0
}
Unexecuted instantiation: adler32_ssse3.c:adler32_copy_align
Unexecuted instantiation: adler32_sse42.c:adler32_copy_align
Unexecuted instantiation: adler32_avx2.c:adler32_copy_align
Unexecuted instantiation: adler32_avx512.c:adler32_copy_align
Unexecuted instantiation: adler32_avx512_vnni.c:adler32_copy_align
Unexecuted instantiation: adler32_c.c:adler32_copy_align
Unexecuted instantiation: adler32.c:adler32_copy_align
54
55
/* SIMD Within A Register (SWAR) scalar adler32. Splits bytes into
56
 * even/odd lanes packed as 4x16-bit in uint64_t, with prefix sums for s2.
57
 * Reduction uses multiply-and-shift with positional weight constants.
58
 *
59
 * Technique pioneered by Michael Niedermayer <michaelni@gmx.at>.
60
 * Max chunk: 23 iterations * 8 bytes = 184 (255*23 = 5865 < 65535). */
61
#define ADLER32_SWAR_MAX_BYTES   (23 * 8)
62
329k
#define ADLER32_SWAR_EVEN_MASK   0x00FF00FF00FF00FFULL
63
329k
#define ADLER32_SWAR_HSUM        0x1000100010001ULL
64
65
Z_FORCEINLINE static void adler32_swar(uint32_t *adler, uint8_t *dst, const uint8_t *buf, size_t len,
66
164k
                                       uint32_t *sum2, const int COPY) {
67
164k
    uint64_t sum_even = 0, sum_odd = 0, prefix_even = 0, prefix_odd = 0;
68
69
164k
    *sum2 += *adler * (uint32_t)len;
70
71
164k
    const uint64_t *src64 = (const uint64_t *)buf;
72
73
164k
    while (len >= 16) {
74
0
        uint64_t v0 = src64[0];
75
0
        uint64_t v1 = src64[1];
76
0
        if (COPY) {
77
0
            memcpy(dst, &v0, sizeof(v0));
78
0
            memcpy(dst + 8, &v1, sizeof(v1));
79
0
            dst += 16;
80
0
        }
81
82
0
        prefix_even += sum_even;
83
0
        prefix_odd += sum_odd;
84
0
        sum_even +=  v0       & ADLER32_SWAR_EVEN_MASK;
85
0
        sum_odd  += (v0 >> 8) & ADLER32_SWAR_EVEN_MASK;
86
87
0
        prefix_even += sum_even;
88
0
        prefix_odd += sum_odd;
89
0
        sum_even +=  v1       & ADLER32_SWAR_EVEN_MASK;
90
0
        sum_odd  += (v1 >> 8) & ADLER32_SWAR_EVEN_MASK;
91
92
0
        src64 += 2;
93
0
        len -= 16;
94
0
    }
95
96
    /* Handle remaining 8 bytes if present */
97
164k
    if (len >= 8) {
98
164k
        uint64_t v = *src64;
99
164k
        if (COPY)
100
18.6k
            memcpy(dst, &v, sizeof(v));
101
102
164k
        prefix_even += sum_even;
103
164k
        prefix_odd += sum_odd;
104
164k
        sum_even +=  v       & ADLER32_SWAR_EVEN_MASK;
105
164k
        sum_odd  += (v >> 8) & ADLER32_SWAR_EVEN_MASK;
106
164k
    }
107
108
    /* Horizontal sum of 4x16-bit lanes for s1 */
109
164k
    *adler += (uint32_t)(((sum_even + sum_odd) * ADLER32_SWAR_HSUM) >> 48);
110
111
    /* Widen prefix sums to 32-bit pairs and horizontal sum for s2 */
112
164k
    uint64_t pe_lo = prefix_even & 0xFFFF0000FFFFULL;
113
164k
    uint64_t pe_hi = (prefix_even >> 16) & 0xFFFF0000FFFFULL;
114
164k
    uint64_t po_lo = prefix_odd & 0xFFFF0000FFFFULL;
115
164k
    uint64_t po_hi = (prefix_odd >> 16) & 0xFFFF0000FFFFULL;
116
117
164k
    *sum2 += (uint32_t)(((pe_lo + po_lo + pe_hi + po_hi) * 0x800000008ULL) >> 32);
118
119
    /* Positional weights [8,7,6,5,4,3,2,1] per 8-byte group for s2.
120
     * On big-endian the even mask captures odd-index memory bytes (b1,b3,b5,b7)
121
     * so HSUM (+1 per odd-index byte) must be applied to sum_even, not sum_odd. */
122
164k
#if BYTE_ORDER == LITTLE_ENDIAN
123
164k
    *sum2 += 2 * (uint32_t)((sum_even * 0x4000300020001ULL) >> 48)
124
164k
           +     (uint32_t)((sum_odd  * ADLER32_SWAR_HSUM) >> 48)
125
164k
           + 2 * (uint32_t)((sum_odd  * 0x3000200010000ULL) >> 48);
126
#else
127
    *sum2 += 2 * (uint32_t)((sum_even * 0x0000100020003ULL) >> 48)
128
           +     (uint32_t)((sum_even * ADLER32_SWAR_HSUM) >> 48)
129
           + 2 * (uint32_t)((sum_odd  * 0x1000200030004ULL) >> 48);
130
#endif
131
164k
}
adler32_ssse3.c:adler32_swar
Line
Count
Source
66
118k
                                       uint32_t *sum2, const int COPY) {
67
118k
    uint64_t sum_even = 0, sum_odd = 0, prefix_even = 0, prefix_odd = 0;
68
69
118k
    *sum2 += *adler * (uint32_t)len;
70
71
118k
    const uint64_t *src64 = (const uint64_t *)buf;
72
73
118k
    while (len >= 16) {
74
0
        uint64_t v0 = src64[0];
75
0
        uint64_t v1 = src64[1];
76
0
        if (COPY) {
77
0
            memcpy(dst, &v0, sizeof(v0));
78
0
            memcpy(dst + 8, &v1, sizeof(v1));
79
0
            dst += 16;
80
0
        }
81
82
0
        prefix_even += sum_even;
83
0
        prefix_odd += sum_odd;
84
0
        sum_even +=  v0       & ADLER32_SWAR_EVEN_MASK;
85
0
        sum_odd  += (v0 >> 8) & ADLER32_SWAR_EVEN_MASK;
86
87
0
        prefix_even += sum_even;
88
0
        prefix_odd += sum_odd;
89
0
        sum_even +=  v1       & ADLER32_SWAR_EVEN_MASK;
90
0
        sum_odd  += (v1 >> 8) & ADLER32_SWAR_EVEN_MASK;
91
92
0
        src64 += 2;
93
0
        len -= 16;
94
0
    }
95
96
    /* Handle remaining 8 bytes if present */
97
118k
    if (len >= 8) {
98
118k
        uint64_t v = *src64;
99
118k
        if (COPY)
100
0
            memcpy(dst, &v, sizeof(v));
101
102
118k
        prefix_even += sum_even;
103
118k
        prefix_odd += sum_odd;
104
118k
        sum_even +=  v       & ADLER32_SWAR_EVEN_MASK;
105
118k
        sum_odd  += (v >> 8) & ADLER32_SWAR_EVEN_MASK;
106
118k
    }
107
108
    /* Horizontal sum of 4x16-bit lanes for s1 */
109
118k
    *adler += (uint32_t)(((sum_even + sum_odd) * ADLER32_SWAR_HSUM) >> 48);
110
111
    /* Widen prefix sums to 32-bit pairs and horizontal sum for s2 */
112
118k
    uint64_t pe_lo = prefix_even & 0xFFFF0000FFFFULL;
113
118k
    uint64_t pe_hi = (prefix_even >> 16) & 0xFFFF0000FFFFULL;
114
118k
    uint64_t po_lo = prefix_odd & 0xFFFF0000FFFFULL;
115
118k
    uint64_t po_hi = (prefix_odd >> 16) & 0xFFFF0000FFFFULL;
116
117
118k
    *sum2 += (uint32_t)(((pe_lo + po_lo + pe_hi + po_hi) * 0x800000008ULL) >> 32);
118
119
    /* Positional weights [8,7,6,5,4,3,2,1] per 8-byte group for s2.
120
     * On big-endian the even mask captures odd-index memory bytes (b1,b3,b5,b7)
121
     * so HSUM (+1 per odd-index byte) must be applied to sum_even, not sum_odd. */
122
118k
#if BYTE_ORDER == LITTLE_ENDIAN
123
118k
    *sum2 += 2 * (uint32_t)((sum_even * 0x4000300020001ULL) >> 48)
124
118k
           +     (uint32_t)((sum_odd  * ADLER32_SWAR_HSUM) >> 48)
125
118k
           + 2 * (uint32_t)((sum_odd  * 0x3000200010000ULL) >> 48);
126
#else
127
    *sum2 += 2 * (uint32_t)((sum_even * 0x0000100020003ULL) >> 48)
128
           +     (uint32_t)((sum_even * ADLER32_SWAR_HSUM) >> 48)
129
           + 2 * (uint32_t)((sum_odd  * 0x1000200030004ULL) >> 48);
130
#endif
131
118k
}
adler32_sse42.c:adler32_swar
Line
Count
Source
66
9.05k
                                       uint32_t *sum2, const int COPY) {
67
9.05k
    uint64_t sum_even = 0, sum_odd = 0, prefix_even = 0, prefix_odd = 0;
68
69
9.05k
    *sum2 += *adler * (uint32_t)len;
70
71
9.05k
    const uint64_t *src64 = (const uint64_t *)buf;
72
73
9.05k
    while (len >= 16) {
74
0
        uint64_t v0 = src64[0];
75
0
        uint64_t v1 = src64[1];
76
0
        if (COPY) {
77
0
            memcpy(dst, &v0, sizeof(v0));
78
0
            memcpy(dst + 8, &v1, sizeof(v1));
79
0
            dst += 16;
80
0
        }
81
82
0
        prefix_even += sum_even;
83
0
        prefix_odd += sum_odd;
84
0
        sum_even +=  v0       & ADLER32_SWAR_EVEN_MASK;
85
0
        sum_odd  += (v0 >> 8) & ADLER32_SWAR_EVEN_MASK;
86
87
0
        prefix_even += sum_even;
88
0
        prefix_odd += sum_odd;
89
0
        sum_even +=  v1       & ADLER32_SWAR_EVEN_MASK;
90
0
        sum_odd  += (v1 >> 8) & ADLER32_SWAR_EVEN_MASK;
91
92
0
        src64 += 2;
93
0
        len -= 16;
94
0
    }
95
96
    /* Handle remaining 8 bytes if present */
97
9.05k
    if (len >= 8) {
98
9.05k
        uint64_t v = *src64;
99
9.05k
        if (COPY)
100
9.05k
            memcpy(dst, &v, sizeof(v));
101
102
9.05k
        prefix_even += sum_even;
103
9.05k
        prefix_odd += sum_odd;
104
9.05k
        sum_even +=  v       & ADLER32_SWAR_EVEN_MASK;
105
9.05k
        sum_odd  += (v >> 8) & ADLER32_SWAR_EVEN_MASK;
106
9.05k
    }
107
108
    /* Horizontal sum of 4x16-bit lanes for s1 */
109
9.05k
    *adler += (uint32_t)(((sum_even + sum_odd) * ADLER32_SWAR_HSUM) >> 48);
110
111
    /* Widen prefix sums to 32-bit pairs and horizontal sum for s2 */
112
9.05k
    uint64_t pe_lo = prefix_even & 0xFFFF0000FFFFULL;
113
9.05k
    uint64_t pe_hi = (prefix_even >> 16) & 0xFFFF0000FFFFULL;
114
9.05k
    uint64_t po_lo = prefix_odd & 0xFFFF0000FFFFULL;
115
9.05k
    uint64_t po_hi = (prefix_odd >> 16) & 0xFFFF0000FFFFULL;
116
117
9.05k
    *sum2 += (uint32_t)(((pe_lo + po_lo + pe_hi + po_hi) * 0x800000008ULL) >> 32);
118
119
    /* Positional weights [8,7,6,5,4,3,2,1] per 8-byte group for s2.
120
     * On big-endian the even mask captures odd-index memory bytes (b1,b3,b5,b7)
121
     * so HSUM (+1 per odd-index byte) must be applied to sum_even, not sum_odd. */
122
9.05k
#if BYTE_ORDER == LITTLE_ENDIAN
123
9.05k
    *sum2 += 2 * (uint32_t)((sum_even * 0x4000300020001ULL) >> 48)
124
9.05k
           +     (uint32_t)((sum_odd  * ADLER32_SWAR_HSUM) >> 48)
125
9.05k
           + 2 * (uint32_t)((sum_odd  * 0x3000200010000ULL) >> 48);
126
#else
127
    *sum2 += 2 * (uint32_t)((sum_even * 0x0000100020003ULL) >> 48)
128
           +     (uint32_t)((sum_even * ADLER32_SWAR_HSUM) >> 48)
129
           + 2 * (uint32_t)((sum_odd  * 0x1000200030004ULL) >> 48);
130
#endif
131
9.05k
}
adler32_avx2.c:adler32_swar
Line
Count
Source
66
37.1k
                                       uint32_t *sum2, const int COPY) {
67
37.1k
    uint64_t sum_even = 0, sum_odd = 0, prefix_even = 0, prefix_odd = 0;
68
69
37.1k
    *sum2 += *adler * (uint32_t)len;
70
71
37.1k
    const uint64_t *src64 = (const uint64_t *)buf;
72
73
37.1k
    while (len >= 16) {
74
0
        uint64_t v0 = src64[0];
75
0
        uint64_t v1 = src64[1];
76
0
        if (COPY) {
77
0
            memcpy(dst, &v0, sizeof(v0));
78
0
            memcpy(dst + 8, &v1, sizeof(v1));
79
0
            dst += 16;
80
0
        }
81
82
0
        prefix_even += sum_even;
83
0
        prefix_odd += sum_odd;
84
0
        sum_even +=  v0       & ADLER32_SWAR_EVEN_MASK;
85
0
        sum_odd  += (v0 >> 8) & ADLER32_SWAR_EVEN_MASK;
86
87
0
        prefix_even += sum_even;
88
0
        prefix_odd += sum_odd;
89
0
        sum_even +=  v1       & ADLER32_SWAR_EVEN_MASK;
90
0
        sum_odd  += (v1 >> 8) & ADLER32_SWAR_EVEN_MASK;
91
92
0
        src64 += 2;
93
0
        len -= 16;
94
0
    }
95
96
    /* Handle remaining 8 bytes if present */
97
37.1k
    if (len >= 8) {
98
37.1k
        uint64_t v = *src64;
99
37.1k
        if (COPY)
100
9.62k
            memcpy(dst, &v, sizeof(v));
101
102
37.1k
        prefix_even += sum_even;
103
37.1k
        prefix_odd += sum_odd;
104
37.1k
        sum_even +=  v       & ADLER32_SWAR_EVEN_MASK;
105
37.1k
        sum_odd  += (v >> 8) & ADLER32_SWAR_EVEN_MASK;
106
37.1k
    }
107
108
    /* Horizontal sum of 4x16-bit lanes for s1 */
109
37.1k
    *adler += (uint32_t)(((sum_even + sum_odd) * ADLER32_SWAR_HSUM) >> 48);
110
111
    /* Widen prefix sums to 32-bit pairs and horizontal sum for s2 */
112
37.1k
    uint64_t pe_lo = prefix_even & 0xFFFF0000FFFFULL;
113
37.1k
    uint64_t pe_hi = (prefix_even >> 16) & 0xFFFF0000FFFFULL;
114
37.1k
    uint64_t po_lo = prefix_odd & 0xFFFF0000FFFFULL;
115
37.1k
    uint64_t po_hi = (prefix_odd >> 16) & 0xFFFF0000FFFFULL;
116
117
37.1k
    *sum2 += (uint32_t)(((pe_lo + po_lo + pe_hi + po_hi) * 0x800000008ULL) >> 32);
118
119
    /* Positional weights [8,7,6,5,4,3,2,1] per 8-byte group for s2.
120
     * On big-endian the even mask captures odd-index memory bytes (b1,b3,b5,b7)
121
     * so HSUM (+1 per odd-index byte) must be applied to sum_even, not sum_odd. */
122
37.1k
#if BYTE_ORDER == LITTLE_ENDIAN
123
37.1k
    *sum2 += 2 * (uint32_t)((sum_even * 0x4000300020001ULL) >> 48)
124
37.1k
           +     (uint32_t)((sum_odd  * ADLER32_SWAR_HSUM) >> 48)
125
37.1k
           + 2 * (uint32_t)((sum_odd  * 0x3000200010000ULL) >> 48);
126
#else
127
    *sum2 += 2 * (uint32_t)((sum_even * 0x0000100020003ULL) >> 48)
128
           +     (uint32_t)((sum_even * ADLER32_SWAR_HSUM) >> 48)
129
           + 2 * (uint32_t)((sum_odd  * 0x1000200030004ULL) >> 48);
130
#endif
131
37.1k
}
Unexecuted instantiation: adler32_avx512.c:adler32_swar
Unexecuted instantiation: adler32_avx512_vnni.c:adler32_swar
Unexecuted instantiation: adler32_c.c:adler32_swar
Unexecuted instantiation: adler32.c:adler32_swar
132
133
Z_FORCEINLINE static uint32_t adler32_copy_tail(uint32_t adler, uint8_t *dst, const uint8_t *buf, size_t len,
134
301M
                                                uint32_t sum2, const int REBASE, const int MAX_LEN, const int COPY) {
135
301M
    if (len) {
136
300M
        Z_UNUSED(MAX_LEN);
137
        /* Process using packed 64-bit arithmetic when source is aligned */
138
301M
        while (len >= 8 && ((uintptr_t)buf & 7) == 0) {
139
164k
            size_t chunk = MIN(ALIGN_DOWN(len, (size_t)8), (size_t)ADLER32_SWAR_MAX_BYTES);
140
164k
            adler32_swar(&adler, dst, buf, chunk, &sum2, COPY);
141
164k
            buf += chunk;
142
164k
            if (COPY)
143
18.6k
                dst += chunk;
144
164k
            len -= chunk;
145
164k
        }
146
        /* DO4 loop avoids GCC x86 register pressure from hoisted DO8/DO16 loads. */
147
302M
        while (len >= 4) {
148
1.22M
            if (COPY) {
149
27.6k
                memcpy(dst, buf, 4);
150
27.6k
                dst += 4;
151
27.6k
            }
152
1.22M
            len -= 4;
153
1.22M
            ADLER_DO4(adler, sum2, buf, 0);
154
1.22M
            buf += 4;
155
1.22M
        }
156
300M
        if (len & 2) {
157
1.52M
            if (COPY) {
158
28.2k
                memcpy(dst, buf, 2);
159
28.2k
                dst += 2;
160
28.2k
            }
161
1.52M
            ADLER_DO2(adler, sum2, buf, 0);
162
1.52M
            buf += 2;
163
1.52M
        }
164
300M
        if (len & 1) {
165
299M
            if (COPY)
166
297M
                *dst = *buf;
167
299M
            ADLER_DO1(adler, sum2, buf, 0);
168
299M
        }
169
300M
    }
170
301M
    if (REBASE) {
171
300M
        adler %= BASE;
172
300M
        sum2 %= BASE;
173
300M
    }
174
    /* D = B * 65536 + A, see: https://en.wikipedia.org/wiki/Adler-32. */
175
301M
    return adler | (sum2 << 16);
176
301M
}
adler32_ssse3.c:adler32_copy_tail
Line
Count
Source
134
564k
                                                uint32_t sum2, const int REBASE, const int MAX_LEN, const int COPY) {
135
564k
    if (len) {
136
472k
        Z_UNUSED(MAX_LEN);
137
        /* Process using packed 64-bit arithmetic when source is aligned */
138
591k
        while (len >= 8 && ((uintptr_t)buf & 7) == 0) {
139
118k
            size_t chunk = MIN(ALIGN_DOWN(len, (size_t)8), (size_t)ADLER32_SWAR_MAX_BYTES);
140
118k
            adler32_swar(&adler, dst, buf, chunk, &sum2, COPY);
141
118k
            buf += chunk;
142
118k
            if (COPY)
143
0
                dst += chunk;
144
118k
            len -= chunk;
145
118k
        }
146
        /* DO4 loop avoids GCC x86 register pressure from hoisted DO8/DO16 loads. */
147
1.55M
        while (len >= 4) {
148
1.08M
            if (COPY) {
149
0
                memcpy(dst, buf, 4);
150
0
                dst += 4;
151
0
            }
152
1.08M
            len -= 4;
153
1.08M
            ADLER_DO4(adler, sum2, buf, 0);
154
1.08M
            buf += 4;
155
1.08M
        }
156
472k
        if (len & 2) {
157
384k
            if (COPY) {
158
0
                memcpy(dst, buf, 2);
159
0
                dst += 2;
160
0
            }
161
384k
            ADLER_DO2(adler, sum2, buf, 0);
162
384k
            buf += 2;
163
384k
        }
164
472k
        if (len & 1) {
165
144k
            if (COPY)
166
0
                *dst = *buf;
167
144k
            ADLER_DO1(adler, sum2, buf, 0);
168
144k
        }
169
472k
    }
170
564k
    if (REBASE) {
171
472k
        adler %= BASE;
172
472k
        sum2 %= BASE;
173
472k
    }
174
    /* D = B * 65536 + A, see: https://en.wikipedia.org/wiki/Adler-32. */
175
564k
    return adler | (sum2 << 16);
176
564k
}
adler32_sse42.c:adler32_copy_tail
Line
Count
Source
134
19.3k
                                                uint32_t sum2, const int REBASE, const int MAX_LEN, const int COPY) {
135
19.3k
    if (len) {
136
19.3k
        Z_UNUSED(MAX_LEN);
137
        /* Process using packed 64-bit arithmetic when source is aligned */
138
28.3k
        while (len >= 8 && ((uintptr_t)buf & 7) == 0) {
139
9.05k
            size_t chunk = MIN(ALIGN_DOWN(len, (size_t)8), (size_t)ADLER32_SWAR_MAX_BYTES);
140
9.05k
            adler32_swar(&adler, dst, buf, chunk, &sum2, COPY);
141
9.05k
            buf += chunk;
142
9.05k
            if (COPY)
143
9.05k
                dst += chunk;
144
9.05k
            len -= chunk;
145
9.05k
        }
146
        /* DO4 loop avoids GCC x86 register pressure from hoisted DO8/DO16 loads. */
147
32.1k
        while (len >= 4) {
148
12.7k
            if (COPY) {
149
12.7k
                memcpy(dst, buf, 4);
150
12.7k
                dst += 4;
151
12.7k
            }
152
12.7k
            len -= 4;
153
12.7k
            ADLER_DO4(adler, sum2, buf, 0);
154
12.7k
            buf += 4;
155
12.7k
        }
156
19.3k
        if (len & 2) {
157
11.1k
            if (COPY) {
158
11.1k
                memcpy(dst, buf, 2);
159
11.1k
                dst += 2;
160
11.1k
            }
161
11.1k
            ADLER_DO2(adler, sum2, buf, 0);
162
11.1k
            buf += 2;
163
11.1k
        }
164
19.3k
        if (len & 1) {
165
9.78k
            if (COPY)
166
9.78k
                *dst = *buf;
167
9.78k
            ADLER_DO1(adler, sum2, buf, 0);
168
9.78k
        }
169
19.3k
    }
170
19.3k
    if (REBASE) {
171
19.3k
        adler %= BASE;
172
19.3k
        sum2 %= BASE;
173
19.3k
    }
174
    /* D = B * 65536 + A, see: https://en.wikipedia.org/wiki/Adler-32. */
175
19.3k
    return adler | (sum2 << 16);
176
19.3k
}
adler32_avx2.c:adler32_copy_tail
Line
Count
Source
134
300M
                                                uint32_t sum2, const int REBASE, const int MAX_LEN, const int COPY) {
135
300M
    if (len) {
136
300M
        Z_UNUSED(MAX_LEN);
137
        /* Process using packed 64-bit arithmetic when source is aligned */
138
300M
        while (len >= 8 && ((uintptr_t)buf & 7) == 0) {
139
37.1k
            size_t chunk = MIN(ALIGN_DOWN(len, (size_t)8), (size_t)ADLER32_SWAR_MAX_BYTES);
140
37.1k
            adler32_swar(&adler, dst, buf, chunk, &sum2, COPY);
141
37.1k
            buf += chunk;
142
37.1k
            if (COPY)
143
9.62k
                dst += chunk;
144
37.1k
            len -= chunk;
145
37.1k
        }
146
        /* DO4 loop avoids GCC x86 register pressure from hoisted DO8/DO16 loads. */
147
300M
        while (len >= 4) {
148
129k
            if (COPY) {
149
14.8k
                memcpy(dst, buf, 4);
150
14.8k
                dst += 4;
151
14.8k
            }
152
129k
            len -= 4;
153
129k
            ADLER_DO4(adler, sum2, buf, 0);
154
129k
            buf += 4;
155
129k
        }
156
300M
        if (len & 2) {
157
1.12M
            if (COPY) {
158
17.1k
                memcpy(dst, buf, 2);
159
17.1k
                dst += 2;
160
17.1k
            }
161
1.12M
            ADLER_DO2(adler, sum2, buf, 0);
162
1.12M
            buf += 2;
163
1.12M
        }
164
300M
        if (len & 1) {
165
299M
            if (COPY)
166
297M
                *dst = *buf;
167
299M
            ADLER_DO1(adler, sum2, buf, 0);
168
299M
        }
169
300M
    }
170
300M
    if (REBASE) {
171
300M
        adler %= BASE;
172
300M
        sum2 %= BASE;
173
300M
    }
174
    /* D = B * 65536 + A, see: https://en.wikipedia.org/wiki/Adler-32. */
175
300M
    return adler | (sum2 << 16);
176
300M
}
Unexecuted instantiation: adler32_avx512.c:adler32_copy_tail
Unexecuted instantiation: adler32_avx512_vnni.c:adler32_copy_tail
Unexecuted instantiation: adler32_c.c:adler32_copy_tail
Unexecuted instantiation: adler32.c:adler32_copy_tail
177
178
#endif /* ADLER32_P_H */