annotate crc32-test.c @ 0:422835bc1aca

*: checkin
author Paper <paper@tflc.us>
date Mon, 09 Feb 2026 01:15:00 -0500
parents
children 90cb48b87dcc
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
1 #include "crc32i.h"
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
2 #include <stdio.h>
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
3
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
4 /* Test implementations and make sure they agree with each other */
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
5 int crc32_test(void)
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
6 {
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
7 /* Force alignment :) */
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
8 static const __attribute__((__aligned__(CRC32_MAX_ALIGNMENT))) unsigned char testdata[1024] =
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
9 #define DOUBLE(x) x x
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
10 DOUBLE(DOUBLE(DOUBLE(DOUBLE(DOUBLE(DOUBLE(DOUBLE("\x01\x02\x04\x08\x10\x20\x40\x80")))))))
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
11 #undef DOUBLE
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
12 ;
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
13 static const crc32_r_spec crc[] = {
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
14 crc32c_r,
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
15 crc32qw_r,
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
16 crc32x86_vpclmulqdq_r
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
17 };
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
18 size_t i;
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
19
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
20 uint32_t crcc = crc32(testdata, sizeof(testdata));
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
21
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
22 for (i = 0; i < ARRAY_SIZE(crc); i++) {
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
23 uint32_t thiscrc = ~crc[i](0xFFFFFFFF, testdata, sizeof(testdata));
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
24
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
25 if (thiscrc != crcc) {
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
26 fprintf(stderr, "%zu, mismatch: %08x, %08x\n", i, crcc, thiscrc);
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
27 return -1;
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
28 }
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
29 }
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
30
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
31 return 0;
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
32 }
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
33
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
34 int main(void)
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
35 {
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
36 return -crc32_test();
422835bc1aca *: checkin
Paper <paper@tflc.us>
parents:
diff changeset
37 }