The RtlDeleteRegistryValue routine removes the specified entry name and the associated values from the registry along the given relative path.
NTSTATUS
RtlDeleteRegistryValue(
IN ULONG RelativeTo,
IN PCWSTR Path,
IN PCWSTR ValueName
);
| Value | Meaning |
|---|---|
| RTL_REGISTRY_ABSOLUTE | |
| Path is an absolute registry path. | |
| RTL_REGISTRY_SERVICES | |
| Path is relative to \Registry\Machine\System\CurrentControlSet\Services. | |
| RTL_REGISTRY_CONTROL | |
| Path is relative to \Registry\Machine\System\CurrentControlSet\Control. | |
| RTL_REGISTRY_WINDOWS_NT | |
| Path is relative to \Registry\Machine\Software\Microsoft\ Windows NT\CurrentVersion. |
|
| RTL_REGISTRY_DEVICEMAP | |
| Path is relative to \Registry\Machine\Hardware\DeviceMap. | |
| RTL_REGISTRY_USER | |
| Path is relative to \Registry\User\CurrentUser. (For a system process, this is \Users\.Default.) | |
| RTL_REGISTRY_OPTIONAL | |
| Specifies that the key referenced by this parameter and the Path parameter are optional. | |
| RTL_REGISTRY_HANDLE | |
| Specifies that the Path parameter is actually a registry handle to use. This value is optional. | |
RtlDeleteRegistryValue returns STATUS_SUCCESS if the value entry was deleted.
Callers of RtlDeleteRegistryValue must be running at IRQL = PASSIVE_LEVEL.
Note that if RelativeTo is set to RTL_REGISTRY_HANDLE, the following occurs:
Declared in wdm.h and ntddk.h. Include wdm.h or ntddk.h.
RtlCheckRegistryKey, RtlQueryRegistryValues, RtlWriteRegistryValue, ZwEnumerateKey, ZwOpenKey