home *** CD-ROM | disk | FTP | other *** search
/ High Voltage Shareware / high1.zip / high1 / DIR3 / KA9Q212.ZIP / RBSB.C < prev    next >
C/C++ Source or Header  |  1993-07-16  |  17KB  |  448 lines

  1. /****************************************************************************
  2. *    Language     :    Turbo C 2.0                                                *
  3. *    Logfile        :    rbsb.c                                                    *
  4. *    Project        :    Comms library.                                            *
  5. *    Date         :    25 Jan 90                                                *
  6. *    Revision     :    1.1        GT    PC version.                                    *
  7. *    25 Oct 92    :    1.2        GT    KA9Q mods.                                    *
  8. *    30 Jan 93    :    1.3        GT    Fix KA9Q background operation.                *
  9. *    20 Feb 93    :    1.4        GT    Buffer sends locally.                        *
  10. *    20 Feb 93    :    1.5        GT    Fix return value in send_zbuf ().            *
  11. *    21 Feb 93    :    1.6        GT    Allocate send buffer from heap.                *
  12. *    08 May 93    :    1.7        GT    Fix warnings.                                *
  13. *****************************************************************************
  14. *    Purpose        :    Terminal mode and CRC code.                                *
  15. *****************************************************************************
  16. *                :    This module is based on the equivalent module in the    *
  17. *                :    31 Aug 87 version of rz/sz.                                *
  18. *    $Id: rbsb.c 1.6 93/07/16 11:49:32 ROOT_DOS Exp $
  19. ****************************************************************************/
  20.  
  21. /*
  22.  *
  23.  * -rev 04-16-87
  24.  *  This file contains Unix specific code for setting terminal modes,
  25.  *  very little is specific to ZMODEM or YMODEM per se (that code is in
  26.  *  sz.c and rz.c).  The CRC-16 routines used by XMODEM, YMODEM, and ZMODEM
  27.  *  are also in this file, a fast table driven macro version
  28.  *
  29.  *   This file is #included so the main file can set parameters such as HOWMANY.
  30.  *   See the main files (rz.c/sz.c) for compile instructions.
  31.  */
  32.  
  33. #include    <stdio.h>
  34. #include    <string.h>
  35. #include    "rbsb.h"
  36. #include    "session.h"
  37. #include    "socket.h"
  38. #include    "usock.h"
  39. #include    "mbuf.h"
  40. #include    "proc.h"
  41. #include    "global.h"
  42.  
  43. static int send_zbuf (void);
  44.  
  45. #define    SENDSIZE    (BUFSIZ * 4)
  46.  
  47. int _z_socket;                        /* socket                                */
  48. #if    0
  49. static unsigned char sbuf[SENDSIZE];    /* send buffer                        */
  50. #endif
  51. static unsigned char *sbuf = 0;        /* -> send buffer                        */
  52. static size_t buflen = 0;            /* send buffer size                        */
  53. static unsigned char *bufptr;        /* -> send buffer                    */
  54.  
  55.  
  56. /****************************************************************************
  57. *    sndbrk                                                                    *
  58. *    Send break to the modem.                                                *
  59. ****************************************************************************/
  60.  
  61. void _sendbrk (void)
  62.     {
  63.     /* does nothing */
  64.     }    /* void _sendbrk (void) */
  65.  
  66.  
  67. /****************************************************************************
  68. *    _rdchk                                                                    *
  69. *    Returns nz if something to read from remote.                            *
  70. ****************************************************************************/
  71.  
  72. int _rdchk (void)
  73.     {
  74.     int rc;
  75.  
  76.     rc = socklen (_z_socket, 0);
  77.     if (rc < 0)
  78.         rc = 0;
  79.  
  80.     if (rc == 0)
  81.         pwait (0);                    /* let others run                    */
  82.  
  83. #if    0        
  84.     usflush (_z_socket);
  85. #endif
  86.     return (rc);
  87.     }    /* int _rdchk (void) */
  88.  
  89. /****************************************************************************
  90. *    _send                                                                    *
  91. *    Send some data to the remote.                                            *
  92. ****************************************************************************/
  93.  
  94. int _send (unsigned char *buf, int len)
  95.     {
  96. #if    0
  97.     int rc;                                /* result code                        */
  98.     int count;                            /* byte counter                        */
  99.     int oldmode;                         /* old socket mode                    */
  100.     int oldflush;                         /* old flush character                */
  101. #endif
  102.  
  103.     if (sbuf == 0)
  104.         {
  105.         sbuf = mallocw (SENDSIZE);
  106.         bufptr = sbuf;
  107.         buflen = 0;
  108.         }
  109.         
  110.     if (len + buflen > SENDSIZE)
  111.         {
  112.         if (send_zbuf () < 0)
  113.             return (0);
  114.  
  115.         }
  116.  
  117.     (void) memcpy (bufptr, buf, len);
  118.     bufptr += len;
  119.     buflen += len;
  120.     return (len);
  121.     
  122. #if    0
  123.     count = 0;
  124.     oldmode = sockmode (_z_socket, SOCK_BINARY);
  125.     oldflush = setflush (_z_socket, -1);
  126.     while (len > 0)
  127.         {
  128.         rc = send (_z_socket, buf, len, 0);
  129.         if (rc < 0)
  130.             break;
  131.  
  132.         len -= rc;
  133.         buf += rc;
  134.         count += rc;
  135.         if (count != len)
  136.             pwait (0);
  137.             
  138.         }
  139.  
  140. #if    0
  141.     if (rc >= 0)        
  142.         usflush (_z_socket);
  143. #endif
  144.     
  145.     (void) setflush (_z_socket, oldflush);
  146.     (void) sockmode (_z_socket, oldmode);
  147.     return (count);
  148. #endif
  149.     }    /* int _send (unsigned char *buf, int len) */
  150.  
  151.  
  152. /****************************************************************************
  153. *    _flush                                                                    *
  154. *    Flush output.                                                            *
  155. ****************************************************************************/
  156.  
  157. void _flush (void)
  158.     {
  159.     if (send_zbuf () > 0)
  160.         usflush (_z_socket);
  161.         
  162.     }    /* void _flush (void) */
  163.  
  164.     
  165. /****************************************************************************
  166. *    send_zbuf                                                                *
  167. *    Sends the send buffer to the remote.                                    *
  168. ****************************************************************************/
  169.  
  170. static int send_zbuf (void)
  171.     {
  172.     int rc;                                /* return value                        */
  173. #if    0
  174.     int count;                            /* byte counter                        */
  175. #endif
  176.     int oldmode;                         /* old socket mode                    */
  177.     int oldflush;                         /* old flush character                */
  178.     struct mbuf *bp;                    /* -> mbuf                            */
  179.  
  180.     if (sbuf == 0)
  181.         return (0);
  182.         
  183.     oldmode = sockmode (_z_socket, SOCK_BINARY);
  184.     oldflush = setflush (_z_socket, -1);
  185.     bp = ambufw (SENDSIZE);
  186.     bp->cnt = buflen;
  187.     (void) memcpy (bp->data, sbuf, buflen);
  188. #if    0
  189.     _vfile ("Calling send_mbuf (), count = %d, sbuf = %p\n", bp->cnt, sbuf);
  190. #endif
  191.     rc = send_mbuf (_z_socket, bp, 0, NULLCHAR, 0);
  192. #if    0
  193.     _vfile ("Back from send_mbuf (), rc = %d\n", rc);
  194. #endif
  195.     if (rc < 0)
  196.         rc = 0;
  197.     else
  198.         {
  199.         bufptr = sbuf;
  200.         buflen = 0;
  201.         }
  202.  
  203.     (void) setflush (_z_socket, oldflush);
  204.     (void) sockmode (_z_socket, oldmode);
  205.     return (rc);
  206.     }    /* static int send_zbuf (void) */
  207.     
  208.  
  209. /****************************************************************************
  210. *    _receive                                                                *
  211. *    Receive some data from the remote.                                        *
  212. ****************************************************************************/
  213.  
  214. int _receive (unsigned char *buf, int len)
  215.     {
  216.     int rc;
  217.     int oldmode;                         /* old socket mode                    */
  218.     int oldflush;                         /* old flush character                */
  219. #if    0
  220.     static char rcv_buf[1024];            /* receive buffer                    */
  221.     static char *p;                        /* -> receive buffer                */
  222.     static unsigned count = 0;            /* number of bytes in receive buf    */
  223.     struct mbuf *bp;                    /* -> mbuf                            */
  224. #endif
  225.  
  226.     oldmode = sockmode (_z_socket, SOCK_BINARY);
  227.     oldflush = setflush (_z_socket, -1);
  228.     rc = recv (_z_socket, (char *) buf, len, 0);
  229.     (void) setflush (_z_socket, oldflush);
  230.     (void) sockmode (_z_socket, oldmode);
  231.     if (rc < 0)
  232.         rc = 0;
  233.  
  234. #if    0
  235.     /* Do we have any data? */
  236.  
  237.     if (count == 0)
  238.         {
  239.         oldmode = sockmode (_z_socket, SOCK_BINARY);
  240.         oldflush = setflush (_z_socket, -1);
  241.         rc = recv_mbuf (_z_socket, &bp, 0, NULLCHAR, 0);
  242.         if (rc == -1)
  243.             count = -1;
  244.  
  245.         (void) setflush (_z_socket, oldflush);
  246.         (void) sockmode (_z_socket, oldmode);
  247.         if (rc <= 0)
  248.             {
  249.             count = 0;
  250.             return (0);
  251.             }
  252.  
  253.         count = dqdata (bp, rcv_buf, sizeof (rcv_buf));        
  254.         p = rcv_buf;
  255.         }
  256.  
  257.     if (count >= len)
  258.         {
  259.         (void) memcpy (buf, p, len);
  260.         count -= len;
  261.         p += len;
  262.         return (len);
  263.         }
  264.  
  265.     /* Can't give all that was asked for. */
  266.  
  267.     (void) memcpy (buf, p, count);
  268.     rc = count;
  269.     count = 0;
  270. #endif
  271.  
  272.     return (rc);
  273.     }    /* int _receive (unsigned char *buf, int len) */
  274.  
  275.  
  276. /* _crctab calculated by Mark G. Mendel, Network Systems Corporation */
  277.  
  278. unsigned short _crctab[256] =
  279.     {
  280.     0x0000,  0x1021,  0x2042,  0x3063,  0x4084,  0x50a5,  0x60c6,  0x70e7,
  281.     0x8108,  0x9129,  0xa14a,  0xb16b,  0xc18c,  0xd1ad,  0xe1ce,  0xf1ef,
  282.     0x1231,  0x0210,  0x3273,  0x2252,  0x52b5,  0x4294,  0x72f7,  0x62d6,
  283.     0x9339,  0x8318,  0xb37b,  0xa35a,  0xd3bd,  0xc39c,  0xf3ff,  0xe3de,
  284.     0x2462,  0x3443,  0x0420,  0x1401,  0x64e6,  0x74c7,  0x44a4,  0x5485,
  285.     0xa56a,  0xb54b,  0x8528,  0x9509,  0xe5ee,  0xf5cf,  0xc5ac,  0xd58d,
  286.     0x3653,  0x2672,  0x1611,  0x0630,  0x76d7,  0x66f6,  0x5695,  0x46b4,
  287.     0xb75b,  0xa77a,  0x9719,  0x8738,  0xf7df,  0xe7fe,  0xd79d,  0xc7bc,
  288.     0x48c4,  0x58e5,  0x6886,  0x78a7,  0x0840,  0x1861,  0x2802,  0x3823,
  289.     0xc9cc,  0xd9ed,  0xe98e,  0xf9af,  0x8948,  0x9969,  0xa90a,  0xb92b,
  290.     0x5af5,  0x4ad4,  0x7ab7,  0x6a96,  0x1a71,  0x0a50,  0x3a33,  0x2a12,
  291.     0xdbfd,  0xcbdc,  0xfbbf,  0xeb9e,  0x9b79,  0x8b58,  0xbb3b,  0xab1a,
  292.     0x6ca6,  0x7c87,  0x4ce4,  0x5cc5,  0x2c22,  0x3c03,  0x0c60,  0x1c41,
  293.     0xedae,  0xfd8f,  0xcdec,  0xddcd,  0xad2a,  0xbd0b,  0x8d68,  0x9d49,
  294.     0x7e97,  0x6eb6,  0x5ed5,  0x4ef4,  0x3e13,  0x2e32,  0x1e51,  0x0e70,
  295.     0xff9f,  0xefbe,  0xdfdd,  0xcffc,  0xbf1b,  0xaf3a,  0x9f59,  0x8f78,
  296.     0x9188,  0x81a9,  0xb1ca,  0xa1eb,  0xd10c,  0xc12d,  0xf14e,  0xe16f,
  297.     0x1080,  0x00a1,  0x30c2,  0x20e3,  0x5004,  0x4025,  0x7046,  0x6067,
  298.     0x83b9,  0x9398,  0xa3fb,  0xb3da,  0xc33d,  0xd31c,  0xe37f,  0xf35e,
  299.     0x02b1,  0x1290,  0x22f3,  0x32d2,  0x4235,  0x5214,  0x6277,  0x7256,
  300.     0xb5ea,  0xa5cb,  0x95a8,  0x8589,  0xf56e,  0xe54f,  0xd52c,  0xc50d,
  301.     0x34e2,  0x24c3,  0x14a0,  0x0481,  0x7466,  0x6447,  0x5424,  0x4405,
  302.     0xa7db,  0xb7fa,  0x8799,  0x97b8,  0xe75f,  0xf77e,  0xc71d,  0xd73c,
  303.     0x26d3,  0x36f2,  0x0691,  0x16b0,  0x6657,  0x7676,  0x4615,  0x5634,
  304.     0xd94c,  0xc96d,  0xf90e,  0xe92f,  0x99c8,  0x89e9,  0xb98a,  0xa9ab,
  305.     0x5844,  0x4865,  0x7806,  0x6827,  0x18c0,  0x08e1,  0x3882,  0x28a3,
  306.     0xcb7d,  0xdb5c,  0xeb3f,  0xfb1e,  0x8bf9,  0x9bd8,  0xabbb,  0xbb9a,
  307.     0x4a75,  0x5a54,  0x6a37,  0x7a16,  0x0af1,  0x1ad0,  0x2ab3,  0x3a92,
  308.     0xfd2e,  0xed0f,  0xdd6c,  0xcd4d,  0xbdaa,  0xad8b,  0x9de8,  0x8dc9,
  309.     0x7c26,  0x6c07,  0x5c64,  0x4c45,  0x3ca2,  0x2c83,  0x1ce0,  0x0cc1,
  310.     0xef1f,  0xff3e,  0xcf5d,  0xdf7c,  0xaf9b,  0xbfba,  0x8fd9,  0x9ff8,
  311.     0x6e17,  0x7e36,  0x4e55,  0x5e74,  0x2e93,  0x3eb2,  0x0ed1,  0x1ef0
  312.     };
  313.  
  314. /*
  315.  * updcrc macro derived from article Copyright (C) 1986 Stephen Satchell. 
  316.  *  NOTE: First srgument must be in range 0 to 255.
  317.  *        Second argument is referenced twice.
  318.  * 
  319.  * Programmers may incorporate any or all code into their programs, 
  320.  * giving proper credit within the source. Publication of the 
  321.  * source routines is permitted so long as proper credit is given 
  322.  * to Stephen Satchell, Satchell Evaluations and Chuck Forsberg, 
  323.  * Omen Technology.
  324.  */
  325.  
  326. #if    0                    /* defined in rbsb.h                                */
  327. #define updcrc(cp, crc) (_crctab[((crc >> 8) & 255)] ^ (crc << 8) ^ cp)
  328. #endif
  329.  
  330. /*
  331.  * Copyright (C) 1986 Gary S. Brown.  You may use this program, or
  332.  * code or tables extracted from it, as desired without restriction.
  333.  */
  334.  
  335. /* First, the polynomial itself and its table of feedback terms.  The  */
  336. /* polynomial is                                                       */
  337. /* 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 */
  338. /* Note that we take it "backwards" and put the highest-order term in  */
  339. /* the lowest-order bit.  The X^32 term is "implied"; the LSB is the   */
  340. /* X^31 term, etc.  The X^0 term (usually shown as "+1") results in    */
  341. /* the MSB being 1.                                                    */
  342.  
  343. /* Note that the usual hardware shift register implementation, which   */
  344. /* is what we're using (we're merely optimizing it by doing eight-bit  */
  345. /* chunks at a time) shifts bits into the lowest-order term.  In our   */
  346. /* implementation, that means shifting towards the right.  Why do we   */
  347. /* do it this way?  Because the calculated CRC must be transmitted in  */
  348. /* order from highest-order term to lowest-order term.  UARTs transmit */
  349. /* characters in order from LSB to MSB.  By storing the CRC this way,  */
  350. /* we hand it to the UART in the order low-byte to high-byte; the UART */
  351. /* sends each low-bit to hight-bit; and the result is transmission bit */
  352. /* by bit from highest- to lowest-order term without requiring any bit */
  353. /* shuffling on our part.  Reception works similarly.                  */
  354.  
  355. /* The feedback terms table consists of 256, 32-bit entries.  Notes:   */
  356. /*                                                                     */
  357. /*     The table can be generated at runtime if desired; code to do so */
  358. /*     is shown later.  It might not be obvious, but the feedback      */
  359. /*     terms simply represent the results of eight shift/xor opera-    */
  360. /*     tions for all combinations of data and CRC register values.     */
  361. /*                                                                     */
  362. /*     The values must be right-shifted by eight bits by the "updcrc"  */
  363. /*     logic; the shift must be unsigned (bring in zeroes).  On some   */
  364. /*     hardware you could probably optimize the shift in assembler by  */
  365. /*     using byte-swap instructions.                                   */
  366.  
  367. unsigned long far _cr3tab[] =
  368.     { /* CRC polynomial 0xedb88320 */
  369.     0x00000000L, 0x77073096L, 0xee0e612cL, 0x990951baL,
  370.     0x076dc419L, 0x706af48fL, 0xe963a535L, 0x9e6495a3L,
  371.     0x0edb8832L, 0x79dcb8a4L, 0xe0d5e91eL, 0x97d2d988L,
  372.     0x09b64c2bL, 0x7eb17cbdL, 0xe7b82d07L, 0x90bf1d91L,
  373.     0x1db71064L, 0x6ab020f2L, 0xf3b97148L, 0x84be41deL,
  374.     0x1adad47dL, 0x6ddde4ebL, 0xf4d4b551L, 0x83d385c7L,
  375.     0x136c9856L, 0x646ba8c0L, 0xfd62f97aL, 0x8a65c9ecL,
  376.     0x14015c4fL, 0x63066cd9L, 0xfa0f3d63L, 0x8d080df5L,
  377.     0x3b6e20c8L, 0x4c69105eL, 0xd56041e4L, 0xa2677172L,
  378.     0x3c03e4d1L, 0x4b04d447L, 0xd20d85fdL, 0xa50ab56bL,
  379.     0x35b5a8faL, 0x42b2986cL, 0xdbbbc9d6L, 0xacbcf940L,
  380.     0x32d86ce3L, 0x45df5c75L, 0xdcd60dcfL, 0xabd13d59L,
  381.     0x26d930acL, 0x51de003aL, 0xc8d75180L, 0xbfd06116L,
  382.     0x21b4f4b5L, 0x56b3c423L, 0xcfba9599L, 0xb8bda50fL,
  383.     0x2802b89eL, 0x5f058808L, 0xc60cd9b2L, 0xb10be924L,
  384.     0x2f6f7c87L, 0x58684c11L, 0xc1611dabL, 0xb6662d3dL,
  385.     0x76dc4190L, 0x01db7106L, 0x98d220bcL, 0xefd5102aL,
  386.     0x71b18589L, 0x06b6b51fL, 0x9fbfe4a5L, 0xe8b8d433L,
  387.     0x7807c9a2L, 0x0f00f934L, 0x9609a88eL, 0xe10e9818L,
  388.     0x7f6a0dbbL, 0x086d3d2dL, 0x91646c97L, 0xe6635c01L,
  389.     0x6b6b51f4L, 0x1c6c6162L, 0x856530d8L, 0xf262004eL,
  390.     0x6c0695edL, 0x1b01a57bL, 0x8208f4c1L, 0xf50fc457L,
  391.     0x65b0d9c6L, 0x12b7e950L, 0x8bbeb8eaL, 0xfcb9887cL,
  392.     0x62dd1ddfL, 0x15da2d49L, 0x8cd37cf3L, 0xfbd44c65L,
  393.     0x4db26158L, 0x3ab551ceL, 0xa3bc0074L, 0xd4bb30e2L,
  394.     0x4adfa541L, 0x3dd895d7L, 0xa4d1c46dL, 0xd3d6f4fbL,
  395.     0x4369e96aL, 0x346ed9fcL, 0xad678846L, 0xda60b8d0L,
  396.     0x44042d73L, 0x33031de5L, 0xaa0a4c5fL, 0xdd0d7cc9L,
  397.     0x5005713cL, 0x270241aaL, 0xbe0b1010L, 0xc90c2086L,
  398.     0x5768b525L, 0x206f85b3L, 0xb966d409L, 0xce61e49fL,
  399.     0x5edef90eL, 0x29d9c998L, 0xb0d09822L, 0xc7d7a8b4L,
  400.     0x59b33d17L, 0x2eb40d81L, 0xb7bd5c3bL, 0xc0ba6cadL,
  401.     0xedb88320L, 0x9abfb3b6L, 0x03b6e20cL, 0x74b1d29aL,
  402.     0xead54739L, 0x9dd277afL, 0x04db2615L, 0x73dc1683L,
  403.     0xe3630b12L, 0x94643b84L, 0x0d6d6a3eL, 0x7a6a5aa8L,
  404.     0xe40ecf0bL, 0x9309ff9dL, 0x0a00ae27L, 0x7d079eb1L,
  405.     0xf00f9344L, 0x8708a3d2L, 0x1e01f268L, 0x6906c2feL,
  406.     0xf762575dL, 0x806567cbL, 0x196c3671L, 0x6e6b06e7L,
  407.     0xfed41b76L, 0x89d32be0L, 0x10da7a5aL, 0x67dd4accL,
  408.     0xf9b9df6fL, 0x8ebeeff9L, 0x17b7be43L, 0x60b08ed5L,
  409.     0xd6d6a3e8L, 0xa1d1937eL, 0x38d8c2c4L, 0x4fdff252L,
  410.     0xd1bb67f1L, 0xa6bc5767L, 0x3fb506ddL, 0x48b2364bL,
  411.     0xd80d2bdaL, 0xaf0a1b4cL, 0x36034af6L, 0x41047a60L,
  412.     0xdf60efc3L, 0xa867df55L, 0x316e8eefL, 0x4669be79L,
  413.     0xcb61b38cL, 0xbc66831aL, 0x256fd2a0L, 0x5268e236L,
  414.     0xcc0c7795L, 0xbb0b4703L, 0x220216b9L, 0x5505262fL,
  415.     0xc5ba3bbeL, 0xb2bd0b28L, 0x2bb45a92L, 0x5cb36a04L,
  416.     0xc2d7ffa7L, 0xb5d0cf31L, 0x2cd99e8bL, 0x5bdeae1dL,
  417.     0x9b64c2b0L, 0xec63f226L, 0x756aa39cL, 0x026d930aL,
  418.     0x9c0906a9L, 0xeb0e363fL, 0x72076785L, 0x05005713L,
  419.     0x95bf4a82L, 0xe2b87a14L, 0x7bb12baeL, 0x0cb61b38L,
  420.     0x92d28e9bL, 0xe5d5be0dL, 0x7cdcefb7L, 0x0bdbdf21L,
  421.     0x86d3d2d4L, 0xf1d4e242L, 0x68ddb3f8L, 0x1fda836eL,
  422.     0x81be16cdL, 0xf6b9265bL, 0x6fb077e1L, 0x18b74777L,
  423.     0x88085ae6L, 0xff0f6a70L, 0x66063bcaL, 0x11010b5cL,
  424.     0x8f659effL, 0xf862ae69L, 0x616bffd3L, 0x166ccf45L,
  425.     0xa00ae278L, 0xd70dd2eeL, 0x4e048354L, 0x3903b3c2L,
  426.     0xa7672661L, 0xd06016f7L, 0x4969474dL, 0x3e6e77dbL,
  427.     0xaed16a4aL, 0xd9d65adcL, 0x40df0b66L, 0x37d83bf0L,
  428.     0xa9bcae53L, 0xdebb9ec5L, 0x47b2cf7fL, 0x30b5ffe9L,
  429.     0xbdbdf21cL, 0xcabac28aL, 0x53b39330L, 0x24b4a3a6L,
  430.     0xbad03605L, 0xcdd70693L, 0x54de5729L, 0x23d967bfL,
  431.     0xb3667a2eL, 0xc4614ab8L, 0x5d681b02L, 0x2a6f2b94L,
  432.     0xb40bbe37L, 0xc30c8ea1L, 0x5a05df1bL, 0x2d02ef8dL
  433.     };
  434.  
  435. #if    0                    /* defined in rbsb.h                                */
  436. #ifdef NFGM
  437. long UPDC32 (int b, long c)
  438.     {
  439.     return (_cr3tab[((int)c ^ b) & 0xff] ^ ((c >> 8) & 0x00FFFFFF));
  440.     }    /* long UPDC32 (int b, long c) */
  441.  
  442. #else
  443.  
  444. #define UPDC32(b, c) (_cr3tab[((int)c ^ b) & 0xff] ^ ((c >> 8) & 0x00FFFFFF))
  445. #endif
  446. #endif
  447. /* End of rbsb.c */
  448.