Linux 4.18.10
[linux/fpc-iii.git] / arch / x86 / um / asm / checksum_32.h
blob83a75f8a12330237a73b20a9d5c96c9a77d4b450
1 /*
2 * Licensed under the GPL
3 */
5 #ifndef __UM_SYSDEP_CHECKSUM_H
6 #define __UM_SYSDEP_CHECKSUM_H
8 static inline __sum16 ip_compute_csum(const void *buff, int len)
10 return csum_fold (csum_partial(buff, len, 0));
13 #define _HAVE_ARCH_IPV6_CSUM
14 static __inline__ __sum16 csum_ipv6_magic(const struct in6_addr *saddr,
15 const struct in6_addr *daddr,
16 __u32 len, __u8 proto,
17 __wsum sum)
19 __asm__(
20 "addl 0(%1), %0 ;\n"
21 "adcl 4(%1), %0 ;\n"
22 "adcl 8(%1), %0 ;\n"
23 "adcl 12(%1), %0 ;\n"
24 "adcl 0(%2), %0 ;\n"
25 "adcl 4(%2), %0 ;\n"
26 "adcl 8(%2), %0 ;\n"
27 "adcl 12(%2), %0 ;\n"
28 "adcl %3, %0 ;\n"
29 "adcl %4, %0 ;\n"
30 "adcl $0, %0 ;\n"
31 : "=&r" (sum)
32 : "r" (saddr), "r" (daddr),
33 "r"(htonl(len)), "r"(htonl(proto)), "0"(sum));
35 return csum_fold(sum);
39 * Copy and checksum to user
41 #define HAVE_CSUM_COPY_USER
42 static __inline__ __wsum csum_and_copy_to_user(const void *src,
43 void __user *dst,
44 int len, __wsum sum, int *err_ptr)
46 if (access_ok(VERIFY_WRITE, dst, len)) {
47 if (copy_to_user(dst, src, len)) {
48 *err_ptr = -EFAULT;
49 return (__force __wsum)-1;
52 return csum_partial(src, len, sum);
55 if (len)
56 *err_ptr = -EFAULT;
58 return (__force __wsum)-1; /* invalid checksum */
61 #endif