The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/lib/gen_crc32table.c

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 #include <stdio.h>
    2 #include "crc32defs.h"
    3 #include <sys/types.h>
    4 
    5 #define ENTRIES_PER_LINE 4
    6 
    7 #define LE_TABLE_SIZE (1 << CRC_LE_BITS)
    8 #define BE_TABLE_SIZE (1 << CRC_BE_BITS)
    9 
   10 static u_int32_t crc32table_le[LE_TABLE_SIZE];
   11 static u_int32_t crc32table_be[BE_TABLE_SIZE];
   12 
   13 /**
   14  * crc32init_le() - allocate and initialize LE table data
   15  *
   16  * crc is the crc of the byte i; other entries are filled in based on the
   17  * fact that crctable[i^j] = crctable[i] ^ crctable[j].
   18  *
   19  */
   20 static void crc32init_le(void)
   21 {
   22         unsigned i, j;
   23         u_int32_t crc = 1;
   24 
   25         crc32table_le[0] = 0;
   26 
   27         for (i = 1 << (CRC_LE_BITS - 1); i; i >>= 1) {
   28                 crc = (crc >> 1) ^ ((crc & 1) ? CRCPOLY_LE : 0);
   29                 for (j = 0; j < LE_TABLE_SIZE; j += 2 * i)
   30                         crc32table_le[i + j] = crc ^ crc32table_le[j];
   31         }
   32 }
   33 
   34 /**
   35  * crc32init_be() - allocate and initialize BE table data
   36  */
   37 static void crc32init_be(void)
   38 {
   39         unsigned i, j;
   40         u_int32_t crc = 0x80000000;
   41 
   42         crc32table_be[0] = 0;
   43 
   44         for (i = 1; i < BE_TABLE_SIZE; i <<= 1) {
   45                 crc = (crc << 1) ^ ((crc & 0x80000000) ? CRCPOLY_BE : 0);
   46                 for (j = 0; j < i; j++)
   47                         crc32table_be[i + j] = crc ^ crc32table_be[j];
   48         }
   49 }
   50 
   51 static void output_table(u_int32_t table[], int len, char *trans)
   52 {
   53         int i;
   54 
   55         for (i = 0; i < len - 1; i++) {
   56                 if (i % ENTRIES_PER_LINE == 0)
   57                         printf("\n");
   58                 printf("%s(0x%8.8xL), ", trans, table[i]);
   59         }
   60         printf("%s(0x%8.8xL)\n", trans, table[len - 1]);
   61 }
   62 
   63 int main(int argc, char** argv)
   64 {
   65         printf("/* this file is generated - do not edit */\n\n");
   66 
   67         if (CRC_LE_BITS > 1) {
   68                 crc32init_le();
   69                 printf("static const u32 crc32table_le[] = {");
   70                 output_table(crc32table_le, LE_TABLE_SIZE, "tole");
   71                 printf("};\n");
   72         }
   73 
   74         if (CRC_BE_BITS > 1) {
   75                 crc32init_be();
   76                 printf("static const u32 crc32table_be[] = {");
   77                 output_table(crc32table_be, BE_TABLE_SIZE, "tobe");
   78                 printf("};\n");
   79         }
   80 
   81         return 0;
   82 }

Cache object: 534332ce74f76766f81cd85dadc89b41


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.