Blame view

include/net/checksum.h 2.38 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
  /*
   * INET		An implementation of the TCP/IP protocol suite for the LINUX
   *		operating system.  INET is implemented using the  BSD Socket
   *		interface as the means of communication with the user level.
   *
   *		Checksumming functions for IP, TCP, UDP and so on
   *
   * Authors:	Jorge Cwik, <jorge@laser.satlink.net>
   *		Arnt Gulbrandsen, <agulbra@nvg.unit.no>
   *		Borrows very liberally from tcp.c and ip.c, see those
   *		files for more names.
   *
   *		This program is free software; you can redistribute it and/or
   *		modify it under the terms of the GNU General Public License
   *		as published by the Free Software Foundation; either version
   *		2 of the License, or (at your option) any later version.
   */
  
  #ifndef _CHECKSUM_H
  #define _CHECKSUM_H
  
  #include <linux/errno.h>
  #include <asm/types.h>
  #include <asm/byteorder.h>
  #include <asm/uaccess.h>
  #include <asm/checksum.h>
  
  #ifndef _HAVE_ARCH_COPY_AND_CSUM_FROM_USER
  static inline
56649d5d3   Al Viro   [NET]: Generic ch...
30
31
  __wsum csum_and_copy_from_user (const void __user *src, void *dst,
  				      int len, __wsum sum, int *err_ptr)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
32
33
34
35
36
37
38
39
40
41
42
43
  {
  	if (access_ok(VERIFY_READ, src, len))
  		return csum_partial_copy_from_user(src, dst, len, sum, err_ptr);
  
  	if (len)
  		*err_ptr = -EFAULT;
  
  	return sum;
  }
  #endif
  
  #ifndef HAVE_CSUM_COPY_USER
56649d5d3   Al Viro   [NET]: Generic ch...
44
45
  static __inline__ __wsum csum_and_copy_to_user
  (const void *src, void __user *dst, int len, __wsum sum, int *err_ptr)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
46
47
48
49
50
51
52
53
54
  {
  	sum = csum_partial(src, len, sum);
  
  	if (access_ok(VERIFY_WRITE, dst, len)) {
  		if (copy_to_user(dst, src, len) == 0)
  			return sum;
  	}
  	if (len)
  		*err_ptr = -EFAULT;
56649d5d3   Al Viro   [NET]: Generic ch...
55
  	return (__force __wsum)-1; /* invalid checksum */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
56
57
  }
  #endif
56649d5d3   Al Viro   [NET]: Generic ch...
58
  static inline __wsum csum_add(__wsum csum, __wsum addend)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
59
  {
56649d5d3   Al Viro   [NET]: Generic ch...
60
61
62
  	u32 res = (__force u32)csum;
  	res += (__force u32)addend;
  	return (__force __wsum)(res + (res < (__force u32)addend));
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
63
  }
56649d5d3   Al Viro   [NET]: Generic ch...
64
  static inline __wsum csum_sub(__wsum csum, __wsum addend)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
65
66
67
  {
  	return csum_add(csum, ~addend);
  }
56649d5d3   Al Viro   [NET]: Generic ch...
68
69
  static inline __wsum
  csum_block_add(__wsum csum, __wsum csum2, int offset)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
70
  {
56649d5d3   Al Viro   [NET]: Generic ch...
71
  	u32 sum = (__force u32)csum2;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
72
  	if (offset&1)
56649d5d3   Al Viro   [NET]: Generic ch...
73
74
  		sum = ((sum&0xFF00FF)<<8)+((sum>>8)&0xFF00FF);
  	return csum_add(csum, (__force __wsum)sum);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
75
  }
56649d5d3   Al Viro   [NET]: Generic ch...
76
77
  static inline __wsum
  csum_block_sub(__wsum csum, __wsum csum2, int offset)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
78
  {
56649d5d3   Al Viro   [NET]: Generic ch...
79
  	u32 sum = (__force u32)csum2;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
80
  	if (offset&1)
56649d5d3   Al Viro   [NET]: Generic ch...
81
82
83
84
85
86
87
  		sum = ((sum&0xFF00FF)<<8)+((sum>>8)&0xFF00FF);
  	return csum_sub(csum, (__force __wsum)sum);
  }
  
  static inline __wsum csum_unfold(__sum16 n)
  {
  	return (__force __wsum)n;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
88
  }
f6ab02880   Al Viro   [NET]: Make mangl...
89
  #define CSUM_MANGLED_0 ((__force __sum16)0xffff)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
90
  #endif