1da0c48c4Sopenharmony_ci/* Copyright (C) 2000-2019 Red Hat, Inc.
2da0c48c4Sopenharmony_ci   This file is part of elfutils.
3da0c48c4Sopenharmony_ci   Written by Srdan Milakovic <sm108@rice.edu>, 2019.
4da0c48c4Sopenharmony_ci   Derived from Ulrich Drepper <drepper@redhat.com>, 2000.
5da0c48c4Sopenharmony_ci
6da0c48c4Sopenharmony_ci   This file is free software; you can redistribute it and/or modify
7da0c48c4Sopenharmony_ci   it under the terms of either
8da0c48c4Sopenharmony_ci
9da0c48c4Sopenharmony_ci     * the GNU Lesser General Public License as published by the Free
10da0c48c4Sopenharmony_ci       Software Foundation; either version 3 of the License, or (at
11da0c48c4Sopenharmony_ci       your option) any later version
12da0c48c4Sopenharmony_ci
13da0c48c4Sopenharmony_ci   or
14da0c48c4Sopenharmony_ci
15da0c48c4Sopenharmony_ci     * the GNU General Public License as published by the Free
16da0c48c4Sopenharmony_ci       Software Foundation; either version 2 of the License, or (at
17da0c48c4Sopenharmony_ci       your option) any later version
18da0c48c4Sopenharmony_ci
19da0c48c4Sopenharmony_ci   or both in parallel, as here.
20da0c48c4Sopenharmony_ci
21da0c48c4Sopenharmony_ci   elfutils is distributed in the hope that it will be useful, but
22da0c48c4Sopenharmony_ci   WITHOUT ANY WARRANTY; without even the implied warranty of
23da0c48c4Sopenharmony_ci   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
24da0c48c4Sopenharmony_ci   General Public License for more details.
25da0c48c4Sopenharmony_ci
26da0c48c4Sopenharmony_ci   You should have received copies of the GNU General Public License and
27da0c48c4Sopenharmony_ci   the GNU Lesser General Public License along with this program.  If
28da0c48c4Sopenharmony_ci   not, see <http://www.gnu.org/licenses/>.  */
29da0c48c4Sopenharmony_ci
30da0c48c4Sopenharmony_ci#include <stddef.h>
31da0c48c4Sopenharmony_ci#include <pthread.h>
32da0c48c4Sopenharmony_ci#include "atomics.h"
33da0c48c4Sopenharmony_ci/* Before including this file the following macros must be defined:
34da0c48c4Sopenharmony_ci
35da0c48c4Sopenharmony_ci   NAME      name of the hash table structure.
36da0c48c4Sopenharmony_ci   TYPE      data type of the hash table entries
37da0c48c4Sopenharmony_ci
38da0c48c4Sopenharmony_ci   The following macros if present select features:
39da0c48c4Sopenharmony_ci
40da0c48c4Sopenharmony_ci   ITERATE   iterating over the table entries is possible
41da0c48c4Sopenharmony_ci   HASHTYPE  integer type for hash values, default unsigned long int
42da0c48c4Sopenharmony_ci */
43da0c48c4Sopenharmony_ci
44da0c48c4Sopenharmony_ci
45da0c48c4Sopenharmony_ci
46da0c48c4Sopenharmony_ci#ifndef HASHTYPE
47da0c48c4Sopenharmony_ci# define HASHTYPE unsigned long int
48da0c48c4Sopenharmony_ci#endif
49da0c48c4Sopenharmony_ci
50da0c48c4Sopenharmony_ci#ifndef RESIZE_BLOCK_SIZE
51da0c48c4Sopenharmony_ci# define RESIZE_BLOCK_SIZE 256
52da0c48c4Sopenharmony_ci#endif
53da0c48c4Sopenharmony_ci
54da0c48c4Sopenharmony_ci/* Defined separately.  */
55da0c48c4Sopenharmony_ciextern size_t next_prime (size_t seed);
56da0c48c4Sopenharmony_ci
57da0c48c4Sopenharmony_ci
58da0c48c4Sopenharmony_ci/* Table entry type.  */
59da0c48c4Sopenharmony_ci#define _DYNHASHCONENTTYPE(name)       \
60da0c48c4Sopenharmony_ci  typedef struct name##_ent         \
61da0c48c4Sopenharmony_ci  {                                 \
62da0c48c4Sopenharmony_ci    _Atomic(HASHTYPE) hashval;      \
63da0c48c4Sopenharmony_ci    atomic_uintptr_t val_ptr;       \
64da0c48c4Sopenharmony_ci  } name##_ent
65da0c48c4Sopenharmony_ci#define DYNHASHENTTYPE(name) _DYNHASHCONENTTYPE (name)
66da0c48c4Sopenharmony_ciDYNHASHENTTYPE (NAME);
67da0c48c4Sopenharmony_ci
68da0c48c4Sopenharmony_ci/* Type of the dynamic hash table data structure.  */
69da0c48c4Sopenharmony_ci#define _DYNHASHCONTYPE(name) \
70da0c48c4Sopenharmony_citypedef struct                                     \
71da0c48c4Sopenharmony_ci{                                                  \
72da0c48c4Sopenharmony_ci  size_t size;                                     \
73da0c48c4Sopenharmony_ci  size_t old_size;                                 \
74da0c48c4Sopenharmony_ci  atomic_size_t filled;                            \
75da0c48c4Sopenharmony_ci  name##_ent *table;                               \
76da0c48c4Sopenharmony_ci  name##_ent *old_table;                           \
77da0c48c4Sopenharmony_ci  atomic_size_t resizing_state;                    \
78da0c48c4Sopenharmony_ci  atomic_size_t next_init_block;                   \
79da0c48c4Sopenharmony_ci  atomic_size_t num_initialized_blocks;            \
80da0c48c4Sopenharmony_ci  atomic_size_t next_move_block;                   \
81da0c48c4Sopenharmony_ci  atomic_size_t num_moved_blocks;                  \
82da0c48c4Sopenharmony_ci  pthread_rwlock_t resize_rwl;                     \
83da0c48c4Sopenharmony_ci} name
84da0c48c4Sopenharmony_ci#define DYNHASHTYPE(name) _DYNHASHCONTYPE (name)
85da0c48c4Sopenharmony_ciDYNHASHTYPE (NAME);
86da0c48c4Sopenharmony_ci
87da0c48c4Sopenharmony_ci
88da0c48c4Sopenharmony_ci
89da0c48c4Sopenharmony_ci#define _FUNCTIONS(name)                                            \
90da0c48c4Sopenharmony_ci/* Initialize the hash table.  */                                   \
91da0c48c4Sopenharmony_ciextern int name##_init (name *htab, size_t init_size);              \
92da0c48c4Sopenharmony_ci                                                                    \
93da0c48c4Sopenharmony_ci/* Free resources allocated for hash table.  */                     \
94da0c48c4Sopenharmony_ciextern int name##_free (name *htab);                                \
95da0c48c4Sopenharmony_ci                                                                    \
96da0c48c4Sopenharmony_ci/* Insert new entry.  */                                            \
97da0c48c4Sopenharmony_ciextern int name##_insert (name *htab, HASHTYPE hval, TYPE data);    \
98da0c48c4Sopenharmony_ci                                                                    \
99da0c48c4Sopenharmony_ci/* Find entry in hash table.  */                                    \
100da0c48c4Sopenharmony_ciextern TYPE name##_find (name *htab, HASHTYPE hval);
101da0c48c4Sopenharmony_ci#define FUNCTIONS(name) _FUNCTIONS (name)
102da0c48c4Sopenharmony_ciFUNCTIONS (NAME)
103da0c48c4Sopenharmony_ci
104da0c48c4Sopenharmony_ci
105da0c48c4Sopenharmony_ci#ifndef NO_UNDEF
106da0c48c4Sopenharmony_ci# undef DYNHASHENTTYPE
107da0c48c4Sopenharmony_ci# undef DYNHASHTYPE
108da0c48c4Sopenharmony_ci# undef FUNCTIONS
109da0c48c4Sopenharmony_ci# undef _FUNCTIONS
110da0c48c4Sopenharmony_ci# undef XFUNCTIONS
111da0c48c4Sopenharmony_ci# undef _XFUNCTIONS
112da0c48c4Sopenharmony_ci# undef NAME
113da0c48c4Sopenharmony_ci# undef TYPE
114da0c48c4Sopenharmony_ci# undef ITERATE
115da0c48c4Sopenharmony_ci# undef COMPARE
116da0c48c4Sopenharmony_ci# undef FIRST
117da0c48c4Sopenharmony_ci# undef NEXT
118da0c48c4Sopenharmony_ci#endif
119