Blame view
include/asm-v850/checksum.h
2.68 KB
1da177e4c
|
1 2 3 |
/* * include/asm-v850/checksum.h -- Checksum ops * |
623cdf4a0
|
4 5 |
* Copyright (C) 2001,2005 NEC Corporation * Copyright (C) 2001,2005 Miles Bader <miles@gnu.org> |
1da177e4c
|
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
|
29 |
extern __wsum csum_partial(const void *buff, int len, __wsum sum); |
1da177e4c
|
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
|
38 39 |
extern __wsum csum_partial_copy_nocheck(const void *src, void *dst, int len, __wsum sum); |
1da177e4c
|
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
|
48 49 50 |
extern __wsum csum_partial_copy_from_user (const void *src, void *dst, int len, __wsum sum, |
1da177e4c
|
51 |
int *csum_err); |
9d3d41955
|
52 |
__sum16 ip_fast_csum(const void *iph, unsigned int ihl); |
1da177e4c
|
53 54 55 56 |
/* * Fold a partial checksum */ |
9d3d41955
|
57 |
static inline __sum16 csum_fold (__wsum sum) |
1da177e4c
|
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
|
66 |
return (__force __sum16)(~result >> 16); |
1da177e4c
|
67 68 69 70 71 72 73 |
} /* * computes the checksum of the TCP/UDP pseudo-header * returns a 16-bit checksum, already complemented */ |
9d3d41955
|
74 75 |
static inline __wsum csum_tcpudp_nofold (__be32 saddr, __be32 daddr, |
1da177e4c
|
76 |
unsigned short len, |
9d3d41955
|
77 |
unsigned short proto, __wsum sum) |
1da177e4c
|
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
|
91 |
"r" ((len + proto) << 8), |
1da177e4c
|
92 93 94 |
"0" (sum)); return sum; } |
9d3d41955
|
95 96 |
static inline __sum16 csum_tcpudp_magic (__be32 saddr, __be32 daddr, |
1da177e4c
|
97 |
unsigned short len, |
9d3d41955
|
98 |
unsigned short proto, __wsum sum) |
1da177e4c
|
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
|
107 |
extern __sum16 ip_compute_csum(const void *buff, int len); |
1da177e4c
|
108 109 110 |
#endif /* __V850_CHECKSUM_H__ */ |