checksum.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef __ASM_GENERIC_CHECKSUM_H
  3. #define __ASM_GENERIC_CHECKSUM_H
  4. #include <linux/bitops.h>
  5. /*
  6. * computes the checksum of a memory block at buff, length len,
  7. * and adds in "sum" (32-bit)
  8. *
  9. * returns a 32-bit number suitable for feeding into itself
  10. * or csum_tcpudp_magic
  11. *
  12. * this function must be called with even lengths, except
  13. * for the last fragment, which may be odd
  14. *
  15. * it's best to have buff aligned on a 32-bit boundary
  16. */
  17. extern __wsum csum_partial(const void *buff, int len, __wsum sum);
  18. #ifndef ip_fast_csum
  19. /*
  20. * This is a version of ip_compute_csum() optimized for IP headers,
  21. * which always checksum on 4 octet boundaries.
  22. */
  23. extern __sum16 ip_fast_csum(const void *iph, unsigned int ihl);
  24. #endif
  25. #ifndef csum_fold
  26. /*
  27. * Fold a partial checksum
  28. */
  29. static inline __sum16 csum_fold(__wsum csum)
  30. {
  31. u32 sum = (__force u32)csum;
  32. return (__force __sum16)((~sum - ror32(sum, 16)) >> 16);
  33. }
  34. #endif
  35. #ifndef csum_tcpudp_nofold
  36. /*
  37. * computes the checksum of the TCP/UDP pseudo-header
  38. * returns a 16-bit checksum, already complemented
  39. */
  40. extern __wsum
  41. csum_tcpudp_nofold(__be32 saddr, __be32 daddr, __u32 len,
  42. __u8 proto, __wsum sum);
  43. #endif
  44. #ifndef csum_tcpudp_magic
  45. static inline __sum16
  46. csum_tcpudp_magic(__be32 saddr, __be32 daddr, __u32 len,
  47. __u8 proto, __wsum sum)
  48. {
  49. return csum_fold(csum_tcpudp_nofold(saddr, daddr, len, proto, sum));
  50. }
  51. #endif
  52. /*
  53. * this routine is used for miscellaneous IP-like checksums, mainly
  54. * in icmp.c
  55. */
  56. extern __sum16 ip_compute_csum(const void *buff, int len);
  57. #endif /* __ASM_GENERIC_CHECKSUM_H */