home *** CD-ROM | disk | FTP | other *** search
/ H4CK3R 14 / hacker14.iso / programacao / cwin / c.exe / $INSTDIR / include / ddk / ntddvol.h < prev    next >
Encoding:
C/C++ Source or Header  |  2003-12-15  |  4.0 KB  |  147 lines

  1. /*
  2.  * ntddvol.h
  3.  *
  4.  * Volume IOCTL interface.
  5.  *
  6.  * This file is part of the w32api package.
  7.  *
  8.  * Contributors:
  9.  *   Created by Casper S. Hornstrup <chorns@users.sourceforge.net>
  10.  *
  11.  * THIS SOFTWARE IS NOT COPYRIGHTED
  12.  *
  13.  * This source code is offered for use in the public domain. You may
  14.  * use, modify or distribute it freely.
  15.  *
  16.  * This code is distributed in the hope that it will be useful but
  17.  * WITHOUT ANY WARRANTY. ALL WARRANTIES, EXPRESS OR IMPLIED ARE HEREBY
  18.  * DISCLAIMED. This includes but is not limited to warranties of
  19.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  20.  *
  21.  */
  22.  
  23. #ifndef __NTDDVOL_H
  24. #define __NTDDVOL_H
  25.  
  26. #if __GNUC__ >=3
  27. #pragma GCC system_header
  28. #endif
  29.  
  30. #ifdef __cplusplus
  31. extern "C" {
  32. #endif
  33.  
  34. #pragma pack(push,4)
  35.  
  36. #include "ntddk.h"
  37.  
  38.  
  39. #define IOCTL_VOLUME_BASE                 ((ULONG) 'V')
  40.  
  41. #define IOCTL_VOLUME_LOGICAL_TO_PHYSICAL \
  42.   CTL_CODE(IOCTL_VOLUME_BASE, 8, METHOD_BUFFERED, FILE_ANY_ACCESS)
  43.  
  44. #define IOCTL_VOLUME_PHYSICAL_TO_LOGICAL \
  45.   CTL_CODE(IOCTL_VOLUME_BASE, 9, METHOD_BUFFERED, FILE_ANY_ACCESS)
  46.  
  47. #define IOCTL_VOLUME_READ_PLEX \
  48.   CTL_CODE(IOCTL_VOLUME_BASE, 11, METHOD_OUT_DIRECT, FILE_READ_ACCESS)
  49.  
  50. #define IOCTL_VOLUME_GET_VOLUME_DISK_EXTENTS \
  51.   CTL_CODE(IOCTL_VOLUME_BASE, 0, METHOD_BUFFERED, FILE_ANY_ACCESS)
  52.  
  53. #define IOCTL_VOLUME_IS_CLUSTERED \
  54.   CTL_CODE(IOCTL_VOLUME_BASE, 12, METHOD_BUFFERED, FILE_ANY_ACCESS)
  55.  
  56. #define IOCTL_VOLUME_QUERY_VOLUME_NUMBER \
  57.   CTL_CODE(IOCTL_VOLUME_BASE, 7, METHOD_BUFFERED, FILE_ANY_ACCESS)
  58.  
  59. #define IOCTL_VOLUME_IS_PARTITION \
  60.   CTL_CODE(IOCTL_VOLUME_BASE, 10, METHOD_BUFFERED, FILE_ANY_ACCESS)
  61.  
  62. #define IOCTL_VOLUME_SET_GPT_ATTRIBUTES \
  63.   CTL_CODE(IOCTL_VOLUME_BASE, 13, METHOD_BUFFERED, FILE_ANY_ACCESS)
  64.  
  65. #define IOCTL_VOLUME_GET_GPT_ATTRIBUTES \
  66.   CTL_CODE(IOCTL_VOLUME_BASE, 14, METHOD_BUFFERED, FILE_ANY_ACCESS)
  67.  
  68. #define IOCTL_VOLUME_SUPPORTS_ONLINE_OFFLINE \
  69.   CTL_CODE(IOCTL_VOLUME_BASE, 1, METHOD_BUFFERED, FILE_ANY_ACCESS)
  70.  
  71. #define IOCTL_VOLUME_ONLINE \
  72.   CTL_CODE(IOCTL_VOLUME_BASE, 2, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
  73.  
  74. #define IOCTL_VOLUME_OFFLINE \
  75.   CTL_CODE(IOCTL_VOLUME_BASE, 3, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
  76.  
  77. #define IOCTL_VOLUME_IS_OFFLINE \
  78.   CTL_CODE(IOCTL_VOLUME_BASE, 4, METHOD_BUFFERED, FILE_ANY_ACCESS)
  79.  
  80. #define IOCTL_VOLUME_IS_IO_CAPABLE \
  81.   CTL_CODE(IOCTL_VOLUME_BASE, 5, METHOD_BUFFERED, FILE_ANY_ACCESS)
  82.  
  83. #define IOCTL_VOLUME_QUERY_FAILOVER_SET \
  84.   CTL_CODE(IOCTL_VOLUME_BASE, 6, METHOD_BUFFERED, FILE_ANY_ACCESS)
  85.  
  86.  
  87. typedef struct _VOLUME_LOGICAL_OFFSET {
  88.   LONGLONG  LogicalOffset;
  89. } VOLUME_LOGICAL_OFFSET, *PVOLUME_LOGICAL_OFFSET;
  90.  
  91. typedef struct _VOLUME_PHYSICAL_OFFSET {
  92.   ULONG  DiskNumber;
  93.   LONGLONG  Offset;
  94. } VOLUME_PHYSICAL_OFFSET, *PVOLUME_PHYSICAL_OFFSET;
  95.  
  96. typedef struct _VOLUME_PHYSICAL_OFFSETS {
  97.   ULONG  NumberOfPhysicalOffsets;
  98.   VOLUME_PHYSICAL_OFFSET  PhysicalOffset[1];
  99. } VOLUME_PHYSICAL_OFFSETS, *PVOLUME_PHYSICAL_OFFSETS;
  100.  
  101. typedef struct _VOLUME_READ_PLEX_INPUT {
  102.   LARGE_INTEGER  ByteOffset;
  103.   ULONG  Length;
  104.   ULONG  PlexNumber;
  105. } VOLUME_READ_PLEX_INPUT, *PVOLUME_READ_PLEX_INPUT;
  106.  
  107. typedef struct _VOLUME_GET_GPT_ATTRIBUTES_INFORMATION {
  108.   ULONGLONG  GptAttributes;
  109. } VOLUME_GET_GPT_ATTRIBUTES_INFORMATION, *PVOLUME_GET_GPT_ATTRIBUTES_INFORMATION;
  110.  
  111. typedef struct _VOLUME_SET_GPT_ATTRIBUTES_INFORMATION {
  112.     ULONGLONG  GptAttributes;
  113.     BOOLEAN  RevertOnClose;
  114.     BOOLEAN  ApplyToAllConnectedVolumes;
  115.     USHORT  Reserved1;
  116.     ULONG  Reserved2;
  117. } VOLUME_SET_GPT_ATTRIBUTES_INFORMATION, *PVOLUME_SET_GPT_ATTRIBUTES_INFORMATION;
  118.  
  119. typedef struct _DISK_EXTENT {
  120.     ULONG  DiskNumber;
  121.     LARGE_INTEGER  StartingOffset;
  122.     LARGE_INTEGER  ExtentLength;
  123. } DISK_EXTENT, *PDISK_EXTENT;
  124.  
  125. typedef struct _VOLUME_DISK_EXTENTS {
  126.     ULONG  NumberOfDiskExtents;
  127.     DISK_EXTENT  Extents[1];
  128. } VOLUME_DISK_EXTENTS, *PVOLUME_DISK_EXTENTS;
  129.  
  130. typedef struct _VOLUME_NUMBER {
  131.     ULONG  VolumeNumber;
  132.     WCHAR  VolumeManagerName[8];
  133. } VOLUME_NUMBER, *PVOLUME_NUMBER;
  134.  
  135. typedef struct _VOLUME_FAILOVER_SET {
  136.     ULONG  NumberOfDisks;
  137.     ULONG  DiskNumbers[1];
  138. } VOLUME_FAILOVER_SET, *PVOLUME_FAILOVER_SET;
  139.  
  140. #pragma pack(pop)
  141.  
  142. #ifdef __cplusplus
  143. }
  144. #endif
  145.  
  146. #endif /* __NTDDVOL_H */
  147.