Annotation of embedaddon/quagga/isisd/iso_checksum.c, revision 1.1

1.1     ! misho       1: /*
        !             2:  * IS-IS Rout(e)ing protocol - iso_checksum.c
        !             3:  *                             ISO checksum related routines
        !             4:  *
        !             5:  * Copyright (C) 2001,2002   Sampo Saaristo
        !             6:  *                           Tampere University of Technology      
        !             7:  *                           Institute of Communications Engineering
        !             8:  *
        !             9:  * This program is free software; you can redistribute it and/or modify it 
        !            10:  * under the terms of the GNU General Public Licenseas published by the Free 
        !            11:  * Software Foundation; either version 2 of the License, or (at your option) 
        !            12:  * any later version.
        !            13:  *
        !            14:  * This program is distributed in the hope that it will be useful,but WITHOUT 
        !            15:  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 
        !            16:  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for 
        !            17:  * more details.
        !            18: 
        !            19:  * You should have received a copy of the GNU General Public License along 
        !            20:  * with this program; if not, write to the Free Software Foundation, Inc., 
        !            21:  * 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
        !            22:  */
        !            23: 
        !            24: #include <zebra.h>
        !            25: #include "iso_checksum.h"
        !            26: #include "checksum.h"
        !            27: 
        !            28: /*
        !            29:  * Calculations of the OSI checksum.
        !            30:  * ISO/IEC 8473 defines the sum as
        !            31:  *
        !            32:  *     L
        !            33:  *  sum  a (mod 255) = 0
        !            34:  *     1  i
        !            35:  *
        !            36:  *     L 
        !            37:  *  sum (L-i+1)a (mod 255) = 0
        !            38:  *     1        i
        !            39:  *
        !            40:  */
        !            41: 
        !            42: /*
        !            43:  * Verifies that the checksum is correct.
        !            44:  * Return 0 on correct and 1 on invalid checksum.
        !            45:  * Based on Annex C.4 of ISO/IEC 8473
        !            46:  */
        !            47: 
        !            48: int
        !            49: iso_csum_verify (u_char * buffer, int len, uint16_t * csum)
        !            50: {
        !            51:   u_int16_t checksum;
        !            52:   u_int32_t c0;
        !            53:   u_int32_t c1;
        !            54: 
        !            55:   c0 = *csum & 0xff00;
        !            56:   c1 = *csum & 0x00ff;
        !            57: 
        !            58:   /*
        !            59:    * If both are zero return correct
        !            60:    */
        !            61:   if (c0 == 0 && c1 == 0)
        !            62:     return 0;
        !            63: 
        !            64:   /*
        !            65:    * If either, but not both are zero return incorrect
        !            66:    */
        !            67:   if (c0 == 0 || c1 == 0)
        !            68:     return 1;
        !            69: 
        !            70:   /* Offset of checksum from the start of the buffer */
        !            71:   int offset = (u_char *) csum - buffer;
        !            72: 
        !            73:   checksum = fletcher_checksum(buffer, len, offset);
        !            74:   if (checksum == *csum)
        !            75:     return 0;
        !            76:   return 1;
        !            77: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>