| /* |
| * Licensed under the GPL |
| */ |
| |
| #ifndef __UM_SYSDEP_CHECKSUM_H |
| #define __UM_SYSDEP_CHECKSUM_H |
| |
| static inline __sum16 ip_compute_csum(const void *buff, int len) |
| { |
| return csum_fold (csum_partial(buff, len, 0)); |
| } |
| |
| #define _HAVE_ARCH_IPV6_CSUM |
| static __inline__ __sum16 csum_ipv6_magic(const struct in6_addr *saddr, |
| const struct in6_addr *daddr, |
| __u32 len, __u8 proto, |
| __wsum sum) |
| { |
| __asm__( |
| "addl 0(%1), %0 ;\n" |
| "adcl 4(%1), %0 ;\n" |
| "adcl 8(%1), %0 ;\n" |
| "adcl 12(%1), %0 ;\n" |
| "adcl 0(%2), %0 ;\n" |
| "adcl 4(%2), %0 ;\n" |
| "adcl 8(%2), %0 ;\n" |
| "adcl 12(%2), %0 ;\n" |
| "adcl %3, %0 ;\n" |
| "adcl %4, %0 ;\n" |
| "adcl $0, %0 ;\n" |
| : "=&r" (sum) |
| : "r" (saddr), "r" (daddr), |
| "r"(htonl(len)), "r"(htonl(proto)), "0"(sum)); |
| |
| return csum_fold(sum); |
| } |
| |
| #endif |