| /* |
| * 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 */ |