windows-nt/Source/XPSP1/NT/inetsrv/iis/iisrearc/ul/drv/hashp.h
2020-09-26 16:20:57 +08:00

199 lines
4.3 KiB
C

/*++
Copyright (c) 1998-2001 Microsoft Corporation
Module Name:
hashp.h
Abstract:
The private definition of response cache hash table.
Author:
Alex Chen (alexch) 28-Mar-2001
Revision History:
--*/
#ifndef _HASHP_H_
#define _HASHP_H_
#include "hash.h"
#ifdef __cplusplus
extern "C" {
#endif
// Global Variables
extern ULONG g_UlHashTableBits;
extern ULONG g_UlHashTableSize;
extern ULONG g_UlHashTableMask;
extern ULONG g_UlHashIndexShift;
extern ULONG g_UlNumOfHashUriKeys;
// If we're using PagedPool for the hashtable, we must not access the
// hashtable at dispatch level. The ((void) 0) is because PAGED_CODE()
// expands to nothing in a free build and otherwise you get a compiler
// warning.
#define HASH_PAGED_CODE(pHashTable) \
do { \
if ((pHashTable)->PoolType == PagedPool) { \
PAGED_CODE(); \
((void) 0); /* for free build */ \
} \
} while (0)
#undef HASH_TEST
//
// Hash Table Bucket Stored UriKey definitions
//
#define INVALID_SLOT_INDEX ((LONG) (-1))
typedef struct _HASH_URIKEY
{
PUL_URI_CACHE_ENTRY pUriCacheEntry;
ULONG Hash; // Hash signature
} HASHURIKEY, *PHASHURIKEY;
//
// Hash Table Bucket definitions
//
typedef struct _HASH_BUCKET
{
RWSPINLOCK RWSpinLock;
PUL_URI_CACHE_ENTRY pUriCacheEntry;
ULONG_PTR Entries; // force alignment
// followed immediately by HASHURIKEY HashUriKey[g_UlNumOfHashUriKeys];
} HASHBUCKET, *PHASHBUCKET;
/***************************************************************************++
Routine Description:
Get the indexed bucket
Return Value:
--***************************************************************************/
__inline
PHASHBUCKET
UlpHashTableIndexedBucket(
IN PHASHTABLE pHashTable,
IN ULONG Index
)
{
ASSERT(Index < g_UlHashTableSize);
ASSERT(NULL != pHashTable->pBuckets);
PHASHBUCKET pBucket = (PHASHBUCKET) (((PBYTE) pHashTable->pBuckets)
+ (Index << g_UlHashIndexShift));
ASSERT((PBYTE) pBucket
< (PBYTE) pHashTable->pBuckets + pHashTable->NumberOfBytes);
return pBucket;
} // UlpHashTableIndexedBucket
/***************************************************************************++
Routine Description:
Retrieve the bucket associated with a URI_KEY
Return Value:
--***************************************************************************/
__inline
PHASHBUCKET
UlpHashTableBucketFromUriKey(
IN PHASHTABLE pHashTable,
IN PURI_KEY pUriKey
)
{
ASSERT(NULL != pUriKey);
ASSERT(HASH_INVALID_SIGNATURE != pUriKey->Hash);
return UlpHashTableIndexedBucket(
pHashTable,
pUriKey->Hash & g_UlHashTableMask
);
} // UlpHashTableBucketFromUriKey
/***************************************************************************++
Routine Description:
Get the address of the inline array of HASHURIKEYs at the end of
the HASHBUCKET
Return Value:
--***************************************************************************/
__inline
PHASHURIKEY
UlpHashTableUriKeyFromBucket(
IN PHASHBUCKET pBucket
)
{
return (PHASHURIKEY) ((PBYTE) pBucket + sizeof(HASHBUCKET));
}
/***************************************************************************++
Routine Description:
Compare two URI_KEYS that have identical hashes to see if the
URIs also match (case-insensitively).
(Hashes must have been computed with HashStringNoCaseW or
HashCharNoCaseW.)
Return Value:
--***************************************************************************/
__inline
BOOLEAN
UlpEqualUriKeys(
IN PURI_KEY pUriKey1,
IN PURI_KEY pUriKey2
)
{
ASSERT(pUriKey1->Hash == pUriKey2->Hash);
return (pUriKey1->Length == pUriKey2->Length
&& UlEqualUnicodeString(
pUriKey1->pUri,
pUriKey2->pUri,
pUriKey1->Length,
TRUE
)
);
}
#ifdef __cplusplus
}; // extern "C"
#endif
#endif // _HASHP_H_