[DDK]
[reactos.git] / include / ddk / ntddscsi.h
1 /*
2 * ntddscsi.h
3 *
4 * SCSI port 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 __NTDDSCSI_H
24 #define __NTDDSCSI_H
25
26 #ifdef __cplusplus
27 extern "C" {
28 #endif
29
30 #define DD_SCSI_DEVICE_NAME "\\Device\\ScsiPort"
31 #define DD_SCSI_DEVICE_NAME_U L"\\Device\\ScsiPort"
32
33 #define IOCTL_SCSI_BASE FILE_DEVICE_CONTROLLER
34
35 #define IOCTL_SCSI_FREE_DUMP_POINTERS \
36 CTL_CODE(IOCTL_SCSI_BASE, 0x0409, METHOD_BUFFERED, FILE_ANY_ACCESS)
37
38 #define IOCTL_SCSI_GET_INQUIRY_DATA \
39 CTL_CODE(IOCTL_SCSI_BASE, 0x0403, METHOD_BUFFERED, FILE_ANY_ACCESS)
40
41 #define IOCTL_SCSI_GET_CAPABILITIES \
42 CTL_CODE(IOCTL_SCSI_BASE, 0x0404, METHOD_BUFFERED, FILE_ANY_ACCESS)
43
44 #define IOCTL_SCSI_GET_ADDRESS \
45 CTL_CODE(IOCTL_SCSI_BASE, 0x0406, METHOD_BUFFERED, FILE_ANY_ACCESS)
46
47 #define IOCTL_SCSI_GET_DUMP_POINTERS \
48 CTL_CODE(IOCTL_SCSI_BASE, 0x0408, METHOD_BUFFERED, FILE_ANY_ACCESS)
49
50 #define IOCTL_SCSI_MINIPORT \
51 CTL_CODE(IOCTL_SCSI_BASE, 0x0402, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
52
53 #define IOCTL_SCSI_PASS_THROUGH \
54 CTL_CODE(IOCTL_SCSI_BASE, 0x0401, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
55
56 #define IOCTL_SCSI_PASS_THROUGH_DIRECT \
57 CTL_CODE(IOCTL_SCSI_BASE, 0x0405, METHOD_BUFFERED, FILE_READ_ACCESS | FILE_WRITE_ACCESS)
58
59 #define IOCTL_SCSI_RESCAN_BUS \
60 CTL_CODE(IOCTL_SCSI_BASE, 0x0407, METHOD_BUFFERED, FILE_ANY_ACCESS)
61
62
63 DEFINE_GUID(ScsiRawInterfaceGuid, \
64 0x53f56309L, 0xb6bf, 0x11d0, 0x94, 0xf2, 0x00, 0xa0, 0xc9, 0x1e, 0xfb, 0x8b);
65
66 DEFINE_GUID(WmiScsiAddressGuid, \
67 0x53f5630fL, 0xb6bf, 0x11d0, 0x94, 0xf2, 0x00, 0xa0, 0xc9, 0x1e, 0xfb, 0x8b);
68
69 typedef struct _SCSI_PASS_THROUGH {
70 USHORT Length;
71 UCHAR ScsiStatus;
72 UCHAR PathId;
73 UCHAR TargetId;
74 UCHAR Lun;
75 UCHAR CdbLength;
76 UCHAR SenseInfoLength;
77 UCHAR DataIn;
78 ULONG DataTransferLength;
79 ULONG TimeOutValue;
80 ULONG_PTR DataBufferOffset;
81 ULONG SenseInfoOffset;
82 UCHAR Cdb[16];
83 } SCSI_PASS_THROUGH, *PSCSI_PASS_THROUGH;
84
85 typedef struct _SCSI_PASS_THROUGH_DIRECT {
86 USHORT Length;
87 UCHAR ScsiStatus;
88 UCHAR PathId;
89 UCHAR TargetId;
90 UCHAR Lun;
91 UCHAR CdbLength;
92 UCHAR SenseInfoLength;
93 UCHAR DataIn;
94 ULONG DataTransferLength;
95 ULONG TimeOutValue;
96 PVOID DataBuffer;
97 ULONG SenseInfoOffset;
98 UCHAR Cdb[16];
99 } SCSI_PASS_THROUGH_DIRECT, *PSCSI_PASS_THROUGH_DIRECT;
100
101 typedef struct _SRB_IO_CONTROL {
102 ULONG HeaderLength;
103 UCHAR Signature[8];
104 ULONG Timeout;
105 ULONG ControlCode;
106 ULONG ReturnCode;
107 ULONG Length;
108 } SRB_IO_CONTROL, *PSRB_IO_CONTROL;
109
110 typedef struct _SCSI_ADDRESS {
111 ULONG Length;
112 UCHAR PortNumber;
113 UCHAR PathId;
114 UCHAR TargetId;
115 UCHAR Lun;
116 } SCSI_ADDRESS, *PSCSI_ADDRESS;
117
118 typedef struct _SCSI_BUS_DATA {
119 UCHAR NumberOfLogicalUnits;
120 UCHAR InitiatorBusId;
121 ULONG InquiryDataOffset;
122 }SCSI_BUS_DATA, *PSCSI_BUS_DATA;
123
124 typedef struct _SCSI_ADAPTER_BUS_INFO {
125 UCHAR NumberOfBuses;
126 SCSI_BUS_DATA BusData[1];
127 } SCSI_ADAPTER_BUS_INFO, *PSCSI_ADAPTER_BUS_INFO;
128
129 typedef struct _IO_SCSI_CAPABILITIES {
130 ULONG Length;
131 ULONG MaximumTransferLength;
132 ULONG MaximumPhysicalPages;
133 ULONG SupportedAsynchronousEvents;
134 ULONG AlignmentMask;
135 BOOLEAN TaggedQueuing;
136 BOOLEAN AdapterScansDown;
137 BOOLEAN AdapterUsesPio;
138 } IO_SCSI_CAPABILITIES, *PIO_SCSI_CAPABILITIES;
139
140 typedef struct _SCSI_INQUIRY_DATA {
141 UCHAR PathId;
142 UCHAR TargetId;
143 UCHAR Lun;
144 BOOLEAN DeviceClaimed;
145 ULONG InquiryDataLength;
146 ULONG NextInquiryDataOffset;
147 UCHAR InquiryData[1];
148 } SCSI_INQUIRY_DATA, *PSCSI_INQUIRY_DATA;
149
150 #define SCSI_IOCTL_DATA_OUT 0
151 #define SCSI_IOCTL_DATA_IN 1
152 #define SCSI_IOCTL_DATA_UNSPECIFIED 2
153
154 typedef struct _DUMP_POINTERS {
155 struct _ADAPTER_OBJECT *AdapterObject;
156 PVOID MappedRegisterBase;
157 PVOID DumpData;
158 PVOID CommonBufferVa;
159 LARGE_INTEGER CommonBufferPa;
160 ULONG CommonBufferSize;
161 BOOLEAN AllocateCommonBuffers;
162 BOOLEAN UseDiskDump;
163 UCHAR Spare1[2];
164 PVOID DeviceObject;
165 } DUMP_POINTERS, *PDUMP_POINTERS;
166
167 #ifdef __cplusplus
168 }
169 #endif
170
171 #endif /* __NTDDSCSI_H */