PostgreSQL Source Code
git master
|
#include "utils/dsa.h"
Go to the source code of this file.
Data Structures | |
struct | dshash_parameters |
struct | dshash_seq_status |
Macros | |
#define | DSHASH_HANDLE_INVALID ((dshash_table_handle) InvalidDsaPointer) |
Typedefs | |
typedef struct dshash_table | dshash_table |
typedef dsa_pointer | dshash_table_handle |
typedef uint32 | dshash_hash |
typedef int(* | dshash_compare_function) (const void *a, const void *b, size_t size, void *arg) |
typedef dshash_hash(* | dshash_hash_function) (const void *v, size_t size, void *arg) |
typedef void(* | dshash_copy_function) (void *dest, const void *src, size_t size, void *arg) |
typedef struct dshash_parameters | dshash_parameters |
typedef struct dshash_table_item | dshash_table_item |
typedef struct dshash_seq_status | dshash_seq_status |
Functions | |
dshash_table * | dshash_create (dsa_area *area, const dshash_parameters *params, void *arg) |
dshash_table * | dshash_attach (dsa_area *area, const dshash_parameters *params, dshash_table_handle handle, void *arg) |
void | dshash_detach (dshash_table *hash_table) |
dshash_table_handle | dshash_get_hash_table_handle (dshash_table *hash_table) |
void | dshash_destroy (dshash_table *hash_table) |
void * | dshash_find (dshash_table *hash_table, const void *key, bool exclusive) |
void * | dshash_find_or_insert (dshash_table *hash_table, const void *key, bool *found) |
bool | dshash_delete_key (dshash_table *hash_table, const void *key) |
void | dshash_delete_entry (dshash_table *hash_table, void *entry) |
void | dshash_release_lock (dshash_table *hash_table, void *entry) |
void | dshash_seq_init (dshash_seq_status *status, dshash_table *hash_table, bool exclusive) |
void * | dshash_seq_next (dshash_seq_status *status) |
void | dshash_seq_term (dshash_seq_status *status) |
void | dshash_delete_current (dshash_seq_status *status) |
int | dshash_memcmp (const void *a, const void *b, size_t size, void *arg) |
dshash_hash | dshash_memhash (const void *v, size_t size, void *arg) |
void | dshash_memcpy (void *dest, const void *src, size_t size, void *arg) |
int | dshash_strcmp (const void *a, const void *b, size_t size, void *arg) |
dshash_hash | dshash_strhash (const void *v, size_t size, void *arg) |
void | dshash_strcpy (void *dest, const void *src, size_t size, void *arg) |
void | dshash_dump (dshash_table *hash_table) |
#define DSHASH_HANDLE_INVALID ((dshash_table_handle) InvalidDsaPointer) |
typedef uint32 dshash_hash |
typedef dshash_hash(* dshash_hash_function) (const void *v, size_t size, void *arg) |
typedef struct dshash_parameters dshash_parameters |
typedef struct dshash_seq_status dshash_seq_status |
typedef struct dshash_table dshash_table |
typedef dsa_pointer dshash_table_handle |
typedef struct dshash_table_item dshash_table_item |
dshash_table* dshash_attach | ( | dsa_area * | area, |
const dshash_parameters * | params, | ||
dshash_table_handle | handle, | ||
void * | arg | ||
) |
Definition at line 270 of file dshash.c.
References dshash_table::area, dshash_table::arg, arg, Assert, dshash_table::buckets, dshash_table::control, dsa_get_address(), DSHASH_MAGIC, dshash_table_control::magic, palloc(), dshash_table::params, and dshash_table::size_log2.
Referenced by init_dsm_registry(), logicalrep_launcher_attach_dshmem(), pgstat_attach_shmem(), and SharedRecordTypmodRegistryAttach().
dshash_table* dshash_create | ( | dsa_area * | area, |
const dshash_parameters * | params, | ||
void * | arg | ||
) |
Definition at line 206 of file dshash.c.
References dshash_table::area, dshash_table::arg, arg, dshash_table_control::buckets, dshash_table::buckets, dshash_table::control, DSA_ALLOC_NO_OOM, DSA_ALLOC_ZERO, dsa_allocate, dsa_allocate_extended(), dsa_free(), dsa_get_address(), DsaPointerIsValid, DSHASH_MAGIC, DSHASH_NUM_PARTITIONS, DSHASH_NUM_PARTITIONS_LOG2, ereport, errcode(), errdetail(), errmsg(), ERROR, dshash_table_control::handle, i, dshash_table_control::lwlock_tranche_id, LWLockInitialize(), dshash_table_control::magic, palloc(), dshash_table::params, dshash_table_control::partitions, partitions, dshash_table_control::size_log2, dshash_table::size_log2, and dshash_parameters::tranche_id.
Referenced by init_dsm_registry(), logicalrep_launcher_attach_dshmem(), SharedRecordTypmodRegistryInit(), and StatsShmemInit().
void dshash_delete_current | ( | dshash_seq_status * | status | ) |
Definition at line 757 of file dshash.c.
References Assert, dshash_table::control, dshash_seq_status::curitem, delete_item(), DSHASH_MAGIC, dshash_seq_status::exclusive, dshash_table_item::hash, dshash_seq_status::hash_table, LW_EXCLUSIVE, LWLockHeldByMeInMode(), dshash_table_control::magic, PARTITION_FOR_HASH, PARTITION_LOCK, and PG_USED_FOR_ASSERTS_ONLY.
Referenced by pgstat_free_entry().
void dshash_delete_entry | ( | dshash_table * | hash_table, |
void * | entry | ||
) |
Definition at line 541 of file dshash.c.
References Assert, dshash_table::control, delete_item(), DSHASH_MAGIC, dshash_table_item::hash, ITEM_FROM_ENTRY, LW_EXCLUSIVE, LWLockHeldByMeInMode(), LWLockRelease(), dshash_table_control::magic, PARTITION_FOR_HASH, and PARTITION_LOCK.
Referenced by pgstat_free_entry().
bool dshash_delete_key | ( | dshash_table * | hash_table, |
const void * | key | ||
) |
Definition at line 503 of file dshash.c.
References Assert, ASSERT_NO_PARTITION_LOCKS_HELD_BY_ME, BUCKET_FOR_HASH, dshash_table::control, dshash_partition::count, delete_key_from_bucket(), DSHASH_MAGIC, ensure_valid_bucket_pointers(), hash(), hash_key(), sort-test::key, LW_EXCLUSIVE, LWLockAcquire(), LWLockRelease(), dshash_table_control::magic, PARTITION_FOR_HASH, PARTITION_LOCK, and dshash_table_control::partitions.
Referenced by ApplyLauncherForgetWorkerStartTime(), and find_or_make_matching_shared_tupledesc().
void dshash_destroy | ( | dshash_table * | hash_table | ) |
Definition at line 323 of file dshash.c.
References dshash_table::area, Assert, dshash_table_control::buckets, dshash_table::buckets, dshash_table::control, dsa_free(), dsa_get_address(), DsaPointerIsValid, DSHASH_MAGIC, ensure_valid_bucket_pointers(), dshash_table_control::handle, i, dshash_table_control::magic, dshash_table_item::next, NUM_BUCKETS, pfree(), size, and dshash_table::size_log2.
void dshash_detach | ( | dshash_table * | hash_table | ) |
Definition at line 307 of file dshash.c.
References ASSERT_NO_PARTITION_LOCKS_HELD_BY_ME, and pfree().
Referenced by pgstat_detach_shmem(), shared_record_typmod_registry_detach(), and StatsShmemInit().
void dshash_dump | ( | dshash_table * | hash_table | ) |
Definition at line 778 of file dshash.c.
References dshash_table::area, Assert, ASSERT_NO_PARTITION_LOCKS_HELD_BY_ME, BUCKET_INDEX_FOR_PARTITION, dshash_table::buckets, dshash_table::control, dshash_partition::count, dsa_get_address(), DsaPointerIsValid, DSHASH_MAGIC, DSHASH_NUM_PARTITIONS, ensure_valid_bucket_pointers(), fprintf, i, j, LW_SHARED, LWLockAcquire(), LWLockHeldByMe(), LWLockRelease(), dshash_table_control::magic, dshash_table_item::next, PARTITION_LOCK, dshash_table_control::partitions, and dshash_table::size_log2.
void* dshash_find | ( | dshash_table * | hash_table, |
const void * | key, | ||
bool | exclusive | ||
) |
Definition at line 390 of file dshash.c.
References Assert, ASSERT_NO_PARTITION_LOCKS_HELD_BY_ME, BUCKET_FOR_HASH, dshash_table::control, DSHASH_MAGIC, ensure_valid_bucket_pointers(), ENTRY_FROM_ITEM, find_in_bucket(), hash(), hash_key(), sort-test::key, LW_EXCLUSIVE, LW_SHARED, LWLockAcquire(), LWLockRelease(), dshash_table_control::magic, PARTITION_FOR_HASH, and PARTITION_LOCK.
Referenced by ApplyLauncherGetWorkerStartTime(), find_or_make_matching_shared_tupledesc(), lookup_rowtype_tupdesc_internal(), pgstat_drop_entry(), pgstat_get_entry_ref(), and pgstat_release_entry_ref().
void* dshash_find_or_insert | ( | dshash_table * | hash_table, |
const void * | key, | ||
bool * | found | ||
) |
Definition at line 433 of file dshash.c.
References Assert, ASSERT_NO_PARTITION_LOCKS_HELD_BY_ME, BUCKET_FOR_HASH, dshash_table::control, dshash_partition::count, DSHASH_MAGIC, ensure_valid_bucket_pointers(), ENTRY_FROM_ITEM, find_in_bucket(), dshash_table_item::hash, hash(), hash_key(), insert_into_bucket(), sort-test::key, LW_EXCLUSIVE, LWLockAcquire(), LWLockRelease(), dshash_table_control::magic, MAX_COUNT_PER_PARTITION, PARTITION_FOR_HASH, PARTITION_LOCK, dshash_table_control::partitions, resize(), and dshash_table::size_log2.
Referenced by ApplyLauncherSetWorkerStartTime(), find_or_make_matching_shared_tupledesc(), GetNamedDSMSegment(), pgstat_get_entry_ref(), pgstat_read_statsfile(), and SharedRecordTypmodRegistryInit().
dshash_table_handle dshash_get_hash_table_handle | ( | dshash_table * | hash_table | ) |
Definition at line 367 of file dshash.c.
References Assert, dshash_table::control, DSHASH_MAGIC, dshash_table_control::handle, and dshash_table_control::magic.
Referenced by init_dsm_registry(), logicalrep_launcher_attach_dshmem(), SharedRecordTypmodRegistryInit(), and StatsShmemInit().
int dshash_memcmp | ( | const void * | a, |
const void * | b, | ||
size_t | size, | ||
void * | arg | ||
) |
void dshash_memcpy | ( | void * | dest, |
const void * | src, | ||
size_t | size, | ||
void * | arg | ||
) |
dshash_hash dshash_memhash | ( | const void * | v, |
size_t | size, | ||
void * | arg | ||
) |
void dshash_release_lock | ( | dshash_table * | hash_table, |
void * | entry | ||
) |
Definition at line 558 of file dshash.c.
References Assert, dshash_table::control, DSHASH_MAGIC, dshash_table_item::hash, ITEM_FROM_ENTRY, LWLockRelease(), dshash_table_control::magic, PARTITION_FOR_HASH, and PARTITION_LOCK.
Referenced by ApplyLauncherGetWorkerStartTime(), ApplyLauncherSetWorkerStartTime(), find_or_make_matching_shared_tupledesc(), GetNamedDSMSegment(), lookup_rowtype_tupdesc_internal(), pgstat_acquire_entry_ref(), pgstat_drop_entry_internal(), pgstat_get_entry_ref(), pgstat_read_statsfile(), and SharedRecordTypmodRegistryInit().
void dshash_seq_init | ( | dshash_seq_status * | status, |
dshash_table * | hash_table, | ||
bool | exclusive | ||
) |
Definition at line 638 of file dshash.c.
References dshash_seq_status::curbucket, dshash_seq_status::curitem, dshash_seq_status::curpartition, dshash_seq_status::exclusive, dshash_seq_status::hash_table, InvalidDsaPointer, dshash_seq_status::nbuckets, and dshash_seq_status::pnextitem.
Referenced by pgstat_build_snapshot(), pgstat_drop_all_entries(), pgstat_drop_database_and_contents(), pgstat_reset_matching_entries(), and pgstat_write_statsfile().
void* dshash_seq_next | ( | dshash_seq_status * | status | ) |
Definition at line 657 of file dshash.c.
References dshash_table::area, Assert, ASSERT_NO_PARTITION_LOCKS_HELD_BY_ME, dshash_table::buckets, dshash_table::control, dshash_seq_status::curbucket, dshash_seq_status::curitem, dshash_seq_status::curpartition, dsa_get_address(), DsaPointerIsValid, ensure_valid_bucket_pointers(), ENTRY_FROM_ITEM, dshash_seq_status::exclusive, dshash_seq_status::hash_table, LW_EXCLUSIVE, LW_SHARED, LWLockAcquire(), LWLockHeldByMeInMode(), LWLockRelease(), dshash_seq_status::nbuckets, dshash_table_item::next, NUM_BUCKETS, PARTITION_FOR_BUCKET_INDEX, PARTITION_LOCK, dshash_seq_status::pnextitem, dshash_table_control::size_log2, and dshash_table::size_log2.
Referenced by pgstat_build_snapshot(), pgstat_drop_all_entries(), pgstat_drop_database_and_contents(), pgstat_reset_matching_entries(), and pgstat_write_statsfile().
void dshash_seq_term | ( | dshash_seq_status * | status | ) |
Definition at line 747 of file dshash.c.
References dshash_seq_status::curpartition, dshash_seq_status::hash_table, LWLockRelease(), and PARTITION_LOCK.
Referenced by pgstat_build_snapshot(), pgstat_drop_all_entries(), pgstat_drop_database_and_contents(), pgstat_reset_matching_entries(), and pgstat_write_statsfile().
int dshash_strcmp | ( | const void * | a, |
const void * | b, | ||
size_t | size, | ||
void * | arg | ||
) |
void dshash_strcpy | ( | void * | dest, |
const void * | src, | ||
size_t | size, | ||
void * | arg | ||
) |
dshash_hash dshash_strhash | ( | const void * | v, |
size_t | size, | ||
void * | arg | ||
) |