xref: /titanic_50/usr/src/lib/libsum/common/sum-bsd.c (revision 3e14f97f673e8a630f076077de35afdd43dc1587)
17c2fbfb3SApril Chin /***********************************************************************
27c2fbfb3SApril Chin *                                                                      *
37c2fbfb3SApril Chin *               This software is part of the ast package               *
4*3e14f97fSRoger A. Faulkner *          Copyright (c) 1996-2010 AT&T Intellectual Property          *
57c2fbfb3SApril Chin *                      and is licensed under the                       *
67c2fbfb3SApril Chin *                  Common Public License, Version 1.0                  *
77c2fbfb3SApril Chin *                    by AT&T Intellectual Property                     *
87c2fbfb3SApril Chin *                                                                      *
97c2fbfb3SApril Chin *                A copy of the License is available at                 *
107c2fbfb3SApril Chin *            http://www.opensource.org/licenses/cpl1.0.txt             *
117c2fbfb3SApril Chin *         (with md5 checksum 059e8cd6165cb4c31e351f2b69388fd9)         *
127c2fbfb3SApril Chin *                                                                      *
137c2fbfb3SApril Chin *              Information and Software Systems Research               *
147c2fbfb3SApril Chin *                            AT&T Research                             *
157c2fbfb3SApril Chin *                           Florham Park NJ                            *
167c2fbfb3SApril Chin *                                                                      *
177c2fbfb3SApril Chin *                 Glenn Fowler <gsf@research.att.com>                  *
187c2fbfb3SApril Chin *                                                                      *
197c2fbfb3SApril Chin ***********************************************************************/
207c2fbfb3SApril Chin #pragma prototyped
217c2fbfb3SApril Chin 
227c2fbfb3SApril Chin /*
237c2fbfb3SApril Chin  * bsd
247c2fbfb3SApril Chin  */
257c2fbfb3SApril Chin 
267c2fbfb3SApril Chin #define bsd_description \
277c2fbfb3SApril Chin 	"The BSD checksum."
287c2fbfb3SApril Chin #define bsd_options	0
297c2fbfb3SApril Chin #define bsd_match	"bsd|ucb"
307c2fbfb3SApril Chin #define bsd_open	long_open
317c2fbfb3SApril Chin #define bsd_init	long_init
327c2fbfb3SApril Chin #define bsd_done	short_done
337c2fbfb3SApril Chin #define bsd_print	long_print
347c2fbfb3SApril Chin #define bsd_data	long_data
357c2fbfb3SApril Chin #define bsd_scale	1024
367c2fbfb3SApril Chin 
377c2fbfb3SApril Chin static int
bsd_block(register Sum_t * p,const void * s,size_t n)387c2fbfb3SApril Chin bsd_block(register Sum_t* p, const void* s, size_t n)
397c2fbfb3SApril Chin {
407c2fbfb3SApril Chin 	register uint32_t	c = ((Integral_t*)p)->sum;
417c2fbfb3SApril Chin 	register unsigned char*	b = (unsigned char*)s;
427c2fbfb3SApril Chin 	register unsigned char*	e = b + n;
437c2fbfb3SApril Chin 
447c2fbfb3SApril Chin 	while (b < e)
457c2fbfb3SApril Chin 		c = ((c >> 1) + *b++ + ((c & 01) ? 0x8000 : 0)) & 0xffff;
467c2fbfb3SApril Chin 	((Integral_t*)p)->sum = c;
477c2fbfb3SApril Chin 	return 0;
487c2fbfb3SApril Chin }
49