* Copyright (c) 1983 Regents of the University of California.
* Redistribution and use in source and binary forms are permitted provided
* that: (1) source distributions retain this entire copyright notice and
* comment, and (2) distributions including binaries display the following
* acknowledgement: ``This product includes software developed by the
* University of California, Berkeley and its contributors'' in the
* documentation or other materials provided with the distribution and in
* all advertising materials mentioning features or use of this software.
* Neither the name of the University nor the names of its contributors may
* be used to endorse or promote products derived from this software without
* specific prior written permission.
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
static char sccsid
[] = "@(#)cksum.vax.c 1.5 (Berkeley) 6/1/90";
#define ADD asm("adwc (r9)+,r8;");
/* computes the checksum for ip packets for the VAX */
register int nleft
= len
; /* on vax, (user mode), r11 */
register int xxx
; /* on vax, (user mode), r10 */
register u_short
*w
= addr
; /* on vax, known to be r9 */
register int sum
= 0; /* on vax, known to be r8 */
if (((int)w
&0x2) && nleft
>= 2) {
while ((nleft
-= 32) >= 0) {
asm("clrl r0"); /* clears carry */
ADD
; ADD
; ADD
; ADD
; ADD
; ADD
; ADD
; ADD
;
while ((nleft
-= 8) >= 0) {
{ asm("ashl $-16,r8,r0; addw2 r0,r8");
asm("adwc $0,r8; movzwl r8,r8"); }
while ((nleft
-= 2) >= 0) {
asm("movzwl (r9)+,r0; addl2 r0,r8");
{ asm("ashl $-16,r8,r0; addw2 r0,r8; adwc $0,r8");
asm("mcoml r8,r8; movzwl r8,r8"); }