mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
cc44c17baf
It's always 0. Note that we theoretically could use ~0U as well - result will be the same modulo 0xffff, _if_ the damn thing did the right thing for any value of initial sum; later we'll make use of that when convenient. However, unlike csum_and_copy_..._user(), there are instances that did not work for arbitrary initial sums; c6x is one such. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
35 lines
910 B
C
35 lines
910 B
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright (C) 2011 Texas Instruments Incorporated
|
|
* Author: Mark Salter <msalter@redhat.com>
|
|
*/
|
|
#ifndef _ASM_C6X_CHECKSUM_H
|
|
#define _ASM_C6X_CHECKSUM_H
|
|
|
|
static inline __wsum
|
|
csum_tcpudp_nofold(__be32 saddr, __be32 daddr, __u32 len,
|
|
__u8 proto, __wsum sum)
|
|
{
|
|
unsigned long long tmp;
|
|
|
|
asm ("add .d1 %1,%5,%1\n"
|
|
"|| addu .l1 %3,%4,%0\n"
|
|
"addu .l1 %2,%0,%0\n"
|
|
#ifndef CONFIG_CPU_BIG_ENDIAN
|
|
"|| shl .s1 %1,8,%1\n"
|
|
#endif
|
|
"addu .l1 %1,%0,%0\n"
|
|
"add .l1 %P0,%p0,%2\n"
|
|
: "=&a"(tmp), "+a"(len), "+a"(sum)
|
|
: "a" (saddr), "a" (daddr), "a" (proto));
|
|
return sum;
|
|
}
|
|
#define csum_tcpudp_nofold csum_tcpudp_nofold
|
|
|
|
#define _HAVE_ARCH_CSUM_AND_COPY
|
|
extern __wsum csum_partial_copy_nocheck(const void *src, void *dst, int len);
|
|
|
|
#include <asm-generic/checksum.h>
|
|
|
|
#endif /* _ASM_C6X_CHECKSUM_H */
|