| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 1 | /* SCTP kernel reference Implementation | 
 | 2 |  * Copyright (c) 1999-2001 Motorola, Inc. | 
 | 3 |  * Copyright (c) 2001-2003 International Business Machines, Corp. | 
 | 4 |  * | 
 | 5 |  * This file is part of the SCTP kernel reference Implementation | 
 | 6 |  * | 
 | 7 |  * SCTP Checksum functions | 
 | 8 |  * | 
 | 9 |  * The SCTP reference implementation is free software; | 
 | 10 |  * you can redistribute it and/or modify it under the terms of | 
 | 11 |  * the GNU General Public License as published by | 
 | 12 |  * the Free Software Foundation; either version 2, or (at your option) | 
 | 13 |  * any later version. | 
 | 14 |  * | 
 | 15 |  * The SCTP reference implementation is distributed in the hope that it | 
 | 16 |  * will be useful, but WITHOUT ANY WARRANTY; without even the implied | 
 | 17 |  *                 ************************ | 
 | 18 |  * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | 
 | 19 |  * See the GNU General Public License for more details. | 
 | 20 |  * | 
 | 21 |  * You should have received a copy of the GNU General Public License | 
 | 22 |  * along with GNU CC; see the file COPYING.  If not, write to | 
 | 23 |  * the Free Software Foundation, 59 Temple Place - Suite 330, | 
 | 24 |  * Boston, MA 02111-1307, USA. | 
 | 25 |  * | 
 | 26 |  * Please send any bug reports or fixes you make to the | 
 | 27 |  * email address(es): | 
 | 28 |  *    lksctp developers <lksctp-developers@lists.sourceforge.net> | 
 | 29 |  * | 
 | 30 |  * Or submit a bug report through the following website: | 
 | 31 |  *    http://www.sf.net/projects/lksctp | 
 | 32 |  * | 
 | 33 |  * Written or modified by: | 
 | 34 |  *    Dinakaran Joseph | 
 | 35 |  *    Jon Grimm <jgrimm@us.ibm.com> | 
 | 36 |  *    Sridhar Samudrala <sri@us.ibm.com> | 
 | 37 |  * | 
 | 38 |  * Rewritten to use libcrc32c by: | 
 | 39 |  *    Vlad Yasevich <vladislav.yasevich@hp.com> | 
 | 40 |  * | 
 | 41 |  * Any bugs reported given to us we will try to fix... any fixes shared will | 
 | 42 |  * be incorporated into the next SCTP release. | 
 | 43 |  */ | 
 | 44 |  | 
 | 45 | #include <linux/types.h> | 
 | 46 | #include <net/sctp/sctp.h> | 
 | 47 | #include <linux/crc32c.h> | 
 | 48 |  | 
| Vlad Yasevich | 4458f04 | 2009-02-13 08:33:42 +0000 | [diff] [blame] | 49 | static inline __u32 sctp_crc32c(__u32 crc, u8 *buffer, u16 length) | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 50 | { | 
| Vlad Yasevich | 4458f04 | 2009-02-13 08:33:42 +0000 | [diff] [blame] | 51 | 	return crc32c(crc, buffer, length); | 
| Harvey Harrison | 336d326 | 2008-07-18 23:07:09 -0700 | [diff] [blame] | 52 | } | 
 | 53 |  | 
| Vlad Yasevich | 4458f04 | 2009-02-13 08:33:42 +0000 | [diff] [blame] | 54 | static inline __u32 sctp_start_cksum(__u8 *buffer, __u16 length) | 
| Harvey Harrison | 336d326 | 2008-07-18 23:07:09 -0700 | [diff] [blame] | 55 | { | 
| Vlad Yasevich | 4458f04 | 2009-02-13 08:33:42 +0000 | [diff] [blame] | 56 | 	__u32 crc = ~(__u32)0; | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 57 | 	__u8  zero[sizeof(__u32)] = {0}; | 
 | 58 |  | 
 | 59 | 	/* Optimize this routine to be SCTP specific, knowing how | 
 | 60 | 	 * to skip the checksum field of the SCTP header. | 
 | 61 | 	 */ | 
 | 62 |  | 
 | 63 | 	/* Calculate CRC up to the checksum. */ | 
| Harvey Harrison | 336d326 | 2008-07-18 23:07:09 -0700 | [diff] [blame] | 64 | 	crc = sctp_crc32c(crc, buffer, sizeof(struct sctphdr) - sizeof(__u32)); | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 65 |  | 
 | 66 | 	/* Skip checksum field of the header. */ | 
| Harvey Harrison | 336d326 | 2008-07-18 23:07:09 -0700 | [diff] [blame] | 67 | 	crc = sctp_crc32c(crc, zero, sizeof(__u32)); | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 68 |  | 
 | 69 | 	/* Calculate the rest of the CRC. */ | 
| Harvey Harrison | 336d326 | 2008-07-18 23:07:09 -0700 | [diff] [blame] | 70 | 	crc = sctp_crc32c(crc, &buffer[sizeof(struct sctphdr)], | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 71 | 			    length - sizeof(struct sctphdr)); | 
 | 72 | 	return crc; | 
 | 73 | } | 
 | 74 |  | 
| Vlad Yasevich | 4458f04 | 2009-02-13 08:33:42 +0000 | [diff] [blame] | 75 | static inline __u32 sctp_update_cksum(__u8 *buffer, __u16 length, __u32 crc32) | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 76 | { | 
| Harvey Harrison | 336d326 | 2008-07-18 23:07:09 -0700 | [diff] [blame] | 77 | 	return sctp_crc32c(crc32, buffer, length); | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 78 | } | 
 | 79 |  | 
| Vlad Yasevich | 4458f04 | 2009-02-13 08:33:42 +0000 | [diff] [blame] | 80 | static inline __le32 sctp_end_cksum(__be32 crc32) | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 81 | { | 
| Vlad Yasevich | 4458f04 | 2009-02-13 08:33:42 +0000 | [diff] [blame] | 82 | 	return cpu_to_le32(~crc32); | 
| Vlad Yasevich | 9ad0977 | 2007-12-16 14:06:41 -0800 | [diff] [blame] | 83 | } |