2005-04-16 15:20:36 -07:00
# ifndef __ASM_SH64_CHECKSUM_H
# define __ASM_SH64_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 .
*
* include / asm - sh64 / checksum . h
*
* Copyright ( C ) 2000 , 2001 Paolo Alberelli
*
*/
# include <asm/registers.h>
/*
* 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
*/
2006-11-14 21:19:01 -08:00
asmlinkage __wsum csum_partial ( const void * buff , int len , __wsum sum ) ;
2005-04-16 15:20:36 -07:00
/*
* Note : when you get a NULL pointer exception here this means someone
* passed in an incorrect kernel address to one of these functions .
*
* If you use these functions directly please don ' t forget the
2005-05-01 08:59:08 -07:00
* access_ok ( ) .
2005-04-16 15:20:36 -07:00
*/
2006-11-14 21:19:01 -08:00
__wsum csum_partial_copy_nocheck ( const void * src , void * dst , int len ,
__wsum sum ) ;
2005-04-16 15:20:36 -07:00
2006-11-14 21:19:01 -08:00
__wsum csum_partial_copy_from_user ( const void __user * src , void * dst ,
int len , __wsum sum , int * err_ptr ) ;
2005-04-16 15:20:36 -07:00
2006-11-14 21:19:01 -08:00
static inline __sum16 csum_fold ( __wsum csum )
2005-04-16 15:20:36 -07:00
{
2006-11-14 21:19:01 -08:00
u32 sum = ( __force u32 ) csum ;
2005-04-16 15:20:36 -07:00
sum = ( sum & 0xffff ) + ( sum > > 16 ) ;
sum = ( sum & 0xffff ) + ( sum > > 16 ) ;
2006-11-14 21:19:01 -08:00
return ( __force __sum16 ) ~ sum ;
2005-04-16 15:20:36 -07:00
}
2006-11-14 21:19:01 -08:00
__sum16 ip_fast_csum ( const void * iph , unsigned int ihl ) ;
2005-04-16 15:20:36 -07:00
2006-11-14 21:19:01 -08:00
__wsum csum_tcpudp_nofold ( __be32 saddr , __be32 daddr ,
2005-04-16 15:20:36 -07:00
unsigned short len , unsigned short proto ,
2006-11-14 21:19:01 -08:00
__wsum sum ) ;
2005-04-16 15:20:36 -07:00
/*
* computes the checksum of the TCP / UDP pseudo - header
* returns a 16 - bit checksum , already complemented
*/
2006-11-14 21:19:01 -08:00
static inline __sum16 csum_tcpudp_magic ( __be32 saddr , __be32 daddr ,
2005-04-16 15:20:36 -07:00
unsigned short len ,
unsigned short proto ,
2006-11-14 21:19:01 -08:00
__wsum sum )
2005-04-16 15:20:36 -07:00
{
return csum_fold ( csum_tcpudp_nofold ( saddr , daddr , len , proto , sum ) ) ;
}
/*
* this routine is used for miscellaneous IP - like checksums , mainly
* in icmp . c
*/
2006-11-14 21:19:01 -08:00
static inline __sum16 ip_compute_csum ( const void * buff , int len )
2005-04-16 15:20:36 -07:00
{
return csum_fold ( csum_partial ( buff , len , 0 ) ) ;
}
# endif /* __ASM_SH64_CHECKSUM_H */