This source file includes following definitions.
- csum_fold
- csum_tcpudp_magic
1
2 #ifndef __ASM_GENERIC_CHECKSUM_H
3 #define __ASM_GENERIC_CHECKSUM_H
4
5
6
7
8
9
10
11
12
13
14
15
16
17 extern __wsum csum_partial(const void *buff, int len, __wsum sum);
18
19
20
21
22
23
24
25
26 extern __wsum csum_partial_copy(const void *src, void *dst, int len, __wsum sum);
27
28
29
30
31
32
33
34 extern __wsum csum_partial_copy_from_user(const void __user *src, void *dst,
35 int len, __wsum sum, int *csum_err);
36
37 #ifndef csum_partial_copy_nocheck
38 #define csum_partial_copy_nocheck(src, dst, len, sum) \
39 csum_partial_copy((src), (dst), (len), (sum))
40 #endif
41
42 #ifndef ip_fast_csum
43
44
45
46
47 extern __sum16 ip_fast_csum(const void *iph, unsigned int ihl);
48 #endif
49
50 #ifndef csum_fold
51
52
53
54 static inline __sum16 csum_fold(__wsum csum)
55 {
56 u32 sum = (__force u32)csum;
57 sum = (sum & 0xffff) + (sum >> 16);
58 sum = (sum & 0xffff) + (sum >> 16);
59 return (__force __sum16)~sum;
60 }
61 #endif
62
63 #ifndef csum_tcpudp_nofold
64
65
66
67
68 extern __wsum
69 csum_tcpudp_nofold(__be32 saddr, __be32 daddr, __u32 len,
70 __u8 proto, __wsum sum);
71 #endif
72
73 #ifndef csum_tcpudp_magic
74 static inline __sum16
75 csum_tcpudp_magic(__be32 saddr, __be32 daddr, __u32 len,
76 __u8 proto, __wsum sum)
77 {
78 return csum_fold(csum_tcpudp_nofold(saddr, daddr, len, proto, sum));
79 }
80 #endif
81
82
83
84
85
86 extern __sum16 ip_compute_csum(const void *buff, int len);
87
88 #endif