blob: 4a5b9a306c69b4139c8811138204410bb791e79b [file] [log] [blame]
Vlad Yasevich9ad09772007-12-16 14:06:41 -08001/* 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
Jeff Kirshera6227e22013-12-06 09:13:40 -080022 * along with GNU CC; see the file COPYING. If not, see
23 * <http://www.gnu.org/licenses/>.
Vlad Yasevich9ad09772007-12-16 14:06:41 -080024 *
25 * Please send any bug reports or fixes you make to the
26 * email address(es):
Daniel Borkmann91705c62013-07-23 14:51:47 +020027 * lksctp developers <linux-sctp@vger.kernel.org>
Vlad Yasevich9ad09772007-12-16 14:06:41 -080028 *
Vlad Yasevich9ad09772007-12-16 14:06:41 -080029 * Written or modified by:
30 * Dinakaran Joseph
31 * Jon Grimm <jgrimm@us.ibm.com>
32 * Sridhar Samudrala <sri@us.ibm.com>
33 *
34 * Rewritten to use libcrc32c by:
35 * Vlad Yasevich <vladislav.yasevich@hp.com>
Vlad Yasevich9ad09772007-12-16 14:06:41 -080036 */
37
Daniel Borkmanna05b1012013-07-01 18:10:36 +020038#ifndef __sctp_checksum_h__
39#define __sctp_checksum_h__
40
Vlad Yasevich9ad09772007-12-16 14:06:41 -080041#include <linux/types.h>
42#include <net/sctp/sctp.h>
43#include <linux/crc32c.h>
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010044#include <linux/crc32.h>
Vlad Yasevich9ad09772007-12-16 14:06:41 -080045
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010046static inline __wsum sctp_csum_update(const void *buff, int len, __wsum sum)
Vlad Yasevich9ad09772007-12-16 14:06:41 -080047{
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010048 /* This uses the crypto implementation of crc32c, which is either
49 * implemented w/ hardware support or resolves to __crc32c_le().
Vlad Yasevich9ad09772007-12-16 14:06:41 -080050 */
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010051 return crc32c(sum, buff, len);
Vlad Yasevich9ad09772007-12-16 14:06:41 -080052}
53
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010054static inline __wsum sctp_csum_combine(__wsum csum, __wsum csum2,
55 int offset, int len)
Vlad Yasevich9ad09772007-12-16 14:06:41 -080056{
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010057 return __crc32c_le_combine(csum, csum2, len);
Vlad Yasevich9ad09772007-12-16 14:06:41 -080058}
59
Joe Stringer024ec3d2013-07-25 10:52:05 +090060static inline __le32 sctp_compute_cksum(const struct sk_buff *skb,
61 unsigned int offset)
62{
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010063 struct sctphdr *sh = sctp_hdr(skb);
64 __le32 ret, old = sh->checksum;
65 const struct skb_checksum_ops ops = {
66 .update = sctp_csum_update,
67 .combine = sctp_csum_combine,
68 };
Joe Stringer024ec3d2013-07-25 10:52:05 +090069
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010070 sh->checksum = 0;
71 ret = cpu_to_le32(~__skb_checksum(skb, offset, skb->len - offset,
72 ~(__u32)0, &ops));
73 sh->checksum = old;
Joe Stringer024ec3d2013-07-25 10:52:05 +090074
Daniel Borkmanne6d8b642013-10-30 11:50:52 +010075 return ret;
Joe Stringer024ec3d2013-07-25 10:52:05 +090076}
77
Daniel Borkmanna05b1012013-07-01 18:10:36 +020078#endif /* __sctp_checksum_h__ */