1219019Sgabor/* $FreeBSD$ */
2219019Sgabor/* $NetBSD: citrus_db_hash.c,v 1.5 2008/02/09 14:56:20 junyoung Exp $ */
3219019Sgabor
4219019Sgabor/*-
5219019Sgabor * Copyright (c)2003 Citrus Project,
6219019Sgabor * All rights reserved.
7219019Sgabor *
8219019Sgabor * Redistribution and use in source and binary forms, with or without
9219019Sgabor * modification, are permitted provided that the following conditions
10219019Sgabor * are met:
11219019Sgabor * 1. Redistributions of source code must retain the above copyright
12219019Sgabor *    notice, this list of conditions and the following disclaimer.
13219019Sgabor * 2. Redistributions in binary form must reproduce the above copyright
14219019Sgabor *    notice, this list of conditions and the following disclaimer in the
15219019Sgabor *    documentation and/or other materials provided with the distribution.
16219019Sgabor *
17219019Sgabor * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
18219019Sgabor * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19219019Sgabor * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20219019Sgabor * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
21219019Sgabor * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22219019Sgabor * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23219019Sgabor * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24219019Sgabor * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25219019Sgabor * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26219019Sgabor * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27219019Sgabor * SUCH DAMAGE.
28219019Sgabor */
29219019Sgabor
30219019Sgabor#include <sys/cdefs.h>
31219019Sgabor#include <sys/types.h>
32219019Sgabor
33219019Sgabor#include <assert.h>
34219019Sgabor#include <stdio.h>
35219019Sgabor#include <string.h>
36219019Sgabor
37219019Sgabor#include "citrus_namespace.h"
38219019Sgabor#include "citrus_types.h"
39219019Sgabor#include "citrus_bcs.h"
40219019Sgabor#include "citrus_region.h"
41219019Sgabor#include "citrus_db_hash.h"
42219019Sgabor
43219019Sgaboruint32_t
44219019Sgabor_citrus_db_hash_std(struct _region *r)
45219019Sgabor{
46219019Sgabor	const uint8_t *p;
47219019Sgabor	uint32_t hash, tmp;
48219019Sgabor	size_t i;
49219019Sgabor
50219019Sgabor	hash = 0;
51219019Sgabor	p = _region_head(r);
52219019Sgabor
53219019Sgabor	for (i = _region_size(r); i > 0; i--) {
54219019Sgabor		hash <<= 4;
55219019Sgabor		hash += _bcs_tolower(*p);
56219019Sgabor		tmp = hash & 0xF0000000;
57219019Sgabor		if (tmp != 0) {
58219019Sgabor			hash ^= tmp;
59219019Sgabor			hash ^= tmp >> 24;
60219019Sgabor		}
61219019Sgabor		p++;
62219019Sgabor	}
63219019Sgabor	return (hash);
64219019Sgabor}
65