/* * Copyright 2010 Tilera Corporation. All Rights Reserved. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation, version 2. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or * NON INFRINGEMENT. See the GNU General Public License for * more details. */ #ifndef _ASM_TILE_CHECKSUM_H #define _ASM_TILE_CHECKSUM_H #include <asm-generic/checksum.h> /* Allow us to provide a more optimized do_csum(). */ __wsum do_csum(const unsigned char *buff, int len); #define do_csum do_csum /* * Return the sum of all the 16-bit subwords in a long. * This sums two subwords on a 32-bit machine, and four on 64 bits. * The implementation does two vector adds to capture any overflow. */ static inline unsigned int csum_long(unsigned long x) { unsigned long ret; #ifdef __tilegx__ ret = __insn_v2sadu(x, 0); ret = __insn_v2sadu(ret, 0); #else ret = __insn_sadh_u(x, 0); ret = __insn_sadh_u(ret, 0); #endif return ret; } #endif /* _ASM_TILE_CHECKSUM_H */ |