HEX
Server: Apache/2.4.18 (Ubuntu)
System: Linux phubuntu06.apexhosting.com 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64
User: master06 (1000)
PHP: 7.0.33-0ubuntu0.16.04.16
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,
Upload Files
File: //usr/src/linux-headers-4.4.0-210/arch/cris/include/arch-v32/arch/checksum.h
#ifndef _ASM_CRIS_ARCH_CHECKSUM_H
#define _ASM_CRIS_ARCH_CHECKSUM_H

/*
 * Check values used in TCP/UDP headers.
 *
 * The gain of doing this in assembler instead of C, is that C doesn't
 * generate carry-additions for the 32-bit components of the
 * checksum. Which means it would be necessary to split all those into
 * 16-bit components and then add.
 */
static inline __wsum
csum_tcpudp_nofold(__be32 saddr, __be32 daddr,
		   unsigned short len, unsigned short proto, __wsum sum)
{
	__wsum res;

	__asm__ __volatile__ ("add.d %2, %0\n\t"
			      "addc %3, %0\n\t"
			      "addc %4, %0\n\t"
			      "addc 0, %0\n\t"
			      : "=r" (res)
			      : "0" (sum), "r" (daddr), "r" (saddr), \
			      "r" ((len + proto) << 8));

	return res;
}

#endif /* _ASM_CRIS_ARCH_CHECKSUM_H */