ReactOS  0.4.15-dev-488-gc7a1924
cmlib.h
Go to the documentation of this file.
1 /*
2  * PROJECT: Registry manipulation library
3  * LICENSE: GPL - See COPYING in the top level directory
4  * COPYRIGHT: Copyright 2005 Filip Navara <navaraf@reactos.org>
5  * Copyright 2001 - 2005 Eric Kohl
6  */
7 
8 #ifndef _CMLIB_H_
9 #define _CMLIB_H_
10 
11 //
12 // Debug support switch
13 //
14 #define _CMLIB_DEBUG_ 1
15 
16 #ifdef CMLIB_HOST
17  #include <typedefs.h>
18  #include <stdio.h>
19  #include <string.h>
20 
21  // NTDDI_xxx versions we allude to in the library (see psdk/sdkddkver.h)
22  #define NTDDI_WS03SP4 0x05020400
23  #define NTDDI_WIN6 0x06000000
24  #define NTDDI_LONGHORN NTDDI_WIN6
25  #define NTDDI_VISTA NTDDI_WIN6
26  #define NTDDI_WIN7 0x06010000
27 
28  #define NTDDI_VERSION NTDDI_WS03SP4 // This is the ReactOS NT kernel version
29 
30  /* C_ASSERT Definition */
31  #define C_ASSERT(expr) extern char (*c_assert(void)) [(expr) ? 1 : -1]
32 
33  #ifdef _WIN32
34  #define strncasecmp _strnicmp
35  #define strcasecmp _stricmp
36  #endif // _WIN32
37 
38  #if (!defined(_MSC_VER) || (_MSC_VER < 1500))
39  #define _In_
40  #define _Out_
41  #define _Inout_
42  #define _In_opt_
43  #define _In_range_(x, y)
44  #endif
45 
46  #define __drv_aliasesMem
47 
48  #ifndef min
49  #define min(a, b) (((a) < (b)) ? (a) : (b))
50  #endif
51 
52  // #ifndef max
53  // #define max(a, b) (((a) > (b)) ? (a) : (b))
54  // #endif
55 
56  // Definitions copied from <ntstatus.h>
57  // We only want to include host headers, so we define them manually
58  #define STATUS_SUCCESS ((NTSTATUS)0x00000000)
59  #define STATUS_NOT_IMPLEMENTED ((NTSTATUS)0xC0000002)
60  #define STATUS_NO_MEMORY ((NTSTATUS)0xC0000017)
61  #define STATUS_INSUFFICIENT_RESOURCES ((NTSTATUS)0xC000009A)
62  #define STATUS_REGISTRY_CORRUPT ((NTSTATUS)0xC000014C)
63  #define STATUS_NOT_REGISTRY_FILE ((NTSTATUS)0xC000015C)
64  #define STATUS_REGISTRY_RECOVERED ((NTSTATUS)0x40000009)
65 
66  #define REG_OPTION_VOLATILE 1
67  #define OBJ_CASE_INSENSITIVE 0x00000040L
68  #define USHORT_MAX USHRT_MAX
69 
70  #define OBJ_NAME_PATH_SEPARATOR ((WCHAR)L'\\')
71  #define UNICODE_NULL ((WCHAR)0)
72 
73  VOID NTAPI
77 
78  LONG NTAPI
80  IN PCUNICODE_STRING String1,
83 
84  // FIXME: DECLSPEC_NORETURN
85  VOID
86  NTAPI
88  IN ULONG BugCheckCode,
89  IN ULONG_PTR BugCheckParameter1,
90  IN ULONG_PTR BugCheckParameter2,
91  IN ULONG_PTR BugCheckParameter3,
92  IN ULONG_PTR BugCheckParameter4);
93 
94  VOID NTAPI
96  OUT PLARGE_INTEGER CurrentTime);
97 
98  WCHAR NTAPI
100  IN WCHAR Source);
101 
102  VOID NTAPI
104  IN PRTL_BITMAP BitMapHeader,
105  IN PULONG BitMapBuffer,
106  IN ULONG SizeOfBitMap);
107 
108  ULONG NTAPI
110  IN PRTL_BITMAP BitMapHeader,
112  IN ULONG HintIndex);
113 
114  VOID NTAPI
115  RtlSetBits(
116  IN PRTL_BITMAP BitMapHeader,
118  IN ULONG NumberToSet);
119 
120  VOID NTAPI
122  IN PRTL_BITMAP BitMapHeader);
123 
124  #define RtlCheckBit(BMH,BP) (((((PLONG)(BMH)->Buffer)[(BP) / 32]) >> ((BP) % 32)) & 0x1)
125  #define UNREFERENCED_PARAMETER(P) {(P)=(P);}
126 
127  #define PKTHREAD PVOID
128  #define PKGUARDED_MUTEX PVOID
129  #define PERESOURCE PVOID
130  #define PFILE_OBJECT PVOID
131  #define PKEVENT PVOID
132  #define PWORK_QUEUE_ITEM PVOID
133  #define EX_PUSH_LOCK PULONG_PTR
134 
135  // Definitions copied from <ntifs.h>
136  // We only want to include host headers, so we define them manually
137 
139 
140  typedef struct _SECURITY_DESCRIPTOR_RELATIVE
141  {
142  UCHAR Revision;
143  UCHAR Sbz1;
145  ULONG Owner;
146  ULONG Group;
147  ULONG Sacl;
148  ULONG Dacl;
150 
151  #define CMLTRACE(x, ...)
152  #undef PAGED_CODE
153  #define PAGED_CODE()
154  #define REGISTRY_ERROR ((ULONG)0x00000051L)
155 #else
156  //
157  // Debug/Tracing support
158  //
159  #if _CMLIB_DEBUG_
160  #ifdef NEW_DEBUG_SYSTEM_IMPLEMENTED // enable when Debug Filters are implemented
161  #define CMLTRACE DbgPrintEx
162  #else
163  #define CMLTRACE(x, ...) \
164  if (x & CmlibTraceLevel) DbgPrint(__VA_ARGS__)
165  #endif
166  #else
167  #define CMLTRACE(x, ...) DPRINT(__VA_ARGS__)
168  #endif
169 
170  #include <ntdef.h>
171  #include <ntifs.h>
172  #include <bugcodes.h>
173  #undef PAGED_CODE
174  #define PAGED_CODE()
175 
176  /* Prevent inclusion of Windows headers through <wine/unicode.h> */
177  #define _WINDEF_
178  #define _WINBASE_
179  #define _WINNLS_
180 #endif
181 
182 
183 //
184 // These define the Debug Masks Supported
185 //
186 #define CMLIB_HCELL_DEBUG 0x01
187 
188 #ifndef ROUND_UP
189 #define ROUND_UP(a,b) ((((a)+(b)-1)/(b))*(b))
190 #define ROUND_DOWN(a,b) (((a)/(b))*(b))
191 #endif
192 
193 //
194 // PAGE_SIZE definition
195 //
196 #ifndef PAGE_SIZE
197 #if defined(TARGET_i386) || defined(TARGET_amd64) || defined(TARGET_arm)
198 #define PAGE_SIZE 0x1000
199 #else
200 #error Local PAGE_SIZE definition required when built as host
201 #endif
202 #endif
203 
204 #define TAG_CM ' MC'
205 #define TAG_KCB 'bkMC'
206 #define TAG_CMHIVE 'vHMC'
207 #define TAG_CMSD 'DSMC'
208 
209 #define CMAPI NTAPI
210 
211 #include <wine/unicode.h>
212 #include <wchar.h>
213 #include "hivedata.h"
214 #include "cmdata.h"
215 
216 #if defined(_TYPEDEFS_HOST_H) || defined(__FREELDR_H) // || defined(_BLDR_)
217 
218 #define PCM_KEY_SECURITY_CACHE_ENTRY PVOID
219 #define PCM_KEY_CONTROL_BLOCK PVOID
220 #define PCM_CELL_REMAP_BLOCK PVOID
221 
222 // See also ntoskrnl/include/internal/cm.h
223 #define CMP_SECURITY_HASH_LISTS 64
224 
225 // #endif // Commented out until one finds a way to properly include
226  // this header in freeldr and in ntoskrnl.
227 
228 //
229 // Use Count Log and Entry
230 //
231 typedef struct _CM_USE_COUNT_LOG_ENTRY
232 {
234  PVOID Stack[7];
236 
237 typedef struct _CM_USE_COUNT_LOG
238 {
239  USHORT Next;
240  USHORT Size;
243 
244 //
245 // Configuration Manager Hive Structure
246 //
247 typedef struct _CMHIVE
248 {
249  HHIVE Hive;
269  ULONG UseCount;
277  BOOLEAN Frozen;
286  ULONG Flags;
291 } CMHIVE, *PCMHIVE;
292 
293 #endif // See comment above
294 
295 typedef struct _HV_HIVE_CELL_PAIR
296 {
300 
301 #define STATIC_CELL_PAIR_COUNT 4
302 typedef struct _HV_TRACK_CELL_REF
303 {
310 
311 extern ULONG CmlibTraceLevel;
312 
313 //
314 // Hack since bigkeys are not yet supported
315 //
316 #define ASSERT_VALUE_BIG(h, s) \
317  ASSERTMSG("Big keys not supported!\n", !CmpIsKeyValueBig(h, s));
318 
319 //
320 // Returns whether or not this is a small valued key
321 //
322 static inline
323 BOOLEAN
325  IN ULONG Length)
326 {
327  /* Check if the length has the special size value */
329  {
330  /* It does, so this is a small key: return the real length */
331  *RealLength = Length - CM_KEY_VALUE_SPECIAL_SIZE;
332  return TRUE;
333  }
334 
335  /* This is not a small key, return the length we read */
336  *RealLength = Length;
337  return FALSE;
338 }
339 
340 //
341 // Returns whether or not this is a big valued key
342 //
343 static inline
344 BOOLEAN
346  IN ULONG Length)
347 {
348  /* Check if the hive is XP Beta 1 or newer */
349  if (Hive->Version >= HSYS_WHISTLER_BETA1)
350  {
351  /* Check if the key length is valid for a big value key */
353  {
354  /* Yes, this value is big */
355  return TRUE;
356  }
357  }
358 
359  /* Not a big value key */
360  return FALSE;
361 }
362 
363 /*
364  * Public Hive functions.
365  */
368  PHHIVE RegistryHive,
369  ULONG OperationType,
370  ULONG HiveFlags,
371  ULONG FileType,
372  PVOID HiveData OPTIONAL,
375  PFILE_SET_SIZE_ROUTINE FileSetSize,
376  PFILE_WRITE_ROUTINE FileWrite,
377  PFILE_READ_ROUTINE FileRead,
378  PFILE_FLUSH_ROUTINE FileFlush,
379  ULONG Cluster OPTIONAL,
381 
382 VOID CMAPI
383 HvFree(
384  PHHIVE RegistryHive);
385 
386 PVOID CMAPI
387 HvGetCell(
388  PHHIVE RegistryHive,
389  HCELL_INDEX CellOffset);
390 
391 #define HvReleaseCell(h, c) \
392 do { \
393  if ((h)->ReleaseCellRoutine) \
394  (h)->ReleaseCellRoutine(h, c); \
395 } while(0)
396 
397 LONG CMAPI
399  PHHIVE RegistryHive,
400  PVOID Cell);
401 
404  PHHIVE RegistryHive,
405  ULONG Size,
407  IN HCELL_INDEX Vicinity);
408 
411  IN PHHIVE RegistryHive,
412  IN HCELL_INDEX CellIndex
413 );
414 
417  PHHIVE RegistryHive,
418  HCELL_INDEX CellOffset,
419  ULONG Size);
420 
421 VOID CMAPI
422 HvFreeCell(
423  PHHIVE RegistryHive,
424  HCELL_INDEX CellOffset);
425 
428  PHHIVE RegistryHive,
429  HCELL_INDEX CellOffset,
430  BOOLEAN HoldingLock);
431 
434  IN PHHIVE Hive,
435  IN HCELL_INDEX Cell
436 );
437 
438 BOOLEAN
439 CMAPI
441  IN PHHIVE RegistryHive
442 );
443 
445 HvSyncHive(
446  PHHIVE RegistryHive);
447 
450  PHHIVE RegistryHive);
451 
452 BOOLEAN
453 CMAPI
455  IN OUT PHV_TRACK_CELL_REF CellRef,
456  IN PHHIVE Hive,
457  IN HCELL_INDEX Cell
458 );
459 
460 VOID
461 CMAPI
463  IN OUT PHV_TRACK_CELL_REF CellRef
464 );
465 
466 /*
467  * Private functions.
468  */
469 
470 PHBIN CMAPI
471 HvpAddBin(
472  PHHIVE RegistryHive,
473  ULONG Size,
475 
478  PHHIVE Hive);
479 
480 ULONG CMAPI
482  PHBASE_BLOCK HiveHeader);
483 
484 
485 /* Old-style Public "Cmlib" functions */
486 
489  PHHIVE Hive,
490  PCWSTR Name);
491 
492 VOID CMAPI
494  PHHIVE RegistryHive);
495 
496 
497 /* NT-style Public Cm functions */
498 
499 //
500 // Cell Index Routines
501 //
503 NTAPI
505  IN PHHIVE Hive,
507  IN PCUNICODE_STRING SearchName
508 );
509 
511 NTAPI
513  IN PHHIVE Hive,
515  IN ULONG Number
516 );
517 
518 ULONG
519 NTAPI
521  IN ULONG Hash,
523  IN BOOLEAN AllowSeparators
524 );
525 
526 BOOLEAN
527 NTAPI
529  IN PHHIVE Hive,
532 );
533 
534 BOOLEAN
535 NTAPI
537  IN PHHIVE Hive,
538  IN HCELL_INDEX ParentKey,
539  IN HCELL_INDEX TargetKey
540 );
541 
542 BOOLEAN
543 NTAPI
545  IN PHHIVE Hive,
546  HCELL_INDEX ParentKey,
547  HCELL_INDEX TargetKey
548 );
549 
550 
551 //
552 // Name Functions
553 //
554 LONG
555 NTAPI
557  IN PCUNICODE_STRING SearchName,
558  IN PWCHAR CompressedName,
559  IN ULONG NameLength
560 );
561 
562 USHORT
563 NTAPI
565  IN PHHIVE Hive,
567 );
568 
569 USHORT
570 NTAPI
572  IN PWCHAR Name,
573  IN ULONG Length
574 );
575 
576 USHORT
577 NTAPI
579  IN PHHIVE Hive,
582 );
583 
584 VOID
585 NTAPI
588  IN ULONG DestinationLength,
589  IN PWCHAR Source,
590  IN ULONG SourceLength
591 );
592 
593 BOOLEAN
594 NTAPI
596  IN PHHIVE Hive,
597  IN PCHILD_LIST ChildList,
599  OUT PULONG ChildIndex OPTIONAL,
600  OUT PHCELL_INDEX CellIndex
601 );
602 
603 
604 //
605 // Cell Value Routines
606 //
608 NTAPI
610  IN PHHIVE Hive,
611  IN PCM_KEY_NODE KeyNode,
613 );
614 
616 NTAPI
618  IN PHHIVE Hive,
621 );
622 
623 NTSTATUS
624 NTAPI
626  IN PHHIVE Hive,
627  IN PVOID Data,
628  IN ULONG DataSize,
629  IN HSTORAGE_TYPE StorageType,
630  IN HCELL_INDEX ValueCell,
631  OUT PHCELL_INDEX DataCell
632 );
633 
634 NTSTATUS
635 NTAPI
637  IN PHHIVE Hive,
638  IN HCELL_INDEX ValueCell,
639  IN ULONG Index,
640  IN HSTORAGE_TYPE StorageType,
641  IN OUT PCHILD_LIST ChildList
642 );
643 
644 BOOLEAN
645 NTAPI
647  IN PHHIVE Hive,
648  IN HCELL_INDEX Cell
649 );
650 
651 BOOLEAN
652 NTAPI
654  IN PHHIVE Hive,
656 );
657 
658 BOOLEAN
659 NTAPI
661  IN PHHIVE Hive,
662  IN HCELL_INDEX DataCell,
664 );
665 
666 NTSTATUS
667 NTAPI
669  IN PHHIVE Hive,
670  IN ULONG Index,
671  IN OUT PCHILD_LIST ChildList
672 );
673 
674 BOOLEAN
675 NTAPI
677  IN PHHIVE Hive,
679  OUT PULONG Length,
680  OUT PVOID *Buffer,
681  OUT PBOOLEAN BufferAllocated,
682  OUT PHCELL_INDEX CellToRelease
683 );
684 
685 NTSTATUS
686 NTAPI
688  IN PHHIVE SourceHive,
689  IN PCHILD_LIST SrcValueList,
690  IN PHHIVE DestinationHive,
691  IN OUT PCHILD_LIST DestValueList,
692  IN HSTORAGE_TYPE StorageType
693 );
694 
695 NTSTATUS
696 NTAPI
698  IN PHHIVE Hive,
699  IN HCELL_INDEX Cell,
701 );
702 
703 VOID
704 NTAPI
706  IN PHHIVE Hive,
707  IN HCELL_INDEX SecurityCell
708 );
709 
710 VOID
711 NTAPI
713  IN PHHIVE Hive,
714  IN HCELL_INDEX Cell
715 );
716 
717 /******************************************************************************/
718 
719 /* To be implemented by the user of this library */
720 PVOID
721 NTAPI
723  IN SIZE_T Size,
724  IN BOOLEAN Paged,
725  IN ULONG Tag
726 );
727 
728 VOID
729 NTAPI
730 CmpFree(
731  IN PVOID Ptr,
732  IN ULONG Quota
733 );
734 
735 #endif /* _CMLIB_H_ */
#define KeQuerySystemTime(t)
Definition: env_spec_w32.h:570
PKGUARDED_MUTEX ViewLock
Definition: cm.h:400
static int Hash(const char *)
Definition: reader.c:2257
BOOLEAN CMAPI HvIsCellDirty(IN PHHIVE Hive, IN HCELL_INDEX Cell)
Definition: hivecell.c:126
LIST_ENTRY TrustClassEntry
Definition: cm.h:432
const uint16_t * PCWSTR
Definition: typedefs.h:56
#define IN
Definition: typedefs.h:39
struct _CMHIVE * PCMHIVE
#define TRUE
Definition: types.h:120
PWORK_QUEUE_ITEM UnloadWorkItem
Definition: cm.h:423
PHBIN CMAPI HvpAddBin(PHHIVE RegistryHive, ULONG Size, HSTORAGE_TYPE Storage)
Definition: hivebin.c:12
struct _CM_USE_COUNT_LOG * PCM_USE_COUNT_LOG
VOID NTAPI CmpFree(IN PVOID Ptr, IN ULONG Quota)
Definition: registry.c:47
WORD * PSECURITY_DESCRIPTOR_CONTROL
Definition: lsa.idl:37
PVOID Stack[7]
Definition: cm.h:379
BOOLEAN(CMAPI * PFILE_SET_SIZE_ROUTINE)(struct _HHIVE *RegistryHive, ULONG FileType, ULONG FileSize, ULONG OldfileSize)
Definition: hivedata.h:241
ULONG NTAPI CmpComputeHashKey(IN ULONG Hash, IN PCUNICODE_STRING Name, IN BOOLEAN AllowSeparators)
Definition: cmindex.c:460
BOOLEAN CMAPI HvIsCellAllocated(IN PHHIVE RegistryHive, IN HCELL_INDEX CellIndex)
Definition: hivecell.c:43
LONG SecurityHitHint
Definition: cm.h:417
HCELL_INDEX CMAPI HvReallocateCell(PHHIVE RegistryHive, HCELL_INDEX CellOffset, ULONG Size)
Definition: hivecell.c:394
ULONG CMAPI HvpHiveHeaderChecksum(PHBASE_BLOCK HiveHeader)
Definition: hivesum.c:17
LIST_ENTRY NotifyList
Definition: cm.h:396
CM_USE_COUNT_LOG_ENTRY Log[32]
Definition: cm.h:386
NTSTATUS CMAPI HvInitialize(PHHIVE RegistryHive, ULONG OperationType, ULONG HiveFlags, ULONG FileType, PVOID HiveData OPTIONAL, PALLOCATE_ROUTINE Allocate, PFREE_ROUTINE Free, PFILE_SET_SIZE_ROUTINE FileSetSize, PFILE_WRITE_ROUTINE FileWrite, PFILE_READ_ROUTINE FileRead, PFILE_FLUSH_ROUTINE FileFlush, ULONG Cluster OPTIONAL, PCUNICODE_STRING FileName OPTIONAL)
Definition: hiveinit.c:522
NTSTATUS NTAPI CmpFreeKeyByCell(IN PHHIVE Hive, IN HCELL_INDEX Cell, IN BOOLEAN Unlink)
Definition: cmkeydel.c:159
BOOLEAN NTAPI CmpGetValueData(IN PHHIVE Hive, IN PCM_KEY_VALUE Value, OUT PULONG Length, OUT PVOID *Buffer, OUT PBOOLEAN BufferAllocated, OUT PHCELL_INDEX CellToRelease)
Definition: cmvalue.c:125
_Must_inspect_result_ _In_ PFSRTL_PER_STREAM_CONTEXT Ptr
Definition: fsrtlfuncs.h:898
ULONG SecurityCount
Definition: cm.h:415
USHORT Count
Definition: cmlib.h:304
PVOID NTAPI CmpAllocate(IN SIZE_T Size, IN BOOLEAN Paged, IN ULONG Tag)
Definition: registry.c:34
USHORT StaticCount
Definition: cmlib.h:308
LONG NTSTATUS
Definition: precomp.h:26
NTSYSAPI void WINAPI RtlInitializeBitMap(PRTL_BITMAP, PULONG, ULONG)
VOID NTAPI CmpFreeSecurityDescriptor(IN PHHIVE Hive, IN HCELL_INDEX Cell)
Definition: cmse.c:65
#define STATIC_CELL_PAIR_COUNT
Definition: cmlib.h:301
HCELL_INDEX NTAPI CmpFindSubKeyByNumber(IN PHHIVE Hive, IN PCM_KEY_NODE Node, IN ULONG Number)
Definition: cmindex.c:600
BOOLEAN Frozen
Definition: cm.h:422
CM_USE_COUNT_LOG UseCountLog
Definition: cm.h:429
BOOLEAN NTAPI CmpFindNameInList(IN PHHIVE Hive, IN PCHILD_LIST ChildList, IN PUNICODE_STRING Name, OUT PULONG ChildIndex OPTIONAL, OUT PHCELL_INDEX CellIndex)
Definition: cmname.c:149
VOID CMAPI HvReleaseFreeCellRefArray(IN OUT PHV_TRACK_CELL_REF CellRef)
Definition: hivecell.c:607
ULONG Flags
Definition: cm.h:431
ULONG FlushCount
Definition: cm.h:433
HCELL_INDEX CMAPI HvAllocateCell(PHHIVE RegistryHive, ULONG Size, HSTORAGE_TYPE Storage, IN HCELL_INDEX Vicinity)
NTSYSAPI ULONG WINAPI RtlFindSetBits(PCRTL_BITMAP, ULONG, ULONG)
ACPI_PHYSICAL_ADDRESS ACPI_SIZE BOOLEAN Warn BOOLEAN Physical UINT32 ACPI_TABLE_HEADER *OutTableHeader ACPI_TABLE_HEADER **OutTable ACPI_HANDLE UINT32 ACPI_WALK_CALLBACK ACPI_WALK_CALLBACK void void **ReturnValue UINT32 ACPI_BUFFER *RetPathPtr ACPI_OBJECT_HANDLER void *Data ACPI_OBJECT_HANDLER void **Data ACPI_STRING ACPI_OBJECT_LIST ACPI_BUFFER *ReturnObjectBuffer ACPI_DEVICE_INFO **ReturnBuffer ACPI_HANDLE Parent
Definition: acpixf.h:728
ULONG CmlibTraceLevel
Definition: cminit.c:12
EX_PUSH_LOCK SecurityLock
Definition: cm.h:405
uint16_t * PWCHAR
Definition: typedefs.h:55
#define CM_KEY_VALUE_SPECIAL_SIZE
Definition: cm.h:74
NTSTATUS CMAPI HvpCreateHiveFreeCellList(PHHIVE Hive)
Definition: hivecell.c:279
static int Unlink(const char **args)
Definition: vfdcmd.c:2549
PKTHREAD HiveLockOwner
Definition: cm.h:399
USHORT PinnedViews
Definition: cm.h:413
NTSYSAPI WCHAR NTAPI RtlUpcaseUnicodeChar(WCHAR Source)
NTSTATUS NTAPI CmpRemoveValueFromList(IN PHHIVE Hive, IN ULONG Index, IN OUT PCHILD_LIST ChildList)
Definition: cmvalue.c:320
_In_opt_ PALLOCATE_FUNCTION Allocate
Definition: exfuncs.h:814
BOOLEAN NTAPI CmpAddSubKey(IN PHHIVE Hive, IN HCELL_INDEX Parent, IN HCELL_INDEX Child)
Definition: cmindex.c:1467
NTSTATUS NTAPI CmpAddValueToList(IN PHHIVE Hive, IN HCELL_INDEX ValueCell, IN ULONG Index, IN HSTORAGE_TYPE StorageType, IN OUT PCHILD_LIST ChildList)
Definition: cmvalue.c:207
_In_ ULONG _In_ ULONG HintIndex
Definition: rtlfuncs.h:609
#define CMAPI
Definition: cmlib.h:209
#define CMP_SECURITY_HASH_LISTS
Definition: cm.h:79
IN UCHAR Value
Definition: halp.h:394
_In_opt_ PALLOCATE_FUNCTION _In_opt_ PFREE_FUNCTION Free
Definition: exfuncs.h:814
UNICODE_STRING FileUserName
Definition: cm.h:411
uint32_t ULONG_PTR
Definition: typedefs.h:64
BOOLEAN NTAPI CmpFreeValue(IN PHHIVE Hive, IN HCELL_INDEX Cell)
Definition: cmvalue.c:73
ERESOURCE * PERESOURCE
Definition: env_spec_w32.h:595
NTSTATUS(* NTAPI)(IN PFILE_FULL_EA_INFORMATION EaBuffer, IN ULONG EaLength, OUT PULONG ErrorOffset)
Definition: IoEaTest.cpp:117
_In_ ULONG NumberToFind
Definition: rtlfuncs.h:609
BOOLEAN(CMAPI * PFILE_READ_ROUTINE)(struct _HHIVE *RegistryHive, ULONG FileType, PULONG FileOffset, PVOID Buffer, SIZE_T BufferLength)
Definition: hivedata.h:223
BOOLEAN(CMAPI * PFILE_FLUSH_ROUTINE)(struct _HHIVE *RegistryHive, ULONG FileType, PLARGE_INTEGER FileOffset, ULONG Length)
Definition: hivedata.h:249
long LONG
Definition: pedump.c:60
_In_ const STRING _In_ BOOLEAN CaseInSensitive
Definition: rtlfuncs.h:2322
WORD SECURITY_DESCRIPTOR_CONTROL
Definition: lsa.idl:37
VOID NTAPI CmpCopyCompressedName(OUT PWCHAR Destination, IN ULONG DestinationLength, IN PWCHAR Source, IN ULONG SourceLength)
Definition: cmname.c:56
struct _HV_HIVE_CELL_PAIR * PHV_HIVE_CELL_PAIR
PCM_KEY_CONTROL_BLOCK RootKcb
Definition: cm.h:421
PVOID CMAPI HvGetCell(PHHIVE RegistryHive, HCELL_INDEX CellOffset)
Definition: hivecell.c:67
ULONG GrowOffset
Definition: cm.h:425
struct _SECURITY_DESCRIPTOR_RELATIVE * PISECURITY_DESCRIPTOR_RELATIVE
HANDLE FileHandles[HFILE_TYPE_MAX]
Definition: cm.h:395
BOOLEAN CMAPI HvWriteHive(PHHIVE RegistryHive)
Definition: hivewrt.c:285
static BOOLEAN CmpIsKeyValueSmall(OUT PULONG RealLength, IN ULONG Length)
Definition: cmlib.h:324
HCELL_INDEX Cell
Definition: cm.h:378
unsigned char BOOLEAN
UNICODE_STRING FileFullPath
Definition: cm.h:410
_Out_ _Inout_ POEM_STRING DestinationString
Definition: rtlfuncs.h:1868
ULONG SecurityCacheSize
Definition: cm.h:416
ULONG * PHCELL_INDEX
Definition: hivedata.h:80
HHIVE Hive
Definition: cm.h:394
VOID CMAPI HvFree(PHHIVE RegistryHive)
Definition: hiveinit.c:623
Definition: bufpool.h:45
#define HFILE_TYPE_MAX
Definition: hivedata.h:36
struct _HV_HIVE_CELL_PAIR HV_HIVE_CELL_PAIR
HV_HIVE_CELL_PAIR StaticArray[STATIC_CELL_PAIR_COUNT]
Definition: cmlib.h:307
PCELL_DATA NTAPI CmpValueToData(IN PHHIVE Hive, IN PCM_KEY_VALUE Value, OUT PULONG Length)
Definition: cmvalue.c:167
NTSTATUS NTAPI CmpSetValueDataNew(IN PHHIVE Hive, IN PVOID Data, IN ULONG DataSize, IN HSTORAGE_TYPE StorageType, IN HCELL_INDEX ValueCell, OUT PHCELL_INDEX DataCell)
Definition: cmvalue.c:289
struct _CM_USE_COUNT_LOG CM_USE_COUNT_LOG
BOOLEAN HiveIsLoading
Definition: cm.h:434
HCELL_INDEX NTAPI CmpFindValueByName(IN PHHIVE Hive, IN PCM_KEY_NODE KeyNode, IN PUNICODE_STRING Name)
Definition: cmvalue.c:99
USHORT NTAPI CmpCopyName(IN PHHIVE Hive, OUT PWCHAR Destination, IN PUNICODE_STRING Source)
Definition: cmname.c:21
BOOLEAN CMAPI CmCreateRootNode(PHHIVE Hive, PCWSTR Name)
Definition: cminit.c:17
__wchar_t WCHAR
Definition: xmlstorage.h:180
ULONG HCELL_INDEX
Definition: hivedata.h:80
BOOLEAN(CMAPI * PFILE_WRITE_ROUTINE)(struct _HHIVE *RegistryHive, ULONG FileType, PULONG FileOffset, PVOID Buffer, SIZE_T BufferLength)
Definition: hivedata.h:232
struct _CM_USE_COUNT_LOG_ENTRY CM_USE_COUNT_LOG_ENTRY
struct _CMHIVE CMHIVE
EX_PUSH_LOCK HiveLock
Definition: cm.h:398
Definition: cm.h:196
static const UCHAR Index[8]
Definition: usbohci.c:18
USHORT Next
Definition: cm.h:384
VOID(CMAPI * PFREE_ROUTINE)(PVOID Ptr, ULONG Quota)
Definition: hivedata.h:217
BOOLEAN CMAPI HvMarkCellDirty(PHHIVE RegistryHive, HCELL_INDEX CellOffset, BOOLEAN HoldingLock)
Definition: hivecell.c:100
_In_ PUNICODE_STRING _Inout_ PUNICODE_STRING Destination
Definition: rtlfuncs.h:2937
NTSTATUS NTAPI CmpCopyKeyValueList(IN PHHIVE SourceHive, IN PCHILD_LIST SrcValueList, IN PHHIVE DestinationHive, IN OUT PCHILD_LIST DestValueList, IN HSTORAGE_TYPE StorageType)
Definition: cmvalue.c:521
PERESOURCE FlusherLock
Definition: cm.h:404
_In_ ULONG _In_ ULONG _In_ ULONG Length
Definition: ntddpcm.h:101
* PFILE_OBJECT
Definition: iotypes.h:1957
Definition: cm.h:376
LIST_ENTRY HiveList
Definition: cm.h:397
BOOLEAN CMAPI HvSyncHive(PHHIVE RegistryHive)
Definition: hivewrt.c:243
VOID CMAPI HvFreeCell(PHHIVE RegistryHive, HCELL_INDEX CellOffset)
Definition: hivecell.c:441
BOOLEAN CMAPI HvTrackCellRef(IN OUT PHV_TRACK_CELL_REF CellRef, IN PHHIVE Hive, IN HCELL_INDEX Cell)
Definition: hivecell.c:527
HCELL_INDEX Cell
Definition: cmlib.h:298
unsigned char UCHAR
Definition: xmlstorage.h:181
char * PBOOLEAN
Definition: retypes.h:11
LONG CMAPI HvGetCellSize(PHHIVE RegistryHive, PVOID Cell)
_Out_ _Inout_ POEM_STRING _In_ PCUNICODE_STRING SourceString
Definition: rtlfuncs.h:1868
ULONG RtlCompareUnicodeString(PUNICODE_STRING s1, PUNICODE_STRING s2, BOOLEAN UpCase)
Definition: string_lib.cpp:31
USHORT Size
Definition: cm.h:385
LIST_ENTRY LRUViewListHead
Definition: cm.h:407
USHORT NTAPI CmpNameSize(IN PHHIVE Hive, IN PUNICODE_STRING Name)
Definition: cmname.c:74
EX_PUSH_LOCK WriterLock
Definition: cm.h:402
USHORT MappedViews
Definition: cm.h:412
Definition: typedefs.h:118
struct _SECURITY_DESCRIPTOR_RELATIVE SECURITY_DESCRIPTOR_RELATIVE
PKTHREAD ViewLockOwner
Definition: cm.h:401
IN PVOID IN PVOID IN USHORT IN USHORT Size
Definition: pci.h:361
_In_ ULONG StartingIndex
Definition: rtlfuncs.h:395
_In_opt_ PENTER_STATE_SYSTEM_HANDLER _In_opt_ PVOID _In_ LONG _In_opt_ LONG volatile * Number
Definition: ntpoapi.h:204
PKTHREAD WriterLockOwner
Definition: cm.h:403
ULONG UseCount
Definition: cm.h:414
PFILE_OBJECT FileObject
Definition: cm.h:409
struct _HV_TRACK_CELL_REF * PHV_TRACK_CELL_REF
LIST_ENTRY KnodeConvertListHead
Definition: cm.h:427
ULONG_PTR SIZE_T
Definition: typedefs.h:79
struct _CM_USE_COUNT_LOG_ENTRY * PCM_USE_COUNT_LOG_ENTRY
PCM_CELL_REMAP_BLOCK CellRemapArray
Definition: cm.h:428
PKTHREAD CreatorOwner
Definition: cm.h:435
struct _HV_TRACK_CELL_REF HV_TRACK_CELL_REF
SECURITY_DESCRIPTOR_CONTROL Control
Definition: setypes.h:785
unsigned short USHORT
Definition: pedump.c:61
LONG NTAPI CmpCompareCompressedName(IN PCUNICODE_STRING SearchName, IN PWCHAR CompressedName, IN ULONG NameLength)
Definition: cmname.c:109
HSTORAGE_TYPE
Definition: hivedata.h:100
NTSYSAPI void WINAPI RtlSetBits(PRTL_BITMAP, ULONG, ULONG)
#define CM_KEY_VALUE_BIG
Definition: cm.h:73
VOID NTAPI CmpRemoveSecurityCellList(IN PHHIVE Hive, IN HCELL_INDEX SecurityCell)
Definition: cmse.c:19
unsigned int * PULONG
Definition: retypes.h:1
HCELL_INDEX NTAPI CmpFindSubKeyByName(IN PHHIVE Hive, IN PCM_KEY_NODE Parent, IN PCUNICODE_STRING SearchName)
Definition: cmindex.c:683
PKTHREAD HiveSecurityLockOwner
Definition: cm.h:406
LIST_ENTRY PinViewListHead
Definition: cm.h:408
PKEVENT UnloadEvent
Definition: cm.h:420
NTSYSAPI void WINAPI RtlClearAllBits(PRTL_BITMAP)
static BOOLEAN CmpIsKeyValueBig(IN PHHIVE Hive, IN ULONG Length)
Definition: cmlib.h:345
CM_USE_COUNT_LOG LockHiveLog
Definition: cm.h:430
IN ULONG IN ULONG Tag
Definition: evtlib.h:159
BOOLEAN NTAPI CmpMarkIndexDirty(IN PHHIVE Hive, HCELL_INDEX ParentKey, HCELL_INDEX TargetKey)
_In_ const STRING * String2
Definition: rtlfuncs.h:2291
PVOID(CMAPI * PALLOCATE_ROUTINE)(SIZE_T Size, BOOLEAN Paged, ULONG Tag)
Definition: hivedata.h:210
#define HSYS_WHISTLER_BETA1
Definition: hivedata.h:59
#define OUT
Definition: typedefs.h:40
PCM_KEY_SECURITY_CACHE_ENTRY SecurityCache
Definition: cm.h:418
BOOLEAN NTAPI CmpRemoveSubKey(IN PHHIVE Hive, IN HCELL_INDEX ParentKey, IN HCELL_INDEX TargetKey)
Definition: cmindex.c:1696
unsigned int ULONG
Definition: retypes.h:1
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
ACPI_PHYSICAL_ADDRESS ACPI_SIZE BOOLEAN Warn BOOLEAN Physical UINT32 ACPI_TABLE_HEADER *OutTableHeader ACPI_TABLE_HEADER **OutTable ACPI_HANDLE UINT32 ACPI_WALK_CALLBACK ACPI_WALK_CALLBACK void void **ReturnValue UINT32 ACPI_BUFFER *RetPathPtr ACPI_OBJECT_HANDLER void *Data ACPI_OBJECT_HANDLER void **Data ACPI_STRING ACPI_OBJECT_LIST ACPI_BUFFER *ReturnObjectBuffer ACPI_DEVICE_INFO **ReturnBuffer ACPI_HANDLE ACPI_HANDLE Child
Definition: acpixf.h:728
VOID CMAPI CmPrepareHive(PHHIVE RegistryHive)
Definition: cminit.c:135
_In_ UINT _In_ UINT _In_ PNDIS_PACKET Source
Definition: ndis.h:3167
BOOLEAN NTAPI CmpFreeValueData(IN PHHIVE Hive, IN HCELL_INDEX DataCell, IN ULONG DataLength)
Definition: cmvalue.c:44
_Must_inspect_result_ _Out_writes_to_ DataLength PHIDP_DATA _Inout_ PULONG DataLength
Definition: hidpi.h:333
LIST_ENTRY SecurityHash[CMP_SECURITY_HASH_LISTS]
Definition: cm.h:419
USHORT NTAPI CmpCompressedNameSize(IN PWCHAR Name, IN ULONG Length)
Definition: cmname.c:95
static IStorage Storage
Definition: ole2.c:3548
_In_ NDIS_STATUS _In_ ULONG _In_ USHORT _In_opt_ PVOID _In_ ULONG DataSize
Definition: ndis.h:4751
LIST_ENTRY KcbConvertListHead
Definition: cm.h:426
VOID NTAPI KeBugCheckEx(_In_ ULONG BugCheckCode, _In_ ULONG_PTR BugCheckParameter1, _In_ ULONG_PTR BugCheckParameter2, _In_ ULONG_PTR BugCheckParameter3, _In_ ULONG_PTR BugCheckParameter4)
Definition: rtlcompat.c:108
Definition: cm.h:392
PHV_HIVE_CELL_PAIR CellArray
Definition: cmlib.h:306
Definition: dlist.c:348
BOOLEAN CMAPI HvHiveWillShrink(IN PHHIVE RegistryHive)
Definition: hivewrt.c:277
BOOLEAN NTAPI CmpMarkValueDataDirty(IN PHHIVE Hive, IN PCM_KEY_VALUE Value)
Definition: cmvalue.c:19
PULONG MinorVersion OPTIONAL
Definition: CrossNt.h:68
BOOLEAN GrowOnlyMode
Definition: cm.h:424