2020-09-30 16:53:55 +02:00

176 lines
6.8 KiB
C

/*++
Copyright (c) Microsoft Corporation. All rights reserved.
Module Name:
ntddsnap.h
Abstract:
This header file defines the public interface for the volume snapshot
driver.
Author:
Norbert P. Kusters (norbertk) 30-July-1999
Notes:
Revision History:
Adi Oltean (aoltean) 08-May-2001 - Added Application Info GUID for Client accessible snapshots
--*/
#ifndef _NTDDSNAP_
#define _NTDDSNAP_
#define VOLSNAPCONTROLTYPE ((ULONG) 'S') // ntifs
//
// The following IOCTLs are intended for proper volumes.
//
#define IOCTL_VOLSNAP_FLUSH_AND_HOLD_WRITES CTL_CODE(VOLSNAPCONTROLTYPE, 0, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS) // ntifs
#define IOCTL_VOLSNAP_RELEASE_WRITES CTL_CODE(VOLSNAPCONTROLTYPE, 1, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_PREPARE_FOR_SNAPSHOT CTL_CODE(VOLSNAPCONTROLTYPE, 2, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_ABORT_PREPARED_SNAPSHOT CTL_CODE(VOLSNAPCONTROLTYPE, 3, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_COMMIT_SNAPSHOT CTL_CODE(VOLSNAPCONTROLTYPE, 4, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_END_COMMIT_SNAPSHOT CTL_CODE(VOLSNAPCONTROLTYPE, 5, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_QUERY_NAMES_OF_SNAPSHOTS CTL_CODE(VOLSNAPCONTROLTYPE, 6, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_VOLSNAP_CLEAR_DIFF_AREA CTL_CODE(VOLSNAPCONTROLTYPE, 7, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_ADD_VOLUME_TO_DIFF_AREA CTL_CODE(VOLSNAPCONTROLTYPE, 8, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_QUERY_DIFF_AREA CTL_CODE(VOLSNAPCONTROLTYPE, 9, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_VOLSNAP_SET_MAX_DIFF_AREA_SIZE CTL_CODE(VOLSNAPCONTROLTYPE, 10, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_QUERY_DIFF_AREA_SIZES CTL_CODE(VOLSNAPCONTROLTYPE, 11, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_VOLSNAP_DELETE_OLDEST_SNAPSHOT CTL_CODE(VOLSNAPCONTROLTYPE, 12, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_AUTO_CLEANUP CTL_CODE(VOLSNAPCONTROLTYPE, 13, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_VOLSNAP_DELETE_SNAPSHOT CTL_CODE(VOLSNAPCONTROLTYPE, 14, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_QUERY_EPIC CTL_CODE(VOLSNAPCONTROLTYPE, 20, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_VOLSNAP_QUERY_OFFLINE CTL_CODE(VOLSNAPCONTROLTYPE, 21, METHOD_BUFFERED, FILE_READ_ACCESS)
//
// The following IOCTLs are intended for volume snapshots.
//
#define IOCTL_VOLSNAP_QUERY_ORIGINAL_VOLUME_NAME CTL_CODE(VOLSNAPCONTROLTYPE, 100, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_VOLSNAP_QUERY_CONFIG_INFO CTL_CODE(VOLSNAPCONTROLTYPE, 101, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_VOLSNAP_SET_APPLICATION_INFO CTL_CODE(VOLSNAPCONTROLTYPE, 102, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
#define IOCTL_VOLSNAP_QUERY_APPLICATION_INFO CTL_CODE(VOLSNAPCONTROLTYPE, 103, METHOD_BUFFERED, FILE_ANY_ACCESS)
//
// Input buffer for IOCTL_VOLSNAP_FLUSH_AND_HOLD_WRITES.
//
typedef struct _VOLSNAP_FLUSH_AND_HOLD_INPUT {
GUID InstanceId;
ULONG NumberOfVolumesToFlush;
USHORT SecondsToHoldFileSystemsTimeout; // 60 seconds recommended.
USHORT SecondsToHoldIrpsTimeout; // 10 seconds recommended.
} VOLSNAP_FLUSH_AND_HOLD_INPUT, *PVOLSNAP_FLUSH_AND_HOLD_INPUT;
//
// Input buffer for IOCTL_VOLSNAP_PREPARE_FOR_SNAPSHOT.
//
#define VOLSNAP_ATTRIBUTE_PERSISTENT (0x1)
#define VOLSNAP_ALL_ATTRIBUTES (0x1)
typedef struct _VOLSNAP_PREPARE_INFO {
ULONG Attributes;
ULONG Reserved; // Must be 0.
LONGLONG InitialDiffAreaAllocation; // 100 MB recommended.
} VOLSNAP_PREPARE_INFO, *PVOLSNAP_PREPARE_INFO;
//
// Output buffer for IOCTL_VOLSNAP_END_COMMIT_SNAPSHOT.
// Input buffer for IOCTL_VOLSNAP_ADD_VOLUME_TO_DIFF_AREA.
// Output buffer for IOCTL_VOLSNAP_QUERY_ORIGINAL_VOLUME_NAME.
// Input buffer for IOCTL_VOLSNAP_DELETE_SNAPSHOT.
//
typedef struct _VOLSNAP_NAME {
USHORT NameLength;
WCHAR Name[1];
} VOLSNAP_NAME, *PVOLSNAP_NAME;
//
// Input buffer for IOCTL_VOLSNAP_SET_DIFF_AREA.
// Output buffer for IOCTL_VOLSNAP_QUERY_NAMES_OF_SNAPSHOTS and
// IOCTL_VOLSNAP_QUERY_DIFF_AREA.
//
typedef struct _VOLSNAP_NAMES {
ULONG MultiSzLength;
WCHAR Names[1];
} VOLSNAP_NAMES, *PVOLSNAP_NAMES;
//
// Output buffero for IOCTL_VOLSNAP_QUERY_EPIC.
//
typedef struct _VOLSNAP_EPIC {
LONG EpicNumber;
} VOLSNAP_EPIC, *PVOLSNAP_EPIC;
//
// Output buffer for IOCTL_VOLSNAP_QUERY_DIFF_AREA_SIZES.
// Input buffer for IOCTL_VOLSNAP_SET_MAX_DIFF_AREA_SIZE.
//
typedef struct _VOLSNAP_DIFF_AREA_SIZES {
LONGLONG UsedVolumeSpace; // This value is ignored on a SET call.
LONGLONG AllocatedVolumeSpace;
LONGLONG MaximumVolumeSpace; // A value of 0 indicates no maximum.
} VOLSNAP_DIFF_AREA_SIZES, *PVOLSNAP_DIFF_AREA_SIZES;
//
// Output buffer for IOCTL_VOLSNAP_QUERY_CONFIG_INFO.
//
typedef struct _VOLSNAP_CONFIG_INFO {
ULONG Attributes;
ULONG Reserved;
LARGE_INTEGER SnapshotCreationTime;
} VOLSNAP_CONFIG_INFO, *PVOLSNAP_CONFIG_INFO;
//
// Input buffer for IOCTL_VOLSNAP_END_COMMIT_SNAPSHOT.
// Input buffer for IOCTL_VOLSNAP_SET_APPLICATION_INFO.
// Output buffer for IOCTL_VOLSNAP_QUERY_APPLICATION_INFO.
//
typedef struct _VOLSNAP_APPLICATION_INFO {
ULONG InformationLength;
UCHAR Information[1];
//
// It is highly recommended that the first 16 bytes from the
// Application Info should be a unique GUID indentifying the
// unique structure layout of the subsequent Application Info.
//
} VOLSNAP_APPLICATION_INFO, *PVOLSNAP_APPLICATION_INFO;
#ifdef DEFINE_GUID
//
// This GUID denotes the first 16 bytes from the Application
// Info structure associated with Client accessible snapshots.
//
// {E5DE7D45-49F2-40a4-817C-7DC82B72587F}
DEFINE_GUID(VOLSNAP_APPINFO_GUID_CLIENT_ACCESSIBLE,
0xe5de7d45, 0x49f2, 0x40a4, 0x81, 0x7c, 0x7d, 0xc8, 0x2b, 0x72, 0x58, 0x7f);
//
// This GUID corresponds to the format used to store the
// Hidden (Inaccessible) Snapshot Application Info.
//
// {F12142B4-9A4B-49af-A851-700C42FDC2BE}
DEFINE_GUID(VOLSNAP_APPINFO_GUID_SYSTEM_HIDDEN,
0xf12142b4, 0x9a4b, 0x49af, 0xa8, 0x51, 0x70, 0xc, 0x42, 0xfd, 0xc2, 0xbe);
#endif // DEFINE_GUID
#endif