Blame view

include/asm-v850/checksum.h 2.68 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
  /*
   * include/asm-v850/checksum.h -- Checksum ops
   *
623cdf4a0   Miles Bader   [PATCH] v850: Upd...
4
5
   *  Copyright (C) 2001,2005  NEC Corporation
   *  Copyright (C) 2001,2005  Miles Bader <miles@gnu.org>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
   *
   * This file is subject to the terms and conditions of the GNU General
   * Public License.  See the file COPYING in the main directory of this
   * archive for more details.
   *
   * Written by Miles Bader <miles@gnu.org>
   */
  
  #ifndef __V850_CHECKSUM_H__
  #define __V850_CHECKSUM_H__
  
  /*
   * computes the checksum of a memory block at buff, length len,
   * and adds in "sum" (32-bit)
   *
   * returns a 32-bit number suitable for feeding into itself
   * or csum_tcpudp_magic
   *
   * this function must be called with even lengths, except
   * for the last fragment, which may be odd
   *
   * it's best to have buff aligned on a 32-bit boundary
   */
9d3d41955   Al Viro   [NET]: V850 check...
29
  extern __wsum csum_partial(const void *buff, int len, __wsum sum);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
30
31
32
33
34
35
36
37
  
  /*
   * the same as csum_partial, but copies from src while it
   * checksums
   *
   * here even more important to align src and dst on a 32-bit (or even
   * better 64-bit) boundary
   */
9d3d41955   Al Viro   [NET]: V850 check...
38
39
  extern __wsum csum_partial_copy_nocheck(const void *src,
  				   void *dst, int len, __wsum sum);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
40
41
42
43
44
45
46
47
  
  
  /*
   * the same as csum_partial_copy, but copies from user space.
   *
   * here even more important to align src and dst on a 32-bit (or even
   * better 64-bit) boundary
   */
9d3d41955   Al Viro   [NET]: V850 check...
48
49
50
  extern __wsum csum_partial_copy_from_user (const void *src,
  					     void *dst,
  					     int len, __wsum sum,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
51
  					     int *csum_err);
9d3d41955   Al Viro   [NET]: V850 check...
52
  __sum16 ip_fast_csum(const void *iph, unsigned int ihl);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
53
54
55
56
  
  /*
   *	Fold a partial checksum
   */
9d3d41955   Al Viro   [NET]: V850 check...
57
  static inline __sum16 csum_fold (__wsum sum)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
58
59
60
61
62
63
64
65
  {
  	unsigned int result;
  	/*
  			        %0		%1
  	      hsw %1, %0	H     L		L     H
  	      add %1, %0	H     L		H+L+C H+L
  	*/
  	asm ("hsw %1, %0; add %1, %0" : "=&r" (result) : "r" (sum));
9d3d41955   Al Viro   [NET]: V850 check...
66
  	return (__force __sum16)(~result >> 16);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
67
68
69
70
71
72
73
  }
  
  
  /*
   * computes the checksum of the TCP/UDP pseudo-header
   * returns a 16-bit checksum, already complemented
   */
9d3d41955   Al Viro   [NET]: V850 check...
74
75
  static inline __wsum
  csum_tcpudp_nofold (__be32 saddr, __be32 daddr,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
76
  		    unsigned short len,
9d3d41955   Al Viro   [NET]: V850 check...
77
  		    unsigned short proto, __wsum sum)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
78
79
80
81
82
83
84
85
86
87
88
89
90
  {
  	int __carry;
  	__asm__ ("add %2, %0;"
  		 "setf c, %1;"
  		 "add %1, %0;"
  		 "add %3, %0;"
  		 "setf c, %1;"
  		 "add %1, %0;"
  		 "add %4, %0;"
  		 "setf c, %1;"
  		 "add %1, %0"
  		 : "=&r" (sum), "=&r" (__carry)
  		 : "r" (daddr), "r" (saddr),
9d3d41955   Al Viro   [NET]: V850 check...
91
  		 "r" ((len + proto) << 8),
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
92
93
94
  		 "0" (sum));
  	return sum;
  }
9d3d41955   Al Viro   [NET]: V850 check...
95
96
  static inline __sum16
  csum_tcpudp_magic (__be32 saddr, __be32 daddr,
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
97
  		   unsigned short len,
9d3d41955   Al Viro   [NET]: V850 check...
98
  		   unsigned short proto, __wsum sum)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
99
100
101
102
103
104
105
106
  {
  	return csum_fold (csum_tcpudp_nofold (saddr, daddr, len, proto, sum));
  }
  
  /*
   * this routine is used for miscellaneous IP-like checksums, mainly
   * in icmp.c
   */
9d3d41955   Al Viro   [NET]: V850 check...
107
  extern __sum16 ip_compute_csum(const void *buff, int len);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
108
109
110
  
  
  #endif /* __V850_CHECKSUM_H__ */