/* * include/asm-xtensa/checksum.h * * 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. * * Copyright (C) 2001 - 2005 Tensilica Inc.
*/
/* * 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
*/
asmlinkage __wsum csum_partial(constvoid *buff, int len, __wsum sum);
/* * the same as csum_partial, but copies from src while it * checksums, and handles user-space pointer exceptions correctly, when needed. * * here even more important to align src and dst on a 32-bit (or even * better 64-bit) boundary
*/
asmlinkage __wsum csum_partial_copy_generic(constvoid *src, void *dst, int len);
#define _HAVE_ARCH_CSUM_AND_COPY /* * Note: when you get a NULL pointer exception here this means someone * passed in an incorrect kernel address to one of these functions.
*/ staticinline
__wsum csum_partial_copy_nocheck(constvoid *src, void *dst, int len)
{ return csum_partial_copy_generic(src, dst, len);
}
/* * This is a version of ip_compute_csum() optimized for IP headers, * which always checksum on 4 octet boundaries.
*/ static __inline__ __sum16 ip_fast_csum(constvoid *iph, unsignedint ihl)
{ unsignedint sum, tmp, endaddr;
__asm__ __volatile__( "sub %0, %0, %0\n\t" #if XCHAL_HAVE_LOOPS "loopgtz %2, 2f\n\t" #else "beqz %2, 2f\n\t" "slli %4, %2, 2\n\t" "add %4, %4, %1\n\t" "0:\t" #endif "l32i %3, %1, 0\n\t" "add %0, %0, %3\n\t" "bgeu %0, %3, 1f\n\t" "addi %0, %0, 1\n\t" "1:\t" "addi %1, %1, 4\n\t" #if !XCHAL_HAVE_LOOPS "blt %1, %4, 0b\n\t" #endif "2:\t" /* Since the input registers which are loaded with iph and ihl are modified, we must also specify them as outputs, or gcc
will assume they contain their original values. */
: "=r" (sum), "=r" (iph), "=r" (ihl), "=&r" (tmp), "=&r" (endaddr)
: "1" (iph), "2" (ihl)
: "memory");
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.