gen_crc64table.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Generate lookup table for the table-driven CRC64 calculation.
  4. *
  5. * gen_crc64table is executed in kernel build time and generates
  6. * lib/crc64table.h. This header is included by lib/crc64.c for
  7. * the table-driven CRC64 calculation.
  8. *
  9. * See lib/crc64.c for more information about which specification
  10. * and polynomial arithmetic that gen_crc64table.c follows to
  11. * generate the lookup table.
  12. *
  13. * Copyright 2018 SUSE Linux.
  14. * Author: Coly Li <colyli@suse.de>
  15. */
  16. #include <inttypes.h>
  17. #include <stdio.h>
  18. #include <linux/swab.h>
  19. #define CRC64_ECMA182_POLY 0x42F0E1EBA9EA3693ULL
  20. static uint64_t crc64_table[256] = {0};
  21. static void generate_crc64_table(void)
  22. {
  23. uint64_t i, j, c, crc;
  24. for (i = 0; i < 256; i++) {
  25. crc = 0;
  26. c = i << 56;
  27. for (j = 0; j < 8; j++) {
  28. if ((crc ^ c) & 0x8000000000000000ULL)
  29. crc = (crc << 1) ^ CRC64_ECMA182_POLY;
  30. else
  31. crc <<= 1;
  32. c <<= 1;
  33. }
  34. crc64_table[i] = crc;
  35. }
  36. }
  37. static void print_crc64_table(void)
  38. {
  39. int i;
  40. printf("/* this file is generated - do not edit */\n\n");
  41. printf("#include <linux/types.h>\n");
  42. printf("#include <linux/cache.h>\n\n");
  43. printf("static const u64 ____cacheline_aligned crc64table[256] = {\n");
  44. for (i = 0; i < 256; i++) {
  45. printf("\t0x%016" PRIx64 "ULL", crc64_table[i]);
  46. if (i & 0x1)
  47. printf(",\n");
  48. else
  49. printf(", ");
  50. }
  51. printf("};\n");
  52. }
  53. int main(int argc, char *argv[])
  54. {
  55. generate_crc64_table();
  56. print_crc64_table();
  57. return 0;
  58. }