File: perfhash.c

package info (click to toggle)
nasm 3.01-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 23,660 kB
  • sloc: ansic: 129,101; asm: 40,471; perl: 8,238; sh: 4,146; makefile: 1,281; xml: 726; python: 582; lisp: 578; sed: 11
file content (25 lines) | stat: -rw-r--r-- 661 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/* SPDX-License-Identifier: BSD-2-Clause */
/* Copyright 2017 The NASM Authors - All Rights Reserved */

#include "perfhash.h"
#include "hashtbl.h"            /* For crc64i() */

int perfhash_find(const struct perfect_hash *hash, const char *str)
{
    uint32_t k1, k2;
    uint64_t crc;
    uint16_t ix;

    crc = crc64i(hash->crcinit, str);
    k1 = (uint32_t)crc & hash->hashmask;
    k2 = ((uint32_t)(crc >> 32) & hash->hashmask) + 1;

    ix = hash->hashvals[k1] + hash->hashvals[k2];

    if (ix >= hash->tbllen ||
        !hash->strings[ix] ||
        nasm_stricmp(str, hash->strings[ix]))
        return hash->errval;

    return hash->tbloffs + ix;
}