mirror-ac/driver/containers/map.h

95 lines
2.7 KiB
C
Raw Normal View History

#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);
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;
/* 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;
} 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
/* Hashmap is caller allocated */
NTSTATUS
2024-06-11 13:41:55 +02:00
RtlHashmapCreate(_In_ UINT32 BucketCount,
_In_ UINT32 EntryObjectSize,
_In_ HASH_FUNCTION HashFunction,
_In_ COMPARE_FUNCTION CompareFunction,
2024-06-13 14:53:37 +02:00
_In_opt_ PVOID Context,
_Out_ PRTL_HASHMAP Hashmap);
PVOID
2024-06-13 14:53:37 +02:00
RtlHashmapEntryInsert(_In_ PRTL_HASHMAP Hashmap, _In_ UINT32 Index);
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,
_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);
VOID
2024-06-11 13:41:55 +02:00
RtlHashmapEnumerate(_In_ PRTL_HASHMAP Hashmap,
_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;
}
#endif