2024-06-09 09:22:22 +02:00
|
|
|
#ifndef MAP_H
|
|
|
|
#define MAP_H
|
|
|
|
|
|
|
|
#include "common.h"
|
|
|
|
|
|
|
|
/* To improve efficiency, each entry contains a common header
|
|
|
|
* RTL_HASHMAP_ENTRY*, reducing the need to store a seperate pointer to the
|
|
|
|
* entrys data. */
|
|
|
|
typedef struct _RTL_HASHMAP_ENTRY {
|
|
|
|
LIST_ENTRY entry;
|
|
|
|
UINT32 in_use;
|
|
|
|
CHAR object[];
|
|
|
|
} RTL_HASHMAP_ENTRY, *PRTL_HASHMAP_ENTRY;
|
|
|
|
|
2024-06-11 13:41:55 +02:00
|
|
|
typedef UINT32 (*HASH_FUNCTION)(_In_ UINT64 Key);
|
|
|
|
|
|
|
|
/* Struct1 being the node being compared to the value in Struct 2*/
|
|
|
|
typedef BOOLEAN (*COMPARE_FUNCTION)(_In_ PVOID Struct1, _In_ PVOID Struct2);
|
2024-06-09 09:22:22 +02:00
|
|
|
|
|
|
|
typedef struct _RTL_HASHMAP {
|
|
|
|
/* Array of RTL_HASHMAP_ENTRIES with length = bucket_count */
|
|
|
|
PRTL_HASHMAP_ENTRY buckets;
|
|
|
|
|
2024-06-13 14:53:37 +02:00
|
|
|
/* per bucket locks */
|
|
|
|
PKGUARDED_MUTEX locks;
|
|
|
|
|
2024-06-09 09:22:22 +02:00
|
|
|
/* Number of buckets, ideally a prime number */
|
|
|
|
UINT32 bucket_count;
|
|
|
|
|
|
|
|
/* Size of each custom object existing after the RTL_HASHMAP_ENTRY */
|
|
|
|
UINT32 object_size;
|
|
|
|
|
|
|
|
/* Pointer to caller-designated callback routines */
|
|
|
|
HASH_FUNCTION hash_function;
|
|
|
|
COMPARE_FUNCTION compare_function;
|
|
|
|
|
|
|
|
/* in the future bucket entries will use this */
|
|
|
|
LOOKASIDE_LIST_EX pool;
|
|
|
|
|
|
|
|
/* user allocated context */
|
2024-06-13 14:53:37 +02:00
|
|
|
PVOID context;
|
|
|
|
volatile UINT32 active;
|
2024-06-09 09:22:22 +02:00
|
|
|
|
|
|
|
} RTL_HASHMAP, *PRTL_HASHMAP;
|
|
|
|
|
2024-06-11 13:41:55 +02:00
|
|
|
typedef VOID (*ENUMERATE_HASHMAP)(_In_ PRTL_HASHMAP_ENTRY Entry,
|
|
|
|
_In_opt_ PVOID Context);
|
|
|
|
|
2024-06-13 14:53:37 +02:00
|
|
|
#define STATUS_INVALID_HASHMAP_INDEX -1
|
|
|
|
|
2024-06-09 09:22:22 +02:00
|
|
|
/* Hashmap is caller allocated */
|
|
|
|
NTSTATUS
|
2024-06-11 13:41:55 +02:00
|
|
|
RtlHashmapCreate(_In_ UINT32 BucketCount,
|
2024-06-09 09:22:22 +02:00
|
|
|
_In_ UINT32 EntryObjectSize,
|
|
|
|
_In_ HASH_FUNCTION HashFunction,
|
|
|
|
_In_ COMPARE_FUNCTION CompareFunction,
|
2024-06-13 14:53:37 +02:00
|
|
|
_In_opt_ PVOID Context,
|
2024-06-09 09:22:22 +02:00
|
|
|
_Out_ PRTL_HASHMAP Hashmap);
|
|
|
|
|
|
|
|
PVOID
|
2024-06-13 14:53:37 +02:00
|
|
|
RtlHashmapEntryInsert(_In_ PRTL_HASHMAP Hashmap, _In_ UINT32 Index);
|
2024-06-09 09:22:22 +02:00
|
|
|
|
|
|
|
PVOID
|
2024-06-11 13:41:55 +02:00
|
|
|
RtlHashmapEntryLookup(_In_ PRTL_HASHMAP Hashmap,
|
2024-06-13 14:53:37 +02:00
|
|
|
_In_ UINT32 Index,
|
2024-06-09 09:22:22 +02:00
|
|
|
_In_ PVOID Compare);
|
|
|
|
|
|
|
|
BOOLEAN
|
2024-06-11 13:41:55 +02:00
|
|
|
RtlHashmapEntryDelete(_Inout_ PRTL_HASHMAP Hashmap,
|
2024-06-13 14:53:37 +02:00
|
|
|
_In_ UINT32 Index,
|
|
|
|
_In_ PVOID Compare);
|
2024-06-09 09:22:22 +02:00
|
|
|
|
|
|
|
VOID
|
2024-06-11 13:41:55 +02:00
|
|
|
RtlHashmapEnumerate(_In_ PRTL_HASHMAP Hashmap,
|
2024-06-09 09:22:22 +02:00
|
|
|
_In_ ENUMERATE_HASHMAP EnumerationCallback,
|
|
|
|
_In_opt_ PVOID Context);
|
|
|
|
|
|
|
|
VOID
|
2024-06-11 13:41:55 +02:00
|
|
|
RtlHashmapDelete(_In_ PRTL_HASHMAP Hashmap);
|
|
|
|
|
2024-06-13 14:53:37 +02:00
|
|
|
INT32
|
|
|
|
RtlHashmapHashKeyAndAcquireBucket(_Inout_ PRTL_HASHMAP Hashmap,
|
|
|
|
_In_ UINT64 Key);
|
2024-06-11 13:41:55 +02:00
|
|
|
|
|
|
|
VOID
|
2024-06-13 14:53:37 +02:00
|
|
|
RtlHashmapReleaseBucket(_Inout_ PRTL_HASHMAP Hashmap, _In_ UINT32 Index);
|
2024-06-11 13:41:55 +02:00
|
|
|
|
|
|
|
FORCEINLINE
|
|
|
|
VOID
|
|
|
|
RtlHashmapSetInactive(_Inout_ PRTL_HASHMAP Hashmap)
|
|
|
|
{
|
|
|
|
Hashmap->active = FALSE;
|
|
|
|
}
|
|
|
|
|
2024-06-09 09:22:22 +02:00
|
|
|
#endif
|