home *** CD-ROM | disk | FTP | other *** search
/ C/C++ Interactive Guide / c-cplusplus-interactive-guide.iso / c_ref / csource4 / 260_01 / rbsb.c < prev    next >
Encoding:
C/C++ Source or Header  |  1988-02-25  |  15.6 KB  |  449 lines

  1. /*
  2.  *
  3.  * -rev 01-01-87
  4.  *  This file contains Unix specific stuff for setting terminal modes,
  5.  *  very little is specific to ZMODEM or YMODEM per se (that stuff is in
  6.  *  sz.c and rz.c).  The CRC-16 routines used by XMODEM, YMODEM, and ZMODEM
  7.  *  are also in this file, an iterative version, and a fast table driven macro
  8.  *  version, selected by #define CRCTABLE
  9.  *
  10.  *   This file is #included so the main file can set parameters such as HOWMANY.
  11.  *   See the main files (rz.c/sz.c) for compile instructions.
  12.  */
  13.  
  14. #ifdef MSDOS
  15. #include <sys/types.h>
  16. #include <sys/stat.h>
  17. #include <tty.h>
  18. #define OS "MS-DOS"
  19. #endif
  20.  
  21. #ifdef V7
  22. #include <sys/types.h>
  23. #include <sys/stat.h>
  24. #include <sgtty.h>
  25. #define OS "V7/BSD"
  26. #endif
  27.  
  28. #ifndef OS
  29. #ifndef USG
  30. #define USG
  31. #endif
  32. #endif
  33.  
  34. #ifdef USG
  35. #include <sys/types.h>
  36. #include <sys/stat.h>
  37. #include <termio.h>
  38. #include <sys/ioctl.h>
  39. #define OS "SYS III/V"
  40. #endif
  41.  
  42. #if HOWMANY  > 255
  43. Howmany must be 255 or less
  44. #endif
  45.  
  46. struct
  47.    {
  48.    unsigned baudr;
  49.    int speedcode;
  50.    }
  51.    speeds[] =
  52.       {
  53.       110,    B110,
  54.       300,    B300,
  55.       600,    B600,
  56.       1200,   B1200,
  57.       2400,   B2400,
  58.       4800,   B4800,
  59.       9600,   B9600,
  60.       19200,  EXTA,
  61.       9600,   EXTB,
  62.       0,
  63.       };
  64.  
  65. int Twostop;            /* Use two stop bits */
  66.  
  67. unsigned getspeed(code)
  68. int code;
  69.    {
  70.    int n;
  71.  
  72.    for (n = 0; speeds[n].baudr; ++n)
  73. #ifndef MSDOS
  74.        if (speeds[n].speedcode == code)
  75.           return(speeds[n].baudr);
  76.    return(0);
  77. #else
  78.        if (speeds[n].baudr == code)
  79.           return(speeds[n].speedcode);
  80.    return(-1);
  81. #endif
  82.    }
  83.  
  84. #ifndef MSDOS
  85. #ifdef ICANON
  86. struct termio oldtty, tty;
  87. #else
  88. struct sgttyb oldtty, tty;
  89. struct tchars oldtch, tch;
  90. #endif
  91.  
  92. int iofd = 0;           /* File descriptor for ioctls & reads */
  93.  
  94. #else   /* MSDOS */
  95. int iofd = -1;
  96. int speed = B1200;
  97. char *port = "COM1";
  98. #endif
  99.  
  100. /*
  101. * mode(n)
  102. *  2: set a cbreak, XON/XOFF control mode if using Pro-YAM's -g option
  103. *  1: save old tty stat, set raw mode 
  104. *  0: restore original tty mode
  105. */
  106. mode(n)
  107.    {
  108.    static did0 = FALSE;
  109.  
  110.    vfile("mode:%d", n);
  111.    switch (n)
  112.       {
  113. #ifdef USG
  114.       case 2: /* Cbreak mode used by sb when -g detected */
  115.          if (!did0)
  116.             (void) ioctl(iofd, TCGETA, &oldtty);
  117.          tty = oldtty;
  118.  
  119.          tty.c_iflag = BRKINT|IXON;
  120.  
  121.          tty.c_oflag = 0;        /* Transparent output */
  122.  
  123.          tty.c_cflag &= ~PARENB; /* Disable parity */
  124.          tty.c_cflagc |= CS8;     /* Set character size = 8 */
  125.          if (Twostop)
  126.             tty.c_cflag |= CSTOPB;  /* Set two stop bits */
  127.  
  128. #ifdef XCLUDE
  129.          tty.c_lflag = XCLUDE | ISIG;
  130. #else
  131.          tty.c_lflag = ISIG;
  132. #endif
  133.  
  134.          tty.c_cc[VINTR] = Zmodem ? 03:030;      /* Interrupt char */
  135.          tty.c_cc[VMIN] = 1;
  136.  
  137.          (void) ioctl(iofd, TCSETAW, &tty);
  138.          did0 = TRUE;
  139.          return(OK);
  140.       case 1:
  141.          if (!did0)
  142.             (void) ioctl(iofd, TCGETA, &oldtty);
  143.          tty = oldtty;
  144.  
  145.          tty.c_iflag = IGNBRK;
  146.  
  147.          /* No echo, crlf mapping, INTR, QUIT, delays, no erase/kill */
  148.          tty.c_lflag &= ~(ECHO | ICANON | ISIG);
  149. #ifdef XCLUDE
  150.          tty.c_lflag |= XCLUDE;
  151. #endif
  152.  
  153.          tty.c_oflag = 0;        /* Transparent output */
  154.  
  155.          tty.c_cflag &= ~PARENB; /* Same baud rate, disable parity */
  156.          tty.c_cflag |= CS8;     /* Set character size = 8 */
  157.          if (Twostop)
  158.             tty.c_cflag |= CSTOPB;  /* Set two stop bits */
  159.          tty.c_cc[VMIN] = HOWMANY;  /* This many chars satisfies reads */
  160.          tty.c_cc[VTIME] = 1;       /* or in this many tenths of seconds */
  161.          (void) ioctl(iofd, TCSETAW, &tty);
  162.          did0 = TRUE;
  163.          Baudrate = getspeed(tty.c_cflag & CBAUD);
  164.          return(OK);
  165. #endif
  166. #ifdef V7
  167.       case 2: /*  This doesn't work ... */
  168.          printf("No mode(2) in V7/BSD!");
  169.          bibi(99);
  170.          if (!did0)
  171.             {
  172.             ioctl(iofd, TIOCEXCL, 0);
  173.             ioctl(iofd, TIOCGETP, &oldtty);
  174.             ioctl(iofd, TIOCGETC, &oldtch);
  175.             }
  176.          tty = oldtty;
  177.          tch = oldtch;
  178.          tch.t_intrc = Zmodem ? 03:030;  /* Interrupt char */
  179.          tty.sg_flags |= (ODDP|EVENP|CBREAK);
  180.          tty.sg_flags &= ~(ALLDELAY|CRMOD|ECHO|LCASE);
  181.          ioctl(iofd, TIOCSETP, &tty);
  182.          ioctl(iofd, TIOCSETC, &tch);
  183.          did0 = TRUE;
  184.          return(OK);
  185.       case 1:
  186.          if (!did0)
  187.             {
  188.             ioctl(iofd, TIOCEXCL, 0);
  189.             ioctl(iofd, TIOCGETP, &oldtty);
  190.             ioctl(iofd, TIOCGETC, &oldtch);
  191.             }
  192.          tty = oldtty;
  193.          tty.sg_flags |= RAW;
  194.          tty.sg_flags &= ~ECHO;
  195.          ioctl(iofd, TIOCSETP, &tty);
  196.          did0 = TRUE;
  197.          Baudrate = getspeed(tty.sg_ospeed);
  198.          return(OK);
  199. #endif
  200. #ifdef MSDOS
  201.       case 2: /*  This doesn't work ... */
  202.          printf("No mode(2) in MSDOS");
  203.          bibi(99);
  204.       case 1:
  205.          if (!did0)
  206.             iofd = tty_open(port, speed | CS8);
  207.          did0 = TRUE;
  208.          return(OK);
  209. #endif
  210.       case 0:
  211.          if (!did0)
  212.             return(ERROR);
  213. #ifdef USG
  214.          (void) ioctl(iofd, TCSBRK, 1);          /* Wait for output to drain */
  215.          (void) ioctl(iofd, TCFLSH, 1);          /* Flush input queue */
  216.          (void) ioctl(iofd, TCSETAW, &oldtty);   /* Restore original modes */
  217.          (void) ioctl(iofd, TCXONC,1);           /* Restart output */
  218. #endif
  219. #ifdef V7
  220.          ioctl(iofd, TIOCSETP, &oldtty);
  221.          ioctl(iofd, TIOCSETC, &oldtch);
  222.          ioctl(iofd, TIOCNXCL, 0);
  223. #endif
  224. #ifdef MSDOS
  225.          tty_close(iofd);
  226. #endif
  227.          return(OK);
  228.       default:
  229.          return(ERROR);
  230.       }
  231.    }
  232.  
  233. sendbrk()
  234.    {
  235. #ifdef V7
  236. #ifdef TIOCSBRK
  237. #define CANBREAK
  238.    sleep(1);
  239.    ioctl(iofd, TIOCSBRK, 0);
  240.    sleep(1);
  241.    ioctl(iofd, TIOCCBRK, 0);
  242. #endif
  243. #endif
  244. #ifdef USG
  245. #define CANBREAK
  246.    ioctl(iofd, TCSBRK, 0);
  247. #endif
  248. #ifdef MSDOS
  249. #define CANBREAK
  250.    _combrk(iofd);
  251. #endif
  252.    }
  253.  
  254. #ifdef FIONREAD
  255. #define READCHECK
  256. /*
  257. *  Return non 0 iff something to read from io descriptor f
  258. */
  259. rdchk(f)
  260.    {
  261.    static long lf;
  262.  
  263.    ioctl(f, FIONREAD, &lf);
  264.    return ((int) lf);
  265.    }
  266. #endif
  267. #ifdef SVR2
  268. #define READCHECK
  269. #include <fcntl.h>
  270.  
  271. char checked = '\0' ;
  272. /*
  273. * Nonblocking I/O is a bit different in System V, Release 2
  274. */
  275. rdchk(f)
  276.    {
  277.    int lf, savestat = fcntl(f, F_GETFL) ;
  278.  
  279.    fcntl(f, F_SETFL, savestat | O_NDELAY) ;
  280.    lf = read(f, &checked, 1) ;
  281.    fcntl(f, F_SETFL, savestat) ;
  282.    return(lf) ;
  283.    }
  284. #endif
  285.  
  286.  
  287. #ifdef CRCTABLE
  288. /* crctab calculated by Mark G. Mendel, Network Systems Corporation */
  289. static unsigned short crctab[256] =
  290. {
  291. 0x0000,  0x1021,  0x2042,  0x3063,  0x4084,  0x50a5,  0x60c6,  0x70e7,
  292. 0x8108,  0x9129,  0xa14a,  0xb16b,  0xc18c,  0xd1ad,  0xe1ce,  0xf1ef,
  293. 0x1231,  0x0210,  0x3273,  0x2252,  0x52b5,  0x4294,  0x72f7,  0x62d6,
  294. 0x9339,  0x8318,  0xb37b,  0xa35a,  0xd3bd,  0xc39c,  0xf3ff,  0xe3de,
  295. 0x2462,  0x3443,  0x0420,  0x1401,  0x64e6,  0x74c7,  0x44a4,  0x5485,
  296. 0xa56a,  0xb54b,  0x8528,  0x9509,  0xe5ee,  0xf5cf,  0xc5ac,  0xd58d,
  297. 0x3653,  0x2672,  0x1611,  0x0630,  0x76d7,  0x66f6,  0x5695,  0x46b4,
  298. 0xb75b,  0xa77a,  0x9719,  0x8738,  0xf7df,  0xe7fe,  0xd79d,  0xc7bc,
  299. 0x48c4,  0x58e5,  0x6886,  0x78a7,  0x0840,  0x1861,  0x2802,  0x3823,
  300. 0xc9cc,  0xd9ed,  0xe98e,  0xf9af,  0x8948,  0x9969,  0xa90a,  0xb92b,
  301. 0x5af5,  0x4ad4,  0x7ab7,  0x6a96,  0x1a71,  0x0a50,  0x3a33,  0x2a12,
  302. 0xdbfd,  0xcbdc,  0xfbbf,  0xeb9e,  0x9b79,  0x8b58,  0xbb3b,  0xab1a,
  303. 0x6ca6,  0x7c87,  0x4ce4,  0x5cc5,  0x2c22,  0x3c03,  0x0c60,  0x1c41,
  304. 0xedae,  0xfd8f,  0xcdec,  0xddcd,  0xad2a,  0xbd0b,  0x8d68,  0x9d49,
  305. 0x7e97,  0x6eb6,  0x5ed5,  0x4ef4,  0x3e13,  0x2e32,  0x1e51,  0x0e70,
  306. 0xff9f,  0xefbe,  0xdfdd,  0xcffc,  0xbf1b,  0xaf3a,  0x9f59,  0x8f78,
  307. 0x9188,  0x81a9,  0xb1ca,  0xa1eb,  0xd10c,  0xc12d,  0xf14e,  0xe16f,
  308. 0x1080,  0x00a1,  0x30c2,  0x20e3,  0x5004,  0x4025,  0x7046,  0x6067,
  309. 0x83b9,  0x9398,  0xa3fb,  0xb3da,  0xc33d,  0xd31c,  0xe37f,  0xf35e,
  310. 0x02b1,  0x1290,  0x22f3,  0x32d2,  0x4235,  0x5214,  0x6277,  0x7256,
  311. 0xb5ea,  0xa5cb,  0x95a8,  0x8589,  0xf56e,  0xe54f,  0xd52c,  0xc50d,
  312. 0x34e2,  0x24c3,  0x14a0,  0x0481,  0x7466,  0x6447,  0x5424,  0x4405,
  313. 0xa7db,  0xb7fa,  0x8799,  0x97b8,  0xe75f,  0xf77e,  0xc71d,  0xd73c,
  314. 0x26d3,  0x36f2,  0x0691,  0x16b0,  0x6657,  0x7676,  0x4615,  0x5634,
  315. 0xd94c,  0xc96d,  0xf90e,  0xe92f,  0x99c8,  0x89e9,  0xb98a,  0xa9ab,
  316. 0x5844,  0x4865,  0x7806,  0x6827,  0x18c0,  0x08e1,  0x3882,  0x28a3,
  317. 0xcb7d,  0xdb5c,  0xeb3f,  0xfb1e,  0x8bf9,  0x9bd8,  0xabbb,  0xbb9a,
  318. 0x4a75,  0x5a54,  0x6a37,  0x7a16,  0x0af1,  0x1ad0,  0x2ab3,  0x3a92,
  319. 0xfd2e,  0xed0f,  0xdd6c,  0xcd4d,  0xbdaa,  0xad8b,  0x9de8,  0x8dc9,
  320. 0x7c26,  0x6c07,  0x5c64,  0x4c45,  0x3ca2,  0x2c83,  0x1ce0,  0x0cc1,
  321. 0xef1f,  0xff3e,  0xcf5d,  0xdf7c,  0xaf9b,  0xbfba,  0x8fd9,  0x9ff8,
  322. 0x6e17,  0x7e36,  0x4e55,  0x5e74,  0x2e93,  0x3eb2,  0x0ed1,  0x1ef0
  323. };
  324.  
  325. /*
  326. * updcrc macro derived from article Copyright (C) 1986 Stephen Satchell. 
  327. *  NOTE: First srgument must be in range 0 to 255.
  328. *        Second argument is referenced twice.
  329. * Programmers may incorporate any or all code into their programs, 
  330. * giving proper credit within the source. Publication of the 
  331. * source routines is permitted so long as proper credit is given 
  332. * to Stephen Satchell, Satchell Evaluations and Chuck Forsberg, 
  333. * Omen Technology.
  334. */
  335.  
  336. #define updcrc(cp, crc) ( crctab[((crc >> 8) & 255)] ^ (crc << 8) ^ cp)
  337.  
  338. #else
  339.  
  340. unsigned short updcrc();
  341.  
  342. /* update CRC */
  343. unsigned short
  344. updcrc(c, crc)
  345. int c;
  346. unsigned crc;
  347.    {
  348.    int count;
  349.  
  350.    for (count=8; --count>=0;)
  351.       {
  352.       if (crc & 0x8000)
  353.          {
  354.          crc <<= 1;
  355.          crc += (((c<<=1) & 0400)  !=  0);
  356.          crc ^= 0x1021;
  357.          }
  358.       else
  359.          {
  360.          crc <<= 1;
  361.          crc += (((c<<=1) & 0400)  !=  0);
  362.          }
  363.       }
  364.    return(crc);     
  365.    }
  366. #endif
  367.  
  368. /*
  369. * Copyright (C) 1986 Gary S. Brown.  You may use this program, or
  370. * code or tables extracted from it, as desired without restriction.
  371. *
  372. *   Need an unsigned type capable of holding 32 bits;
  373. */
  374. typedef unsigned long int UNS_32_BITS;
  375.  
  376. /* First, the polynomial itself and its table of feedback terms.  The  */
  377. /* polynomial is                                                       */
  378. /* X^32+X^26+X^23+X^22+X^16+X^12+X^11+X^10+X^8+X^7+X^5+X^4+X^2+X^1+X^0 */
  379. /* Note that we take it "backwards" and put the highest-order term in  */
  380. /* the lowest-order bit.  The X^32 term is "implied"; the LSB is the   */
  381. /* X^31 term, etc.  The X^0 term (usually shown as "+1") results in    */
  382. /* the MSB being 1.                                                    */
  383.  
  384. /* Note that the usual hardware shift register implementation, which   */
  385. /* is what we're using (we're merely optimizing it by doing eight-bit  */
  386. /* chunks at a time) shifts bits into the lowest-order term.  In our   */
  387. /* implementation, that means shifting towards the right.  Why do we   */
  388. /* do it this way?  Because the calculated CRC must be transmitted in  */
  389. /* order from highest-order term to lowest-order term.  UARTs transmit */
  390. /* characters in order from LSB to MSB.  By storing the CRC this way,  */
  391. /* we hand it to the UART in the order low-byte to high-byte; the UART */
  392. /* sends each low-bit to hight-bit; and the result is transmission bit */
  393. /* by bit from highest- to lowest-order term without requiring any bit */
  394. /* shuffling on our part.  Reception works similarly.                  */
  395.  
  396. /* The feedback terms table consists of 256, 32-bit entries.  Notes:   */
  397. /*                                                                     */
  398. /*     The table can be generated at runtime if desired; code to do so */
  399. /*     is shown later.  It might not be obvious, but the feedback      */
  400. /*     terms simply represent the results of eight shift/xor opera-    */
  401. /*     tions for all combinations of data and CRC register values.     */
  402. /*                                                                     */
  403. /*     The values must be right-shifted by eight bits by the "updcrc"  */
  404. /*     logic; the shift must be unsigned (bring in zeroes).  On some   */
  405. /*     hardware you could probably optimize the shift in assembler by  */
  406. /*     using byte-swap instructions.                                   */
  407.  
  408. static UNS_32_BITS crc_32_tab[] =
  409. {
  410.    /* CRC polynomial 0xedb88320 */
  411. 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f, 0xe963a535, 0x9e6495a3,
  412. 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988, 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91,
  413. 0x1db71064, 0x6ab020f2, 0xf3b97148, 0x84be41de, 0x1adad47d, 0x6ddde4eb, 0xf4d4b551, 0x83d385c7,
  414. 0x136c9856, 0x646ba8c0, 0xfd62f97a, 0x8a65c9ec, 0x14015c4f, 0x63066cd9, 0xfa0f3d63, 0x8d080df5,
  415. 0x3b6e20c8, 0x4c69105e, 0xd56041e4, 0xa2677172, 0x3c03e4d1, 0x4b04d447, 0xd20d85fd, 0xa50ab56b,
  416. 0x35b5a8fa, 0x42b2986c, 0xdbbbc9d6, 0xacbcf940, 0x32d86ce3, 0x45df5c75, 0xdcd60dcf, 0xabd13d59,
  417. 0x26d930ac, 0x51de003a, 0xc8d75180, 0xbfd06116, 0x21b4f4b5, 0x56b3c423, 0xcfba9599, 0xb8bda50f,
  418. 0x2802b89e, 0x5f058808, 0xc60cd9b2, 0xb10be924, 0x2f6f7c87, 0x58684c11, 0xc1611dab, 0xb6662d3d,
  419. 0x76dc4190, 0x01db7106, 0x98d220bc, 0xefd5102a, 0x71b18589, 0x06b6b51f, 0x9fbfe4a5, 0xe8b8d433,
  420. 0x7807c9a2, 0x0f00f934, 0x9609a88e, 0xe10e9818, 0x7f6a0dbb, 0x086d3d2d, 0x91646c97, 0xe6635c01,
  421. 0x6b6b51f4, 0x1c6c6162, 0x856530d8, 0xf262004e, 0x6c0695ed, 0x1b01a57b, 0x8208f4c1, 0xf50fc457,
  422. 0x65b0d9c6, 0x12b7e950, 0x8bbeb8ea, 0xfcb9887c, 0x62dd1ddf, 0x15da2d49, 0x8cd37cf3, 0xfbd44c65,
  423. 0x4db26158, 0x3ab551ce, 0xa3bc0074, 0xd4bb30e2, 0x4adfa541, 0x3dd895d7, 0xa4d1c46d, 0xd3d6f4fb,
  424. 0x4369e96a, 0x346ed9fc, 0xad678846, 0xda60b8d0, 0x44042d73, 0x33031de5, 0xaa0a4c5f, 0xdd0d7cc9,
  425. 0x5005713c, 0x270241aa, 0xbe0b1010, 0xc90c2086, 0x5768b525, 0x206f85b3, 0xb966d409, 0xce61e49f,
  426. 0x5edef90e, 0x29d9c998, 0xb0d09822, 0xc7d7a8b4, 0x59b33d17, 0x2eb40d81, 0xb7bd5c3b, 0xc0ba6cad,
  427. 0xedb88320, 0x9abfb3b6, 0x03b6e20c, 0x74b1d29a, 0xead54739, 0x9dd277af, 0x04db2615, 0x73dc1683,
  428. 0xe3630b12, 0x94643b84, 0x0d6d6a3e, 0x7a6a5aa8, 0xe40ecf0b, 0x9309ff9d, 0x0a00ae27, 0x7d079eb1,
  429. 0xf00f9344, 0x8708a3d2, 0x1e01f268, 0x6906c2fe, 0xf762575d, 0x806567cb, 0x196c3671, 0x6e6b06e7,
  430. 0xfed41b76, 0x89d32be0, 0x10da7a5a, 0x67dd4acc, 0xf9b9df6f, 0x8ebeeff9, 0x17b7be43, 0x60b08ed5,
  431. 0xd6d6a3e8, 0xa1d1937e, 0x38d8c2c4, 0x4fdff252, 0xd1bb67f1, 0xa6bc5767, 0x3fb506dd, 0x48b2364b,
  432. 0xd80d2bda, 0xaf0a1b4c, 0x36034af6, 0x41047a60, 0xdf60efc3, 0xa867df55, 0x316e8eef, 0x4669be79,
  433. 0xcb61b38c, 0xbc66831a, 0x256fd2a0, 0x5268e236, 0xcc0c7795, 0xbb0b4703, 0x220216b9, 0x5505262f,
  434. 0xc5ba3bbe, 0xb2bd0b28, 0x2bb45a92, 0x5cb36a04, 0xc2d7ffa7, 0xb5d0cf31, 0x2cd99e8b, 0x5bdeae1d,
  435. 0x9b64c2b0, 0xec63f226, 0x756aa39c, 0x026d930a, 0x9c0906a9, 0xeb0e363f, 0x72076785, 0x05005713,
  436. 0x95bf4a82, 0xe2b87a14, 0x7bb12bae, 0x0cb61b38, 0x92d28e9b, 0xe5d5be0d, 0x7cdcefb7, 0x0bdbdf21,
  437. 0x86d3d2d4, 0xf1d4e242, 0x68ddb3f8, 0x1fda836e, 0x81be16cd, 0xf6b9265b, 0x6fb077e1, 0x18b74777,
  438. 0x88085ae6, 0xff0f6a70, 0x66063bca, 0x11010b5c, 0x8f659eff, 0xf862ae69, 0x616bffd3, 0x166ccf45,
  439. 0xa00ae278, 0xd70dd2ee, 0x4e048354, 0x3903b3c2, 0xa7672661, 0xd06016f7, 0x4969474d, 0x3e6e77db,
  440. 0xaed16a4a, 0xd9d65adc, 0x40df0b66, 0x37d83bf0, 0xa9bcae53, 0xdebb9ec5, 0x47b2cf7f, 0x30b5ffe9,
  441. 0xbdbdf21c, 0xcabac28a, 0x53b39330, 0x24b4a3a6, 0xbad03605, 0xcdd70693, 0x54de5729, 0x23d967bf,
  442. 0xb3667a2e, 0xc4614ab8, 0x5d681b02, 0x2a6f2b94, 0xb40bbe37, 0xc30c8ea1, 0x5a05df1b, 0x2d02ef8d
  443. };
  444.  
  445. #define UPDC32(octet, crc) (crc_32_tab[((crc) ^ (octet)) & 0xff] ^ ((crc) >> 8))
  446.  
  447. /* End of rbsb.c */
  448.