Jungo WinDriver  
Official Documentation
windrvr.h
Go to the documentation of this file.
1/* @JUNGO_COPYRIGHT@ */
2
3/*
4 * W i n D r i v e r
5 * =================
6 *
7 * FOR DETAILS ON THE WinDriver FUNCTIONS, PLEASE SEE THE WinDriver MANUAL
8 * OR INCLUDED HELP FILES.
9 *
10 * This file may not be distributed, it may only be used for development
11 * or evaluation purposes. The only exception is distribution to Linux.
12 * For details refer to \WinDriver\docs\license.txt.
13 *
14 * Web site: https://www.jungo.com
15 * Email: [email protected]
16 */
17#ifndef _WINDRVR_H_
18#define _WINDRVR_H_
19
20#if defined(__cplusplus)
21 extern "C" {
22#endif
23
24#include "wd_ver.h"
25
26#if defined(WIN32) && !defined(__MINGW32__)
27 #define DLLCALLCONV __stdcall
28 #if !defined(_SAL_VERSION)
29 #include <sal.h>
30 #endif
31#else
32 #define DLLCALLCONV
33
34 /* the following macros are part of SAL annotations macros in Windows and
35 are used in prototype of API functions, therefore, must be defined in
36 Unix as well */
37 #define _In_
38 #define _Inout_
39 #define _Out_
40 #define _Outptr_
41#endif
42
43#if defined(WIN32)
44 #define WD_DRIVER_NAME_PREFIX "\\\\.\\"
45#elif defined(LINUX)
46 #define WD_DRIVER_NAME_PREFIX "/dev/"
47#else
48 #define WD_DRIVER_NAME_PREFIX ""
49#endif
50
51#if !defined(WIN32)
52 #define __FUNCTION__ __func__
53#endif
54
55#define WD_DEFAULT_DRIVER_NAME_BASE "windrvr" WD_VER_ITOA
56#define WD_DEFAULT_DRIVER_NAME \
57 WD_DRIVER_NAME_PREFIX WD_DEFAULT_DRIVER_NAME_BASE
58
59#define WD_MAX_DRIVER_NAME_LENGTH 128
60#define WD_MAX_KP_NAME_LENGTH 128
61#define WD_VERSION_STR_LENGTH 128
62
63#if defined(WD_DRIVER_NAME_CHANGE)
103 const char* DLLCALLCONV WD_DriverName(const char *sName);
105 #define WD_DRIVER_NAME WD_DriverName(NULL)
106#else
107 #define WD_DRIVER_NAME WD_DEFAULT_DRIVER_NAME
108#endif
109
110#if defined (LOCAL_DEMO)
111#define WD_PROD_NAME "WinDriver (Local Demo)"
112#else
113#define WD_PROD_NAME "WinDriver"
114#endif
115
116#if defined(x86_64)
117#define KERNEL_64BIT
118#elif defined(ARM64)
119#define KERNEL_64BIT
120#elif defined(ARM)
121#elif defined(x86)
122#else
123#error No platform is defined. Please define either x86, x86_64, ARM or ARM64.
124#endif
125#if (defined(x86_64) && defined (ARM64)) || \
126 (defined(x86_64) && defined (ARM)) || \
127 (defined(x86_64) && defined (x86)) || \
128 (defined(ARM64) && defined (x86)) || \
129 (defined(ARM64) && defined (ARM)) || \
130 (defined(x86) && defined(ARM))
131#error Cannot have more than one platform defined in a WinDriver compilation.
132#endif
133
134
135#if defined(x86_64)
136 #define WD_CPU_SPEC " x86_64"
137#elif defined(ARM)
138 #define WD_CPU_SPEC " ARM"
139#elif defined(ARM64)
140 #define WD_CPU_SPEC " ARM64"
141#else
142 #define WD_CPU_SPEC " X86"
143#endif
144
145#if defined(WINNT)
146 #define WD_FILE_FORMAT " sys"
147#elif defined (APPLE)
148 #define WD_FILE_FORMAT " kext"
149#elif defined (LINUX)
150 #define WD_FILE_FORMAT " ko"
151#endif
152
153#if defined(KERNEL_64BIT)
154 #define WD_DATA_MODEL " 64bit"
155#else
156 #define WD_DATA_MODEL " 32bit"
157#endif
158
159#if defined(__KERNEL__) && defined(WINNT)
160 #if (NTDDI_VERSION >= NTDDI_WIN10_VB)
161 #define WD_VER_STR_SUFFIX ""
162 #else
163 #define WD_VER_STR_SUFFIX " for Windows 10 (Build 18632 and Lower)"
164 #endif
165#else
166 #define WD_VER_STR_SUFFIX ""
167#endif
168
169#define WD_VER_STR WD_PROD_NAME " v" WD_VERSION_STR \
170 " Jungo Connectivity (c) 1997 - " COPYRIGHTS_YEAR_STR \
171 " Build Date: " __DATE__ \
172 WD_CPU_SPEC WD_DATA_MODEL WD_FILE_FORMAT WD_VER_STR_SUFFIX
173
174#if !defined(POSIX) && defined(LINUX)
175 #define POSIX
176#endif
177
178#if !defined(UNIX) && defined(POSIX)
179 #define UNIX
180#endif
181
182#if !defined(WIN32) && defined(WINNT)
183 #define WIN32
184#endif
185
186#if !defined(WIN32) && !defined(UNIX) && !defined(APPLE)
187 #define WIN32
188#endif
189
190#if defined(_KERNEL_MODE) && !defined(KERNEL)
191 #define KERNEL
192#endif
193
194#if defined(KERNEL) && !defined(__KERNEL__)
195 #define __KERNEL__
196#endif
197
198#if defined(_KERNEL) && !defined(__KERNEL__)
199 #define __KERNEL__
200#endif
201
202#if defined( __KERNEL__) && !defined(_KERNEL)
203 #define _KERNEL
204#endif
205
206#if defined(LINUX) && defined(__x86_64__) && !defined(__KERNEL__)
207 /* This fixes binary compatibility with older version of GLIBC
208 * (64bit only) */
209 __asm__(".symver memcpy,memcpy@GLIBC_2.2.5");
210#endif
211
212#if defined(UNIX)
213
214
215 #if !defined(__P_TYPES__)
216 #define __P_TYPES__
217 #include <wd_types.h>
218
219 typedef void VOID;
220 typedef unsigned char UCHAR;
221 typedef unsigned short USHORT;
222 typedef unsigned int UINT;
223 #if !defined (APPLE_USB)
224 typedef unsigned long ULONG;
225 #endif
226 typedef u32 BOOL;
227 typedef void *PVOID;
228 typedef unsigned char *PBYTE;
229 typedef char CHAR;
230 typedef char *PCHAR;
231 typedef unsigned short *PWORD;
232 typedef u32 DWORD, *PDWORD;
233 typedef PVOID HANDLE;
234 #endif
235 #if !defined(__KERNEL__)
236 #include <string.h>
237 #include <ctype.h>
238 #include <stdlib.h>
239 #endif
240 #ifndef TRUE
241 #define TRUE 1
242 #endif
243 #ifndef FALSE
244 #define FALSE 0
245 #endif
246 #define __cdecl
247 #define WINAPI
248
249 #if defined(__KERNEL__)
250 #if defined(LINUX)
251 /* For _IO macros and for mapping Linux status codes
252 * to WD status codes */
253 #include <asm-generic/ioctl.h>
254 #include <asm-generic/errno.h>
255 #endif
256 #else
257 #include <unistd.h>
258 #if defined(LINUX)
259 #include <sys/ioctl.h> /* for BSD ioctl() */
260 #include <sys/mman.h>
261 #endif
262 #include <sys/types.h>
263 #include <sys/stat.h>
264 #include <fcntl.h>
265 #endif
266 typedef unsigned long long UINT64;
267 #if defined(APPLE)
268 #include <libkern/OSTypes.h>
269 #include <libkern/OSAtomic.h>
270 typedef UInt16 UINT16;
271 typedef UInt8 UINT8;
272 typedef UInt8 u8;
273 typedef UInt16 u16;
274 typedef UInt32 u32;
275 #include <IOKit/IOTypes.h>
276 #if defined(__KERNEL__)
277 typedef struct OSObject* FILEHANDLE;
278 typedef UInt32 PRCHANDLE;
279 #else
280 #include <IOKit/IOKitLib.h>
281 #endif
282 enum {
283 kWinDriverMethodSyncIoctl = 0,
284 kWinDriverNumOfMethods,
285 };
286 #if !defined(__KERNEL__)
287 #include <string.h>
288 #include <ctype.h>
289 #endif
290 #ifndef TRUE
291 #define TRUE true
292 #endif
293 #ifndef FALSE
294 #define FALSE false
295 #endif
296 #define __cdecl
297 #define WINAPI
298 #ifdef __LP64__
299 #define PTR2INT(value) ((UInt64)(value))
300 #else
301 #define PTR2INT(value) ((UInt32)(value))
302 #endif
303 #define MAC_UC_MAGIC_MASK 0xFF0000FF
304 #define MAC_UC_MAGIC_NUM 0x7E000041
305 #define MAC_UC_64BIT_APP 0x100
306#endif
307
308#elif defined(WIN32)
309 #if defined(__KERNEL__)
310 #if !defined (CMAKE_WD_BUILD)
311 int sprintf(char *buffer, const char *format, ...);
312 #endif
313 #else
314 #include <windows.h>
315 #include <winioctl.h>
316 #endif
317 #define stricmp _stricmp
318 typedef unsigned __int64 UINT64;
319#endif
320
321#if !defined(__KERNEL__)
322 #include <stdarg.h>
323 #if !defined(va_copy) && !defined(__va_copy)
324 #define va_copy(ap2,ap1) (ap2)=(ap1)
325 #endif
326 #if !defined(va_copy) && defined(__va_copy)
327 #define va_copy __va_copy
328 #endif
329#endif
330
331#ifndef WINAPI
332 #define WINAPI
333#endif
334
335#if !defined(_WINDEF_)
336 typedef unsigned char BYTE;
337 typedef unsigned short int WORD;
338#endif
339
340#if !defined(_BASETSD_H_)
341 typedef unsigned int UINT32;
342#endif
343
344#ifndef __KERNEL__
345/* Include inttypes.h for portable printf format specifiers
346 * (PRId64, PRIx32, etc.). It does not define a macro named PRI64 */
347#include <inttypes.h>
348#endif
349
351#if defined(UNIX)
352 #define PRI64 "ll"
353#elif defined(WIN32)
354 #define PRI64 "I64"
355#endif
356
358#if defined(KERNEL_64BIT)
359 #define KPRI PRI64
360 #if defined(WIN32)
361 #if defined(i386)
362 #define UPRI "z"
363 #else
364 #define UPRI KPRI
365 #endif
366 #else
367 #define UPRI "l"
368 #endif
369#else
370 #define KPRI ""
371 #define UPRI "l"
372#endif
373
374/*
375 * The KPTR is guaranteed to be the same size as a kernel-mode pointer
376 * The UPTR is guaranteed to be the same size as a user-mode pointer
377 */
378#if defined(KERNEL_64BIT)
379 typedef UINT64 KPTR;
380#else
381 typedef UINT32 KPTR;
382#endif
383
384#if defined(UNIX)
385 typedef unsigned long UPTR;
386#else
387 typedef size_t UPTR;
388#endif
389
392
393#include "windrvr_usb.h"
394
397typedef enum
398{
403 RP_BYTE = 10,
404 RP_WORD = 11,
405 RP_DWORD = 12,
406 WP_BYTE = 13,
407 WP_WORD = 14,
408 WP_DWORD = 15,
409 RP_QWORD = 16,
410 WP_QWORD = 17,
412 RP_SBYTE = 20,
413 RP_SWORD = 21,
415 WP_SBYTE = 23,
416 WP_SWORD = 24,
421 RM_BYTE = 30,
422 RM_WORD = 31,
423 RM_DWORD = 32,
424 WM_BYTE = 33,
425 WM_WORD = 34,
426 WM_DWORD = 35,
427 RM_QWORD = 36,
428 WM_QWORD = 37,
430 RM_SBYTE = 40,
431 RM_SWORD = 41,
433 WM_SBYTE = 43,
434 WM_SWORD = 44,
437 WM_SQWORD = 47
439
440enum { WD_DMA_PAGES = 256 };
441
442#ifndef DMA_BIT_MASK
443 #define DMA_BIT_MASK(n) (((n) == 64) ? ~0ULL : ((1ULL<<(n))-1))
444#endif
445
446typedef enum {
450 DMA_KBUF_BELOW_16M = 0x2,
453 DMA_LARGE_BUFFER = 0x4,
461 DMA_KERNEL_ONLY_MAP = 0x10,
464 DMA_FROM_DEVICE = 0x20,
480
491 DMA_TRANSACTION = 0x2000,
494 DMA_GPUDIRECT = 0x4000,
506
507#define DMA_ADDRESS_WIDTH_MASK 0x7f000000
508
509#define DMA_OPTIONS_ALL \
510 (DMA_KERNEL_BUFFER_ALLOC | DMA_KBUF_BELOW_16M | DMA_LARGE_BUFFER \
511 | DMA_ALLOW_CACHE | DMA_KERNEL_ONLY_MAP | DMA_FROM_DEVICE | DMA_TO_DEVICE \
512 | DMA_ALLOW_64BIT_ADDRESS | DMA_ALLOW_NO_HCARD | DMA_GET_EXISTING_BUF \
513 | DMA_RESERVED_MEM | DMA_KBUF_ALLOC_SPECIFY_ADDRESS_WIDTH \
514 | DMA_ADDRESS_WIDTH_MASK)
515
516#define DMA_DIRECTION_MASK DMA_TO_FROM_DEVICE
517
519#define DMA_READ_FROM_DEVICE DMA_FROM_DEVICE
520#define DMA_WRITE_TO_DEVICE DMA_TO_DEVICE
521
522#define DMA_OPTIONS_ADDRESS_WIDTH_SHIFT 24
527enum {
528 WD_MATCH_EXCLUDE = 0x1
529};
530
531#ifndef PAD_TO_64
532/* Use it to pad struct size to 64 bit, when using 32 on 64 bit applications */
533#if defined (i386) && defined(KERNEL_64BIT)
534 #define PAD_TO_64(pName) DWORD dwPad_##pName;
535#else
536 #define PAD_TO_64(pName)
537#endif
538#endif
540typedef struct
541{
542 DMA_ADDR pPhysicalAddr;
543 DWORD dwBytes;
544 PAD_TO_64(dwBytes)
547typedef void (DLLCALLCONV * DMA_TRANSACTION_CALLBACK)(PVOID pData);
549typedef struct
550{
551 DWORD hDma;
552 PAD_TO_64(hDma)
553
554 PVOID pUserAddr;
555 PAD_TO_64(pUserAddr)
557 KPTR pKernelAddr;
558 DWORD dwBytes;
559 DWORD dwOptions;
562 DWORD dwPages;
563 DWORD hCard;
566 /* Windows: The following 6 parameters are used for DMA transaction only */
567
568 DMA_TRANSACTION_CALLBACK DMATransactionCallback;
569 PAD_TO_64(DMATransactionCallback)
570
571 PVOID DMATransactionCallbackCtx;
572 PAD_TO_64(DMATransactionCallbackCtx)
574 DWORD dwAlignment;
575 DWORD dwMaxTransferSize;
576 DWORD dwTransferElementSize;
577 DWORD dwBytesTransferred;
581
582typedef enum {
583 /* KER_BUF_ALLOC_NON_CONTIG and KER_BUF_GET_EXISTING_BUF options are valid
584 * only as part of "WinDriver for Server" API and require
585 * "WinDriver for Server" license.
586 * @note "WinDriver for Server" APIs are included in WinDriver evaluation
587 * version. */
589 KER_BUF_ALLOC_CONTIG = 0x0002,
590 KER_BUF_ALLOC_CACHED = 0x0004,
594typedef struct
596 DWORD hKerBuf;
597 DWORD dwOptions;
598 UINT64 qwBytes;
599 KPTR pKernelAddr;
600 UPTR pUserAddr;
601 PAD_TO_64(pUserAddr)
604typedef struct
605{
606 KPTR pPort;
607 DWORD cmdTrans;
608 PAD_TO_64(cmdTrans)
610 /* Parameters used for string transfers: */
611 UINT64 u64Bytes;
612 DWORD fAutoinc;
614 DWORD dwOptions;
615 union
617 BYTE Byte;
618 WORD Word;
619 UINT32 Dword;
620 UINT64 Qword;
621 PVOID pBuffer;
622 } Data;
624
625enum {
626 INTERRUPT_LATCHED = 0x00,
629 INTERRUPT_CMD_COPY = 0x02,
638 INTERRUPT_MESSAGE = 0x10,
639 INTERRUPT_MESSAGE_X = 0x20,
643};
645typedef struct
647 DWORD hKernelPlugIn;
648 DWORD dwMessage;
649 PVOID pData;
651 DWORD dwResult;
652 PAD_TO_64(dwResult)
655typedef enum {
662typedef struct
663{
664 DWORD hInterrupt;
665 DWORD dwOptions;
667 WD_TRANSFER *Cmd;
668 PAD_TO_64(Cmd)
669 DWORD dwCmds;
670 PAD_TO_64(dwCmds)
672 /* For WD_IntEnable(): */
673 WD_KERNEL_PLUGIN_CALL kpCall;
674 DWORD fEnableOk;
677 /* For WD_IntWait() and WD_IntCount(): */
678 DWORD dwCounter;
679 DWORD dwLost;
680 DWORD fStopped;
681 DWORD dwLastMessage;
682 DWORD dwEnabledIntType;
692
693#define WD_ENABLED_INT_TYPE_MASK 0x3f
694#define WD_ENABLED_INT_TYPE_GET_ENABLED_INT_TYPE_BITS(dwEnabledIntType) \
695 (dwEnabledIntType & WD_ENABLED_INT_TYPE_MASK)
696#define WD_ENABLED_INT_TYPE_NUM_VECTORS_POSITION_BITS 20
698typedef struct
700 DWORD dwVer;
703
704#define WD_LICENSE_LENGTH 3072
705typedef struct
706{
707 CHAR cLicense[WD_LICENSE_LENGTH];
710enum
712 WD_BUS_USB = (int)0xfffffffe,
715 WD_BUS_EISA = 2,
717 WD_BUS_PLATFORM = 6,
719typedef DWORD WD_BUS_TYPE;
721typedef struct
722{
723 WD_BUS_TYPE dwBusType;
724 DWORD dwDomainNum;
726 DWORD dwBusNum;
727 DWORD dwSlotFunc;
731typedef enum
734 ITEM_INTERRUPT = 1,
736 ITEM_IO = 3,
738} ITEM_TYPE;
739
740typedef enum
741{
751typedef struct
753 DWORD item;
754 DWORD fNotSharable;
755 union I
756 {
758 struct Mem
760 PHYS_ADDR pPhysicalAddr;
761 UINT64 qwBytes;
762 KPTR pTransAddr;
766 UPTR pUserDirectAddr;
770 PAD_TO_64(pUserDirectAddr)
771 DWORD dwBar;
772 DWORD dwOptions;
774 KPTR pReserved;
776
778 struct IO
780 KPTR pAddr;
781 DWORD dwBytes;
782 DWORD dwBar;
783 } IO;
784
786 struct Int
787 {
788 DWORD dwInterrupt;
789 DWORD dwOptions;
794 DWORD hInterrupt;
796 DWORD dwReserved1;
797 KPTR pReserved2;
798 } Int;
799 WD_BUS Bus;
800 } I;
803enum { WD_CARD_ITEMS = 128 };
805typedef struct
807 DWORD dwItems;
808 PAD_TO_64(dwItems)
812typedef struct
813{
814 WD_CARD Card;
815 DWORD fCheckLockOnly;
817 DWORD hCard;
818 DWORD dwOptions;
819 CHAR cName[32];
820 CHAR cDescription[100];
822
823#define WD_PROCESS_NAME_LENGTH 128
824typedef struct
826 CHAR cProcessName[WD_PROCESS_NAME_LENGTH];
827 DWORD dwSubGroupID;
828 DWORD dwGroupID;
832 DWORD hIpc;
835typedef struct
837 WD_IPC_PROCESS procInfo;
838 DWORD dwOptions;
841enum { WD_IPC_MAX_PROCS = 0x40 };
843typedef struct
844{
845 DWORD hIpc;
848 DWORD dwNumProcs;
852enum
854 WD_IPC_UID_UNICAST = 0x1,
857};
859typedef struct
860{
861 DWORD hIpc;
862 DWORD dwOptions;
865 DWORD dwRecipientID;
866 DWORD dwMsgID;
867 UINT64 qwMsgData;
870typedef struct
872 DWORD hCard;
875 PAD_TO_64(Cmd)
876 DWORD dwCmds;
877 DWORD dwOptions;
880enum { WD_FORCE_CLEANUP = 0x1 };
882enum { WD_PCI_CARDS = 256 };
884typedef struct
886 DWORD dwDomain;
888 DWORD dwBus;
889 DWORD dwSlot;
890 DWORD dwFunction;
893typedef struct
894{
895 DWORD dwVendorId;
896 DWORD dwDeviceId;
897} WD_PCI_ID;
898
899typedef struct
900{
902 WD_PCI_ID searchId;
905 DWORD dwCards;
908 WD_PCI_ID cardId[WD_PCI_CARDS];
912 DWORD dwOptions;
914
916enum {WD_DEVICE_NAME_LENGTH = 256};
918typedef struct
919{
920 CHAR pcSearchName[WD_DEVICE_NAME_LENGTH];
923 PHYS_ADDR pSearchAddr;
925 DWORD dwCards;
926 CHAR pcDeviceNames[WD_PLATFORM_CARDS][WD_DEVICE_NAME_LENGTH];
928 KPTR pAddresses[WD_PLATFORM_CARDS];
932typedef enum {
939enum { WD_PCI_MAX_CAPS = 50 };
941enum { WD_PCI_CAP_ID_ALL = 0x0 };
943typedef struct
944{
945 DWORD dwCapId;
946 DWORD dwCapOffset;
948
949typedef enum {
954
955typedef struct
958 WD_PCI_SLOT pciSlot;
959 DWORD dwCapId;
961 DWORD dwOptions;
965 DWORD dwNumCaps;
966 WD_PCI_CAP pciCaps[WD_PCI_MAX_CAPS];
970typedef struct
972 WD_PCI_SLOT pciSlot;
973 DWORD dwNumVFs;
976typedef struct
978 WD_PCI_SLOT pciSlot;
979 WD_CARD Card;
982typedef struct
983{
984 PHYS_ADDR pPhysicalAddr;
988 CHAR pcDeviceName[WD_DEVICE_NAME_LENGTH];
989 WD_CARD Card;
992typedef enum
994 PCI_ACCESS_OK = 0,
996 PCI_BAD_BUS = 2,
1000typedef struct
1001{
1002 WD_PCI_SLOT pciSlot;
1003 PVOID pBuffer;
1004 PAD_TO_64(pBuffer)
1005
1006 DWORD dwOffset;
1007 DWORD dwBytes;
1009 DWORD fIsRead;
1010 DWORD dwResult;
1012
1013enum { SLEEP_BUSY = 0, SLEEP_NON_BUSY = 1 };
1014typedef struct
1016 DWORD dwMicroSeconds;
1018 DWORD dwOptions;
1021typedef enum
1024 D_ERROR = 1,
1026 D_INFO = 3,
1028} DEBUG_LEVEL;
1030typedef enum
1032 S_ALL = (int)0xffffffff,
1033 S_IO = 0x00000008,
1034 S_MEM = 0x00000010,
1035 S_INT = 0x00000020,
1036 S_PCI = 0x00000040,
1037 S_DMA = 0x00000080,
1038 S_MISC = 0x00000100,
1039 S_LICENSE = 0x00000200,
1040 S_PNP = 0x00001000,
1041 S_CARD_REG = 0x00002000,
1042 S_KER_DRV = 0x00004000,
1043 S_USB = 0x00008000,
1044 S_KER_PLUG = 0x00010000,
1045 S_EVENT = 0x00020000,
1046 S_IPC = 0x00040000,
1047 S_KER_BUF = 0x00080000,
1048 S_PLATFORM = 0x00100000,
1051typedef enum
1066typedef struct
1067{
1068 DWORD dwCmd;
1070 /* used for DEBUG_SET_FILTER */
1071 DWORD dwLevel;
1073 DWORD dwSection;
1075 DWORD dwLevelMessageBox;
1076 /* used for DEBUG_SET_BUFFER */
1077 DWORD dwBufferSize;
1079
1080#define DEBUG_USER_BUF_LEN 2048
1081typedef struct
1082{
1083 CHAR cBuffer[DEBUG_USER_BUF_LEN];
1086typedef struct
1088 CHAR pcBuffer[256];
1089 DWORD dwLevel;
1090 DWORD dwSection;
1093typedef struct
1095 DWORD hKernelPlugIn;
1096 CHAR cDriverName[WD_MAX_KP_NAME_LENGTH];
1097 CHAR cDriverPath[WD_MAX_KP_NAME_LENGTH];
1101 PAD_TO_64(hKernelPlugIn) /* 64 bit app has a 4 byte hole here */
1102 PVOID pOpenData;
1103 PAD_TO_64(pOpenData)
1105
1107typedef enum
1109 WD_DEVICE_PCI = 0x1,
1112
1113typedef struct
1115 union
1117 HANDLE hDevice;
1118 DWORD dwUniqueID;
1119 } h;
1120 PAD_TO_64(hDevice)
1121 PVOID pBuf;
1123 DWORD dwBytes;
1124 DWORD dwProperty;
1125 DWORD dwOptions;
1126 PAD_TO_64(dwOptions)
1129typedef enum {
1131 WD_STATUS_INVALID_WD_HANDLE = (int)0xffffffff,
1133 WD_WINDRIVER_STATUS_ERROR = 0x20000000L,
1135 WD_INVALID_HANDLE = 0x20000001L,
1148 WD_READ_WRITE_CONFLICT = 0x20000003L,
1151 WD_ZERO_PACKET_SIZE = 0x20000004L,
1153 WD_INSUFFICIENT_RESOURCES = 0x20000005L,
1158 WD_UNKNOWN_PIPE_TYPE = 0x20000006L,
1159 WD_SYSTEM_INTERNAL_ERROR = 0x20000007L,
1161 WD_DATA_MISMATCH = 0x20000008L,
1165 WD_NO_LICENSE = 0x20000009L,
1171 WD_NOT_IMPLEMENTED = 0x2000000aL,
1176 WD_KERPLUG_FAILURE = 0x2000000bL,
1180 WD_FAILED_ENABLING_INTERRUPT = 0x2000000cL,
1191 WD_INTERRUPT_NOT_ENABLED = 0x2000000dL,
1198 WD_RESOURCE_OVERLAP = 0x2000000eL,
1204 WD_DEVICE_NOT_FOUND = 0x2000000fL,
1207 WD_WRONG_UNIQUE_ID = 0x20000010L,
1210 WD_OPERATION_ALREADY_DONE = 0x20000011L,
1216 WD_USB_DESCRIPTOR_ERROR = 0x20000012L,
1224 WD_SET_CONFIGURATION_FAILED = 0x20000013L,
1229 WD_CANT_OBTAIN_PDO = 0x20000014L,
1230 WD_TIME_OUT_EXPIRED = 0x20000015L,
1234 WD_IRP_CANCELED = 0x20000016L,
1237 WD_FAILED_USER_MAPPING = 0x20000017L,
1246 WD_FAILED_KERNEL_MAPPING = 0x20000018L,
1256 WD_NO_RESOURCES_ON_DEVICE = 0x20000019L,
1266 WD_NO_EVENTS = 0x2000001aL,
1270 WD_INVALID_PARAMETER = 0x2000001bL,
1274 WD_INCORRECT_VERSION = 0x2000001cL,
1280 WD_TRY_AGAIN = 0x2000001dL,
1284 WD_WINDRIVER_NOT_FOUND = 0x2000001eL,
1285 WD_INVALID_IOCTL = 0x2000001fL,
1290 WD_OPERATION_FAILED = 0x20000020L,
1294 WD_INVALID_32BIT_APP = 0x20000021L,
1300 WD_TOO_MANY_HANDLES = 0x20000022L,
1306 WD_NO_DEVICE_OBJECT = 0x20000023L,
1319 WD_MORE_PROCESSING_REQUIRED = (int)0xC0000016L,
1327 /* The following status codes are returned by USBD:
1328 USBD status types: */
1332 WD_USBD_STATUS_ERROR = (int)0x80000000L,
1333 WD_USBD_STATUS_HALTED = (int)0xC0000000L,
1335 /* USBD status codes: */
1336 /* @note The following status codes are comprised of one of the status
1337 * types above and an error code [i.e. 0xXYYYYYYYL - where: X = status type;
1338 * YYYYYYY = error code].
1339 * The same error codes may also appear with one of the other status types
1340 * as well. */
1341
1342 /* HC (Host Controller) status codes.
1343 @note These status codes use the WD_USBD_STATUS_HALTED status type]: */
1344 WD_USBD_STATUS_CRC = (int)0xC0000001L,
1346 WD_USBD_STATUS_BTSTUFF = (int)0xC0000002L,
1352 WD_USBD_STATUS_STALL_PID = (int)0xC0000004L,
1354 WD_USBD_STATUS_DEV_NOT_RESPONDING = (int)0xC0000005L,
1357 WD_USBD_STATUS_PID_CHECK_FAILURE = (int)0xC0000006L,
1360 WD_USBD_STATUS_UNEXPECTED_PID = (int)0xC0000007L,
1363 WD_USBD_STATUS_DATA_OVERRUN = (int)0xC0000008L,
1366 WD_USBD_STATUS_DATA_UNDERRUN = (int)0xC0000009L,
1369 WD_USBD_STATUS_RESERVED1 = (int)0xC000000AL,
1371 WD_USBD_STATUS_RESERVED2 = (int)0xC000000BL,
1373 WD_USBD_STATUS_BUFFER_OVERRUN = (int)0xC000000CL,
1376 WD_USBD_STATUS_BUFFER_UNDERRUN = (int)0xC000000DL,
1379 WD_USBD_STATUS_NOT_ACCESSED = (int)0xC000000FL,
1381 WD_USBD_STATUS_FIFO = (int)0xC0000010L,
1384#if defined(WIN32)
1385 WD_USBD_STATUS_XACT_ERROR = (int)0xC0000011L,
1391 WD_USBD_STATUS_BABBLE_DETECTED = (int)0xC0000012L,
1394 WD_USBD_STATUS_DATA_BUFFER_ERROR = (int)0xC0000013L,
1397#endif
1399 WD_USBD_STATUS_CANCELED = (int)0xC0010000L,
1405 WD_USBD_STATUS_ENDPOINT_HALTED = (int)0xC0000030L,
1406
1407 /* Software status codes
1408 @note The following status codes have only the error bit set: */
1409 WD_USBD_STATUS_NO_MEMORY = (int)0x80000100L,
1412 WD_USBD_STATUS_INVALID_URB_FUNCTION = (int)0x80000200L,
1415 WD_USBD_STATUS_INVALID_PARAMETER = (int)0x80000300L,
1421 WD_USBD_STATUS_ERROR_BUSY = (int)0x80000400L,
1422
1427 WD_USBD_STATUS_REQUEST_FAILED = (int)0x80000500L,
1429 WD_USBD_STATUS_INVALID_PIPE_HANDLE = (int)0x80000600L,
1434
1436 WD_USBD_STATUS_INTERNAL_HC_ERROR = (int)0x80000800L,
1440 WD_USBD_STATUS_ERROR_SHORT_TRANSFER = (int)0x80000900L,
1441
1445 WD_USBD_STATUS_BAD_START_FRAME = (int)0xC0000A00L,
1449 WD_USBD_STATUS_ISOCH_REQUEST_FAILED = (int)0xC0000B00L,
1453 WD_USBD_STATUS_FRAME_CONTROL_OWNED = (int)0xC0000C00L,
1454
1458
1459#if defined(WIN32)
1460 ,
1461 /* Additional USB 2.0 software error codes added for USB 2.0: */
1462 WD_USBD_STATUS_NOT_SUPPORTED = (int)0xC0000E00L,
1475 WD_USBD_STATUS_SET_CONFIG_FAILED = (int)0xC0002000L,
1492 WD_USBD_STATUS_TIMEOUT = (int)0xC0006000L,
1495 WD_USBD_STATUS_DEVICE_GONE = (int)0xC0007000L,
1509 WD_USBD_STATUS_ISO_NOT_ACCESSED_BY_HW = (int)0xC0020000L,
1516 WD_USBD_STATUS_ISO_NA_LATE_USBPORT = (int)0xC0040000L,
1519 WD_USBD_STATUS_ISO_NOT_ACCESSED_LATE = (int)0xC0050000L
1520#endif
1523typedef enum
1525 WD_INSERT = 0x1,
1538 WD_POWER_SYSTEM_SHUTDOWN = 0x2000,
1539 WD_IPC_UNICAST_MSG = 0x4000,
1543#define WD_IPC_ALL_MSG (WD_IPC_UNICAST_MSG | WD_IPC_MULTICAST_MSG)
1545typedef enum
1547 WD_ACKNOWLEDGE = 0x1,
1550
1551#define WDU_USE_SHARED_OBJECT_HANDLE 0x1000000
1552#define WDU_DONT_INSERT_LICENSE 0x2000000
1553
1554#define WD_ACTIONS_POWER (WD_POWER_CHANGED_D0 | WD_POWER_CHANGED_D1 | \
1555 WD_POWER_CHANGED_D2 | WD_POWER_CHANGED_D3 | WD_POWER_SYSTEM_WORKING | \
1556 WD_POWER_SYSTEM_SLEEPING1 | WD_POWER_SYSTEM_SLEEPING3 | \
1557 WD_POWER_SYSTEM_HIBERNATE | WD_POWER_SYSTEM_SHUTDOWN)
1558#define WD_ACTIONS_ALL (WD_ACTIONS_POWER | WD_INSERT | WD_REMOVE)
1560enum
1567typedef DWORD WD_EVENT_TYPE;
1569typedef struct
1570{
1571 DWORD hEvent;
1572 DWORD dwEventType;
1574 DWORD dwAction;
1575 DWORD dwEventId;
1576 DWORD hKernelPlugIn;
1577 DWORD dwOptions;
1578 union u
1580 struct Pci
1583 WD_PCI_SLOT pciSlot;
1585 struct Usb
1587 DWORD dwUniqueID;
1589 struct Ipc
1590 {
1591 DWORD hIpc;
1592 DWORD dwSubGroupID;
1594 DWORD dwGroupID;
1595
1596 DWORD dwSenderUID;
1597 DWORD dwMsgID;
1598 PAD_TO_64(dwMsgID)
1599 UINT64 qwMsgData;
1600 } Ipc;
1601 } u;
1603 DWORD dwNumMatchTables;
1604 WDU_MATCH_TABLE matchTables[1];
1607typedef struct
1608{
1609 DWORD applications_num;
1610 DWORD devices_num;
1611} WD_USAGE;
1613enum
1618
1619#ifndef BZERO
1620 #define BZERO(buf) memset(&(buf), 0, sizeof(buf))
1621#endif
1622
1623#ifndef INVALID_HANDLE_VALUE
1624 #define INVALID_HANDLE_VALUE ((HANDLE)(-1))
1625#endif
1626
1627#ifndef CTL_CODE
1628 #define CTL_CODE(DeviceType, Function, Method, Access) ( \
1629 ((DeviceType)<<16) | ((Access)<<14) | ((Function)<<2) | (Method) \
1632 #define METHOD_BUFFERED 0
1633 #define METHOD_IN_DIRECT 1
1634 #define METHOD_OUT_DIRECT 2
1635 #define METHOD_NEITHER 3
1636 #define FILE_ANY_ACCESS 0
1637 #define FILE_READ_ACCESS 1
1638 #define FILE_WRITE_ACCESS 2
1639#endif
1640
1641#if defined(LINUX) && defined(KERNEL_64BIT)
1642 #define WD_TYPE 0
1643 #define WD_CTL_CODE(wFuncNum) \
1644 _IOC(_IOC_READ|_IOC_WRITE, WD_TYPE, wFuncNum, 0)
1645 #define WD_CTL_DECODE_FUNC(IoControlCode) _IOC_NR(IoControlCode)
1646 #define WD_CTL_DECODE_TYPE(IoControlCode) _IOC_TYPE(IoControlCode)
1647#elif defined(UNIX)
1648 #define WD_TYPE 0
1649 #define WD_CTL_CODE(wFuncNum) (wFuncNum)
1650 #define WD_CTL_DECODE_FUNC(IoControlCode) (IoControlCode)
1651 #define WD_CTL_DECODE_TYPE(IoControlCode) (WD_TYPE)
1652#else
1654 #define WD_TYPE 38200
1655 #if defined(KERNEL_64BIT)
1656 #define FUNC_MASK 0x400
1657 #else
1658 #define FUNC_MASK 0x0
1659 #endif
1660 #define WD_CTL_CODE(wFuncNum) CTL_CODE(WD_TYPE, (wFuncNum | FUNC_MASK), \
1661 METHOD_NEITHER, FILE_ANY_ACCESS)
1662 #define WD_CTL_DECODE_FUNC(IoControlCode) ((IoControlCode >> 2) & 0xfff)
1663 #define WD_CTL_DECODE_TYPE(IoControlCode) \
1664 DEVICE_TYPE_FROM_CTL_CODE(IoControlCode)
1665#endif
1666
1667#if defined(LINUX)
1668 #define WD_CTL_IS_64BIT_AWARE(IoControlCode) \
1669 (_IOC_DIR(IoControlCode) & (_IOC_READ|_IOC_WRITE))
1670#elif defined(UNIX)
1671 #define WD_CTL_IS_64BIT_AWARE(IoControlCode) TRUE
1672#else
1673 #define WD_CTL_IS_64BIT_AWARE(IoControlCode) \
1674 (WD_CTL_DECODE_FUNC(IoControlCode) & FUNC_MASK)
1675#endif
1676
1677/* WinDriver function IOCTL calls. For details on the WinDriver functions, */
1678/* see the WinDriver manual or included help files. */
1680#define IOCTL_WD_KERNEL_BUF_LOCK WD_CTL_CODE(0x901)
1681#define IOCTL_WD_KERNEL_BUF_UNLOCK WD_CTL_CODE(0x902)
1682#define IOCTL_WD_DMA_LOCK WD_CTL_CODE(0x903)
1683#define IOCTL_WD_DMA_UNLOCK WD_CTL_CODE(0x904)
1684#define IOCTL_WD_DMA_SYNC_CPU WD_CTL_CODE(0x905)
1685#define IOCTL_WD_DMA_SYNC_IO WD_CTL_CODE(0x906)
1686#define IOCTL_WD_DMA_TRANSACTION_INIT WD_CTL_CODE(0x907)
1687#define IOCTL_WD_DMA_TRANSACTION_EXECUTE WD_CTL_CODE(0x908)
1688#define IOCTL_WD_DMA_TRANSFER_COMPLETED_AND_CHECK WD_CTL_CODE(0x909)
1689#define IOCTL_WD_DMA_TRANSACTION_RELEASE WD_CTL_CODE(0x90a)
1690#define IOCTL_WD_TRANSFER WD_CTL_CODE(0x90b)
1691#define IOCTL_WD_MULTI_TRANSFER WD_CTL_CODE(0x90c)
1692#define IOCTL_WD_PCI_SCAN_CARDS WD_CTL_CODE(0x90d)
1693#define IOCTL_WD_PCI_GET_CARD_INFO WD_CTL_CODE(0x90e)
1694#define IOCTL_WD_PCI_SCAN_CAPS WD_CTL_CODE(0x90f)
1695#define IOCTL_WD_PCI_CONFIG_DUMP WD_CTL_CODE(0x910)
1696#define IOCTL_WD_VERSION WD_CTL_CODE(0x911)
1697#define IOCTL_WD_KERNEL_PLUGIN_OPEN WD_CTL_CODE(0x912)
1698#define IOCTL_WD_KERNEL_PLUGIN_CLOSE WD_CTL_CODE(0x913)
1699#define IOCTL_WD_KERNEL_PLUGIN_CALL WD_CTL_CODE(0x914)
1700#define IOCTL_WD_INT_ENABLE WD_CTL_CODE(0x915)
1701#define IOCTL_WD_INT_DISABLE WD_CTL_CODE(0x916)
1702#define IOCTL_WD_INT_COUNT WD_CTL_CODE(0x917)
1703#define IOCTL_WD_INT_WAIT WD_CTL_CODE(0x918)
1704#define IOCTL_WD_SLEEP WD_CTL_CODE(0x919)
1705#define IOCTL_WD_DEBUG WD_CTL_CODE(0x91a)
1706#define IOCTL_WD_DEBUG_DUMP WD_CTL_CODE(0x91b)
1707#define IOCTL_WD_DEBUG_ADD WD_CTL_CODE(0x91c)
1708#define IOCTL_WD_CARD_REGISTER WD_CTL_CODE(0x91d)
1709#define IOCTL_WD_CARD_UNREGISTER WD_CTL_CODE(0x91e)
1710#define IOCTL_WD_CARD_CLEANUP_SETUP WD_CTL_CODE(0x91f)
1711#define IOCTL_WD_GET_DEVICE_PROPERTY WD_CTL_CODE(0x920)
1712#define IOCTL_WD_EVENT_REGISTER WD_CTL_CODE(0x921)
1713#define IOCTL_WD_EVENT_UNREGISTER WD_CTL_CODE(0x922)
1714#define IOCTL_WD_EVENT_PULL WD_CTL_CODE(0x923)
1715#define IOCTL_WD_EVENT_SEND WD_CTL_CODE(0x924)
1716#define IOCTL_WDU_GET_DEVICE_DATA WD_CTL_CODE(0x925)
1717#define IOCTL_WDU_WAKEUP WD_CTL_CODE(0x926)
1718#define IOCTL_WDU_SET_INTERFACE WD_CTL_CODE(0x927)
1719#define IOCTL_WDU_RESET_PIPE WD_CTL_CODE(0x928)
1720#define IOCTL_WDU_TRANSFER WD_CTL_CODE(0x929)
1721#define IOCTL_WDU_HALT_TRANSFER WD_CTL_CODE(0x92a)
1722#define IOCTL_WDU_RESET_DEVICE WD_CTL_CODE(0x92b)
1723#define IOCTL_WDU_STREAM_OPEN WD_CTL_CODE(0x92c)
1724#define IOCTL_WDU_STREAM_CLOSE WD_CTL_CODE(0x92d)
1725#define IOCTL_WDU_STREAM_START WD_CTL_CODE(0x92e)
1726#define IOCTL_WDU_STREAM_STOP WD_CTL_CODE(0x92f)
1727#define IOCTL_WDU_STREAM_FLUSH WD_CTL_CODE(0x930)
1728#define IOCTL_WDU_STREAM_GET_STATUS WD_CTL_CODE(0x931)
1729#define IOCTL_WDU_SELECTIVE_SUSPEND WD_CTL_CODE(0x932)
1730#define IOCTL_WD_IPC_REGISTER WD_CTL_CODE(0x933)
1731#define IOCTL_WD_IPC_UNREGISTER WD_CTL_CODE(0x934)
1732#define IOCTL_WD_IPC_SCAN_PROCS WD_CTL_CODE(0x935)
1733#define IOCTL_WD_IPC_SEND WD_CTL_CODE(0x936)
1734#define IOCTL_WD_PCI_SRIOV_ENABLE WD_CTL_CODE(0x937)
1735#define IOCTL_WD_PCI_SRIOV_DISABLE WD_CTL_CODE(0x938)
1736#define IOCTL_WD_PCI_SRIOV_GET_NUMVFS WD_CTL_CODE(0x939)
1737#define IOCTL_WD_IPC_SHARED_INT_ENABLE WD_CTL_CODE(0x93a)
1738#define IOCTL_WD_IPC_SHARED_INT_DISABLE WD_CTL_CODE(0x93b)
1739#define IOCTL_WD_USAGE WD_CTL_CODE(0x93c)
1740#define IOCTL_WD_LICENSE WD_CTL_CODE(0x93d)
1741#define IOCTL_WD_PCI_RESET_CARD WD_CTL_CODE(0x945)
1742#define IOCTL_WD_PLATFORM_GET_DEVICE_INFO WD_CTL_CODE(0x946)
1743#define IOCTL_WD_PLATFORM_SCAN_DEVICES WD_CTL_CODE(0x947)
1744
1745#if defined(UNIX)
1746 typedef struct
1747 {
1748 DWORD dwHeader;
1749 DWORD dwSize;
1750 PVOID pData;
1751 PAD_TO_64(pData)
1752 } WD_IOCTL_HEADER;
1753
1754 #define WD_IOCTL_HEADER_CODE 0xa410b413UL
1755#endif
1756
1757#if defined(__KERNEL__)
1758 HANDLE __cdecl WD_Open(void);
1759 void __cdecl WD_Close(HANDLE hWD);
1760 DWORD __cdecl KP_DeviceIoControl(DWORD dwFuncNum, HANDLE h, PVOID pParam,
1761 DWORD dwSize);
1762 #define WD_FUNCTION(wFuncNum, h, pParam, dwSize, fWait) \
1763 KP_DeviceIoControl((DWORD)wFuncNum, h, (PVOID)pParam, (DWORD)dwSize)
1764#else
1765 #define REGKEY_BUFSIZE 256
1766 #define OS_CAN_NOT_DETECT_TEXT "OS CAN NOT DETECT"
1767 #define INSTALLATION_TYPE_NOT_DETECT_TEXT "unknown"
1768 typedef struct
1769 {
1770 CHAR cProdName[REGKEY_BUFSIZE];
1771 CHAR cInstallationType[REGKEY_BUFSIZE];
1772 #ifdef WIN32
1773 CHAR cCurrentVersion[REGKEY_BUFSIZE];
1774 CHAR cBuild[REGKEY_BUFSIZE];
1775 CHAR cCsdVersion[REGKEY_BUFSIZE];
1776 DWORD dwMajorVersion;
1777 DWORD dwMinorVersion;
1778 #else
1779 CHAR cRelease[REGKEY_BUFSIZE];
1780 CHAR cReleaseVersion[REGKEY_BUFSIZE];
1781 #endif
1782 } WD_OS_INFO;
1783
1793
1805 #if defined(APPLE)
1806 DWORD WD_FUNCTION_LOCAL(int wFuncNum, HANDLE h,
1807 PVOID pParam, DWORD dwSize, BOOL fWait);
1808
1809 HANDLE WD_OpenLocal(void);
1810
1811 void WD_CloseLocal(HANDLE h);
1812
1813 #define WD_OpenStreamLocal(read,sync) INVALID_HANDLE_VALUE
1814
1815 #define WD_UStreamRead(hFile, pBuffer, dwNumberOfBytesToRead, \
1816 dwNumberOfBytesRead)\
1817 WD_NOT_IMPLEMENTED
1818
1819 #define WD_UStreamWrite(hFile, pBuffer, dwNumberOfBytesToWrite, \
1820 dwNumberOfBytesWritten)\
1821 WD_NOT_IMPLEMENTED
1822
1823 #if __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 120000
1824 #define IO_MASTER_PORT IOMainPort
1825 #else
1826 #define IO_MASTER_PORT IOMasterPort
1827 #endif
1828
1829 #elif defined(UNIX)
1830 static inline ULONG WD_FUNCTION_LOCAL(int wFuncNum, HANDLE h,
1831 PVOID pParam, DWORD dwSize, BOOL fWait)
1832 {
1833 WD_IOCTL_HEADER ioctl_hdr;
1834
1835 BZERO(ioctl_hdr);
1836 ioctl_hdr.dwHeader = WD_IOCTL_HEADER_CODE;
1837 ioctl_hdr.dwSize = dwSize;
1838 ioctl_hdr.pData = pParam;
1839 (void)fWait;
1840 #if defined(LINUX)
1841 return (ULONG)ioctl((int)(long)h, wFuncNum, &ioctl_hdr);
1842 #endif
1843 }
1844
1845 #define WD_OpenLocal()\
1846 ((HANDLE)(long)open(WD_DRIVER_NAME, O_RDWR | O_SYNC))
1847 #define WD_OpenStreamLocal(read,sync) \
1848 ((HANDLE)(long)open(WD_DRIVER_NAME, \
1849 ((read) ? O_RDONLY : O_WRONLY) | \
1850 ((sync) ? O_SYNC : O_NONBLOCK)))
1851
1852 #define WD_CloseLocal(h) close((int)(long)(h))
1853
1854 #define WD_UStreamRead(hFile, pBuffer, dwNumberOfBytesToRead, \
1855 dwNumberOfBytesRead)\
1856 WD_NOT_IMPLEMENTED
1857
1858 #define WD_UStreamWrite(hFile, pBuffer, dwNumberOfBytesToWrite, \
1859 dwNumberOfBytesWritten)\
1860 WD_NOT_IMPLEMENTED
1861
1862 #elif defined(WIN32)
1863 #define WD_CloseLocal(h) CloseHandle(h)
1864
1865 #define WD_UStreamRead(hFile, pBuffer, dwNumberOfBytesToRead, \
1866 dwNumberOfBytesRead)\
1867 ReadFile(hFile, pBuffer, dwNumberOfBytesToRead, \
1868 dwNumberOfBytesRead, NULL) ? WD_STATUS_SUCCESS : \
1869 WD_OPERATION_FAILED
1870
1871 #define WD_UStreamWrite(hFile, pBuffer, dwNumberOfBytesToWrite, \
1872 dwNumberOfBytesWritten)\
1873 WriteFile(hFile, pBuffer, dwNumberOfBytesToWrite, \
1874 dwNumberOfBytesWritten, NULL) ? WD_STATUS_SUCCESS : \
1875 WD_OPERATION_FAILED
1876
1877 #if defined(WIN32)
1878 #define WD_OpenLocal()\
1879 CreateFileA(\
1880 WD_DRIVER_NAME,\
1881 GENERIC_READ,\
1882 FILE_SHARE_READ | FILE_SHARE_WRITE,\
1883 NULL, OPEN_EXISTING, FILE_FLAG_OVERLAPPED, NULL)
1884
1885 #define WD_OpenStreamLocal(read,sync) \
1886 CreateFileA(\
1887 WD_DRIVER_NAME,\
1888 (read) ? GENERIC_READ : GENERIC_WRITE,\
1889 FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, \
1890 (sync) ? 0 : FILE_FLAG_OVERLAPPED, NULL)
1891
1892 static DWORD WD_FUNCTION_LOCAL(int wFuncNum, HANDLE h, PVOID pParam,
1893 DWORD dwSize, BOOL fWait)
1894 {
1895 DWORD dwTmp;
1896 HANDLE hWD = fWait ? WD_OpenLocal() : h;
1897 DWORD rc = WD_WINDRIVER_STATUS_ERROR;
1898
1899 if (hWD == INVALID_HANDLE_VALUE)
1900 return (DWORD)WD_STATUS_INVALID_WD_HANDLE;
1901
1902 DeviceIoControl(hWD, (DWORD)wFuncNum, pParam, dwSize, &rc,
1903 sizeof(DWORD), &dwTmp, NULL);
1904
1905 if (fWait)
1906 WD_CloseLocal(hWD);
1907
1908 return rc;
1909 }
1910 #endif
1911 #endif
1913 #define WD_FUNCTION WD_FUNCTION_LOCAL
1914 #define WD_Close WD_CloseLocal
1915 #define WD_Open WD_OpenLocal
1916 #define WD_StreamOpen WD_OpenStreamLocal
1917 #define WD_StreamClose WD_CloseLocal
1918#endif
1919
1920#define SIZE_OF_WD_DMA(pDma) \
1921 ((DWORD)(sizeof(WD_DMA) + ((pDma)->dwPages <= WD_DMA_PAGES ? \
1922 0 : ((pDma)->dwPages - WD_DMA_PAGES) * sizeof(WD_DMA_PAGE))))
1923#define SIZE_OF_WD_EVENT(pEvent) \
1924 ((DWORD)(sizeof(WD_EVENT) + ((pEvent)->dwNumMatchTables > 0 ? \
1925 sizeof(WDU_MATCH_TABLE) * ((pEvent)->dwNumMatchTables - 1) : 0)))
1926
1938#define WD_Debug(h,pDebug)\
1939 WD_FUNCTION(IOCTL_WD_DEBUG, h, pDebug, sizeof(WD_DEBUG), FALSE)
1940
1952#define WD_DebugDump(h,pDebugDump)\
1953 WD_FUNCTION(IOCTL_WD_DEBUG_DUMP, h, pDebugDump, sizeof(WD_DEBUG_DUMP), \
1954 FALSE)
1955
1967#define WD_DebugAdd(h, pDebugAdd)\
1968 WD_FUNCTION(IOCTL_WD_DEBUG_ADD, h, pDebugAdd, sizeof(WD_DEBUG_ADD), FALSE)
1969
1982#define WD_Transfer(h,pTransfer)\
1983 WD_FUNCTION(IOCTL_WD_TRANSFER, h, pTransfer, sizeof(WD_TRANSFER), FALSE)
1984
2001#define WD_MultiTransfer(h, pTransferArray, dwNumTransfers) \
2002 WD_FUNCTION(IOCTL_WD_MULTI_TRANSFER, h, pTransferArray, \
2003 sizeof(WD_TRANSFER) * (dwNumTransfers), FALSE)
2004
2018#define WD_KernelBufLock(h, pKerBuf)\
2019 WD_FUNCTION(IOCTL_WD_KERNEL_BUF_LOCK, h, pKerBuf, \
2020 sizeof(WD_KERNEL_BUFFER), FALSE)
2021
2033#define WD_KernelBufUnlock(h, pKerBuf)\
2034 WD_FUNCTION(IOCTL_WD_KERNEL_BUF_UNLOCK, h, pKerBuf, \
2035 sizeof(WD_KERNEL_BUFFER), FALSE)
2036
2099#define WD_DMALock(h,pDma)\
2100 WD_FUNCTION(IOCTL_WD_DMA_LOCK, h, pDma, SIZE_OF_WD_DMA(pDma), FALSE)
2101
2114#define WD_DMAUnlock(h,pDma)\
2115 WD_FUNCTION(IOCTL_WD_DMA_UNLOCK, h, pDma, SIZE_OF_WD_DMA(pDma), FALSE)
2116
2130#define WD_DMATransactionInit(h,pDma)\
2131 WD_FUNCTION(IOCTL_WD_DMA_TRANSACTION_INIT, h, pDma, SIZE_OF_WD_DMA(pDma), \
2132 FALSE)
2133
2144#define WD_DMATransactionExecute(h,pDma)\
2145 WD_FUNCTION(IOCTL_WD_DMA_TRANSACTION_EXECUTE, h, pDma, \
2146 SIZE_OF_WD_DMA(pDma), FALSE)
2147
2158#define WD_DMATransferCompletedAndCheck(h,pDma)\
2159 WD_FUNCTION(IOCTL_WD_DMA_TRANSFER_COMPLETED_AND_CHECK, h, pDma, \
2160 SIZE_OF_WD_DMA(pDma), FALSE)
2161
2173#define WD_DMATransactionRelease(h,pDma)\
2174 WD_FUNCTION(IOCTL_WD_DMA_TRANSACTION_RELEASE, h, pDma, \
2175 SIZE_OF_WD_DMA(pDma), FALSE)
2176
2188#define WD_DMATransactionUninit(h,pDma)\
2189 WD_FUNCTION(IOCTL_WD_DMA_UNLOCK, h, pDma, SIZE_OF_WD_DMA(pDma), FALSE)
2190
2214#define WD_DMASyncCpu(h,pDma)\
2215 WD_FUNCTION(IOCTL_WD_DMA_SYNC_CPU, h, pDma, SIZE_OF_WD_DMA(pDma), FALSE)
2216
2241#define WD_DMASyncIo(h,pDma)\
2242 WD_FUNCTION(IOCTL_WD_DMA_SYNC_IO, h, pDma, SIZE_OF_WD_DMA(pDma), FALSE)
2243
2295#define WD_CardRegister(h,pCard)\
2296 WD_FUNCTION(IOCTL_WD_CARD_REGISTER, h, pCard, sizeof(WD_CARD_REGISTER),\
2297 FALSE)
2298
2311#define WD_CardUnregister(h,pCard)\
2312 WD_FUNCTION(IOCTL_WD_CARD_UNREGISTER, h, pCard, sizeof(WD_CARD_REGISTER),\
2313 FALSE)
2314
2336#define WD_IpcRegister(h, pIpcRegister) \
2337 WD_FUNCTION(IOCTL_WD_IPC_REGISTER, h, pIpcRegister, \
2338 sizeof(WD_IPC_REGISTER), FALSE)
2339
2352#define WD_IpcUnRegister(h, pProcInfo) \
2353 WD_FUNCTION(IOCTL_WD_IPC_UNREGISTER, h, pProcInfo, sizeof(WD_IPC_PROCESS), \
2354 FALSE)
2355
2369#define WD_IpcScanProcs(h, pIpcScanProcs) \
2370 WD_FUNCTION(IOCTL_WD_IPC_SCAN_PROCS, h, pIpcScanProcs, \
2371 sizeof(WD_IPC_SCAN_PROCS), FALSE)
2372
2386#define WD_IpcSend(h, pIpcSend) \
2387 WD_FUNCTION(IOCTL_WD_IPC_SEND, h, pIpcSend, sizeof(WD_IPC_SEND), FALSE)
2388
2406#define WD_SharedIntEnable(h, pIpcRegister) \
2407 WD_FUNCTION(IOCTL_WD_IPC_SHARED_INT_ENABLE, h, pIpcRegister, \
2408 sizeof(WD_IPC_REGISTER), FALSE)
2409
2421#define WD_SharedIntDisable(h) \
2422 WD_FUNCTION(IOCTL_WD_IPC_SHARED_INT_DISABLE, h, 0, 0, FALSE)
2423
2437#define WD_PciSriovEnable(h,pPciSRIOV) \
2438 WD_FUNCTION(IOCTL_WD_PCI_SRIOV_ENABLE, h, pPciSRIOV, \
2439 sizeof(WD_PCI_SRIOV), FALSE)
2440
2454#define WD_PciSriovDisable(h,pPciSRIOV) \
2455 WD_FUNCTION(IOCTL_WD_PCI_SRIOV_DISABLE, h, pPciSRIOV, \
2456 sizeof(WD_PCI_SRIOV), FALSE)
2457
2473#define WD_PciSriovGetNumVFs(h,pPciSRIOV) \
2474 WD_FUNCTION(IOCTL_WD_PCI_SRIOV_GET_NUMVFS, h, pPciSRIOV, \
2475 sizeof(WD_PCI_SRIOV), FALSE)
2476
2499#define WD_CardCleanupSetup(h,pCardCleanup)\
2500 WD_FUNCTION(IOCTL_WD_CARD_CLEANUP_SETUP, h, pCardCleanup, \
2501 sizeof(WD_CARD_CLEANUP), FALSE)
2502
2517#define WD_PciScanCards(h,pPciScan)\
2518 WD_FUNCTION(IOCTL_WD_PCI_SCAN_CARDS, h, pPciScan,\
2519 sizeof(WD_PCI_SCAN_CARDS), FALSE)
2520
2534#define WD_PciScanCaps(h,pPciScanCaps) \
2535 WD_FUNCTION(IOCTL_WD_PCI_SCAN_CAPS, h, pPciScanCaps, \
2536 sizeof(WD_PCI_SCAN_CAPS), FALSE)
2537
2551#define WD_PciGetCardInfo(h,pPciCard)\
2552 WD_FUNCTION(IOCTL_WD_PCI_GET_CARD_INFO, h, pPciCard, \
2553 sizeof(WD_PCI_CARD_INFO), FALSE)
2554
2569#define WD_PciConfigDump(h,pPciConfigDump)\
2570 WD_FUNCTION(IOCTL_WD_PCI_CONFIG_DUMP, h, pPciConfigDump, \
2571 sizeof(WD_PCI_CONFIG_DUMP), FALSE)
2572
2589#define WD_PciResetCard(h,pPciSlot)\
2590 WD_FUNCTION(IOCTL_WD_PCI_RESET_CARD, h, pPciSlot, sizeof(WD_PCI_SLOT), \
2591 FALSE)
2592
2593#if defined(LINUX)
2604#define WD_PlatformGetCardInfo(h,pCard)\
2605 WD_FUNCTION(IOCTL_WD_PLATFORM_GET_DEVICE_INFO, h, pCard, \
2606 sizeof(WD_PLATFORM_CARD_INFO), FALSE)
2607
2621#define WD_PlatformScanDevices(h,pPlatformScan)\
2622 WD_FUNCTION(IOCTL_WD_PLATFORM_SCAN_DEVICES, h, pPlatformScan, \
2623 sizeof(WD_PLATFORM_SCAN_DEVICES), FALSE)
2624#endif /* defined(LINUX) */
2625
2638#define WD_Version(h,pVerInfo)\
2639 WD_FUNCTION(IOCTL_WD_VERSION, h, pVerInfo, sizeof(WD_VERSION), FALSE)
2640
2664#define WD_License(h,pLicense)\
2665 WD_FUNCTION(IOCTL_WD_LICENSE, h, pLicense, sizeof(WD_LICENSE), FALSE)
2666
2680#define WD_KernelPlugInOpen(h,pKernelPlugIn)\
2681 WD_FUNCTION(IOCTL_WD_KERNEL_PLUGIN_OPEN, h, pKernelPlugIn, \
2682 sizeof(WD_KERNEL_PLUGIN), FALSE)
2683
2696#define WD_KernelPlugInClose(h,pKernelPlugIn)\
2697 WD_FUNCTION(IOCTL_WD_KERNEL_PLUGIN_CLOSE, h, pKernelPlugIn, \
2698 sizeof(WD_KERNEL_PLUGIN), FALSE)
2699
2719#define WD_KernelPlugInCall(h,pKernelPlugInCall)\
2720 WD_FUNCTION(IOCTL_WD_KERNEL_PLUGIN_CALL, h, pKernelPlugInCall, \
2721 sizeof(WD_KERNEL_PLUGIN_CALL), FALSE)
2722
2746#define WD_IntEnable(h,pInterrupt)\
2747 WD_FUNCTION(IOCTL_WD_INT_ENABLE, h, pInterrupt, sizeof(WD_INTERRUPT), FALSE)
2748
2760#define WD_IntDisable(h,pInterrupt)\
2761 WD_FUNCTION(IOCTL_WD_INT_DISABLE, h, pInterrupt, sizeof(WD_INTERRUPT), \
2762 FALSE)
2763
2775#define WD_IntCount(h,pInterrupt)\
2776 WD_FUNCTION(IOCTL_WD_INT_COUNT, h, pInterrupt, sizeof(WD_INTERRUPT), FALSE)
2777
2794#define WD_IntWait(h,pInterrupt)\
2795 WD_FUNCTION(IOCTL_WD_INT_WAIT, h, pInterrupt, sizeof(WD_INTERRUPT), TRUE)
2796
2811#define WD_Sleep(h,pSleep)\
2812 WD_FUNCTION(IOCTL_WD_SLEEP, h, pSleep, sizeof(WD_SLEEP), FALSE)
2813
2814
2815#define WD_EventRegister(h, pEvent) \
2816 WD_FUNCTION(IOCTL_WD_EVENT_REGISTER, h, pEvent, SIZE_OF_WD_EVENT(pEvent), \
2817 FALSE)
2818#define WD_EventUnregister(h, pEvent) \
2819 WD_FUNCTION(IOCTL_WD_EVENT_UNREGISTER, h, pEvent, \
2820 SIZE_OF_WD_EVENT(pEvent), FALSE)
2821#define WD_EventPull(h,pEvent) \
2822 WD_FUNCTION(IOCTL_WD_EVENT_PULL, h, pEvent, SIZE_OF_WD_EVENT(pEvent), FALSE)
2823#define WD_EventSend(h,pEvent) \
2824 WD_FUNCTION(IOCTL_WD_EVENT_SEND, h, pEvent, SIZE_OF_WD_EVENT(pEvent), FALSE)
2825#define WD_Usage(h, pStop) \
2826 WD_FUNCTION(IOCTL_WD_USAGE, h, pStop, sizeof(WD_USAGE), FALSE)
2827
2828#define WD_UGetDeviceData(h, pGetDevData) \
2829 WD_FUNCTION(IOCTL_WDU_GET_DEVICE_DATA, h, pGetDevData, \
2830 sizeof(WDU_GET_DEVICE_DATA), FALSE);
2831#define WD_GetDeviceProperty(h, pGetDevProperty) \
2832 WD_FUNCTION(IOCTL_WD_GET_DEVICE_PROPERTY, h, pGetDevProperty, \
2833 sizeof(WD_GET_DEVICE_PROPERTY), FALSE);
2834#define WD_USetInterface(h, pSetIfc) \
2835 WD_FUNCTION(IOCTL_WDU_SET_INTERFACE, h, pSetIfc, \
2836 sizeof(WDU_SET_INTERFACE), FALSE);
2837#define WD_UResetPipe(h, pResetPipe) \
2838 WD_FUNCTION(IOCTL_WDU_RESET_PIPE, h, pResetPipe, sizeof(WDU_RESET_PIPE), \
2839 FALSE);
2840#define WD_UTransfer(h, pTrans) \
2841 WD_FUNCTION(IOCTL_WDU_TRANSFER, h, pTrans, sizeof(WDU_TRANSFER), TRUE);
2842#define WD_UHaltTransfer(h, pHaltTrans) \
2843 WD_FUNCTION(IOCTL_WDU_HALT_TRANSFER, h, pHaltTrans, \
2844 sizeof(WDU_HALT_TRANSFER), FALSE);
2845#define WD_UWakeup(h, pWakeup) \
2846 WD_FUNCTION(IOCTL_WDU_WAKEUP, h, pWakeup, sizeof(WDU_WAKEUP), FALSE);
2847#define WD_USelectiveSuspend(h, pSelectiveSuspend) \
2848 WD_FUNCTION(IOCTL_WDU_SELECTIVE_SUSPEND, h, pSelectiveSuspend, \
2849 sizeof(WDU_SELECTIVE_SUSPEND), FALSE);
2850#define WD_UResetDevice(h, pResetDevice) \
2851 WD_FUNCTION(IOCTL_WDU_RESET_DEVICE, h, pResetDevice, \
2852 sizeof(WDU_RESET_DEVICE), FALSE);
2853#define WD_UStreamOpen(h, pStream) \
2854 WD_FUNCTION(IOCTL_WDU_STREAM_OPEN, h, pStream, sizeof(WDU_STREAM), FALSE);
2855#define WD_UStreamClose(h, pStream) \
2856 WD_FUNCTION(IOCTL_WDU_STREAM_CLOSE, h, pStream, sizeof(WDU_STREAM), FALSE);
2857#define WD_UStreamStart(h, pStream) \
2858 WD_FUNCTION(IOCTL_WDU_STREAM_START, h, pStream, sizeof(WDU_STREAM), FALSE);
2859#define WD_UStreamStop(h, pStream) \
2860 WD_FUNCTION(IOCTL_WDU_STREAM_STOP, h, pStream, sizeof(WDU_STREAM), FALSE);
2861#define WD_UStreamFlush(h, pStream) \
2862 WD_FUNCTION(IOCTL_WDU_STREAM_FLUSH, h, pStream, sizeof(WDU_STREAM), FALSE);
2863#define WD_UStreamGetStatus(h, pStreamStatus) \
2864 WD_FUNCTION(IOCTL_WDU_STREAM_GET_STATUS, h, pStreamStatus, \
2865 sizeof(WDU_STREAM_STATUS), FALSE);
2866
2867#define __ALIGN_DOWN(val,alignment) ( (val) & ~((alignment) - 1) )
2868#define __ALIGN_UP(val,alignment) \
2869 ( ((val) + (alignment) - 1) & ~((alignment) - 1) )
2870
2871#ifdef WDLOG
2872 #include "wd_log.h"
2873#endif
2874
2875#ifndef MIN
2876 #define MIN(a,b) ((a) > (b) ? (b) : (a))
2877#endif
2878#ifndef MAX
2879 #define MAX(a,b) ((a) > (b) ? (a) : (b))
2880#endif
2881#define SAFE_STRING(s) ((s) ? (s) : "")
2882
2883#define UNUSED_VAR(x) (void)x
2884
2885#ifdef __cplusplus
2886}
2887#endif
2888
2889#endif /* _WINDRVR_H_ */
2890
#define NULL
Definition: kpstdlib.h:269
ITEM_IO.
Definition: windrvr.h:776
ITEM_INTERRUPT.
Definition: windrvr.h:784
ITEM_MEMORY.
Definition: windrvr.h:756
unsigned int u32
Definition: wd_types.h:10
unsigned short u16
Definition: wd_types.h:9
unsigned char u8
Definition: wd_types.h:8
struct WD_BUS WD_BUS_V30
ITEM_TYPE
Definition: windrvr.h:729
@ ITEM_INTERRUPT
Interrupt.
Definition: windrvr.h:731
@ ITEM_BUS
Bus.
Definition: windrvr.h:734
@ ITEM_NONE
Definition: windrvr.h:730
@ ITEM_IO
I/O.
Definition: windrvr.h:733
@ ITEM_MEMORY
Memory.
Definition: windrvr.h:732
@ WD_FORCE_CLEANUP
Definition: windrvr.h:877
@ SLEEP_BUSY
Definition: windrvr.h:1010
@ SLEEP_NON_BUSY
Definition: windrvr.h:1010
struct WD_KERNEL_PLUGIN_CALL WD_KERNEL_PLUGIN_CALL_V40
@ WD_DMA_PAGES
Definition: windrvr.h:440
struct WD_PCI_CARD_INFO WD_PCI_CARD_INFO_V118
PCI_ACCESS_RESULT
Definition: windrvr.h:990
@ PCI_ACCESS_OK
Definition: windrvr.h:991
@ PCI_ACCESS_ERROR
Definition: windrvr.h:992
@ PCI_BAD_SLOT
Definition: windrvr.h:994
@ PCI_BAD_BUS
Definition: windrvr.h:993
WD_ITEM_MEM_OPTIONS
Definition: windrvr.h:738
@ WD_ITEM_MEM_DO_NOT_MAP_KERNEL
Skip the mapping of physical memory to the kernel address space.
Definition: windrvr.h:739
@ WD_ITEM_MEM_ALLOW_CACHE
Map physical memory as cached; applicable only to host RAM, not to local memory on the card.
Definition: windrvr.h:741
@ WD_ITEM_MEM_USER_MAP
Map physical memory from user mode, Linux only.
Definition: windrvr.h:744
WD_GET_DEVICE_PROPERTY_OPTION
IOCTL Structures.
Definition: windrvr.h:1105
@ WD_DEVICE_USB
Definition: windrvr.h:1107
@ WD_DEVICE_PCI
Definition: windrvr.h:1106
struct WD_ITEMS WD_ITEMS_V118
struct WD_DEBUG_ADD WD_DEBUG_ADD_V503
@ WD_EVENT_TYPE_IPC
Definition: windrvr.h:1562
@ WD_EVENT_TYPE_UNKNOWN
Definition: windrvr.h:1559
@ WD_EVENT_TYPE_USB
Definition: windrvr.h:1561
@ WD_EVENT_TYPE_PCI
Definition: windrvr.h:1560
size_t UPTR
Definition: windrvr.h:387
#define WD_VERSION_STR_LENGTH
Definition: windrvr.h:61
struct WD_IPC_SCAN_PROCS WD_IPC_SCAN_PROCS_V121
DEBUG_LEVEL
Definition: windrvr.h:1019
@ D_ERROR
Definition: windrvr.h:1021
@ D_TRACE
Definition: windrvr.h:1024
@ D_WARN
Definition: windrvr.h:1022
@ D_INFO
Definition: windrvr.h:1023
@ D_OFF
Definition: windrvr.h:1020
struct WD_TRANSFER WD_TRANSFER_V61
unsigned short int WORD
Definition: windrvr.h:337
struct WD_KERNEL_BUFFER WD_KERNEL_BUFFER_V121
WD_KER_BUF_OPTION
Definition: windrvr.h:579
@ KER_BUF_ALLOC_NON_CONTIG
Definition: windrvr.h:585
@ KER_BUF_GET_EXISTING_BUF
Definition: windrvr.h:588
@ KER_BUF_ALLOC_CONTIG
Definition: windrvr.h:586
@ KER_BUF_ALLOC_CACHED
Definition: windrvr.h:587
@ WD_DEVICE_NAME_LENGTH
Definition: windrvr.h:913
#define WD_OpenLocal()
Definition: windrvr.h:1875
DEBUG_COMMAND
Definition: windrvr.h:1049
@ DEBUG_DUMP_SEC_ON
Definition: windrvr.h:1054
@ KERNEL_DEBUGGER_OFF
Definition: windrvr.h:1057
@ DEBUG_CLEAR_BUFFER
Definition: windrvr.h:1053
@ DEBUG_DUMP_CLOCK_OFF
Definition: windrvr.h:1059
@ DEBUG_DUMP_CLOCK_ON
Definition: windrvr.h:1058
@ KERNEL_DEBUGGER_ON
Definition: windrvr.h:1056
@ DEBUG_SET_FILTER
Definition: windrvr.h:1051
@ DEBUG_SET_BUFFER
Definition: windrvr.h:1052
@ DEBUG_CLOCK_RESET
Definition: windrvr.h:1060
@ DEBUG_STATUS
Definition: windrvr.h:1050
@ DEBUG_DUMP_SEC_OFF
Definition: windrvr.h:1055
struct WD_SLEEP WD_SLEEP_V40
#define WD_LICENSE_LENGTH
Definition: windrvr.h:701
unsigned char BYTE
Definition: windrvr.h:336
WD_ERROR_CODES
Definition: windrvr.h:1126
@ WD_INVALID_32BIT_APP
[0x20000021] Invalid 32 Bit User Application.
Definition: windrvr.h:1291
@ WD_TRY_AGAIN
[0x2000001d] Try Again.
Definition: windrvr.h:1277
@ WD_USBD_STATUS_DATA_TOGGLE_MISMATCH
[0xC0000003] HC status: Data toggle mismatch
Definition: windrvr.h:1345
@ WD_RESOURCE_OVERLAP
[0x2000000e] Resource Overlap.
Definition: windrvr.h:1195
@ WD_FAILED_KERNEL_MAPPING
[0x20000018] Failed to map memory to Kernel Space.
Definition: windrvr.h:1243
@ WD_WINDRIVER_STATUS_ERROR
[0x20000000]
Definition: windrvr.h:1130
@ WD_USBD_STATUS_UNEXPECTED_PID
[0xC0000007] HC status: Unexpected PID
Definition: windrvr.h:1357
@ WD_USBD_STATUS_REQUEST_FAILED
[0x80000500] Returned by USBD if it cannot complete a URB request.
Definition: windrvr.h:1424
@ WD_USBD_STATUS_INTERFACE_NOT_FOUND
[0xC0004000] USBD: Interface not found
Definition: windrvr.h:1481
@ WD_USBD_STATUS_INAVLID_CONFIGURATION_DESCRIPTOR
[0xC0000F00] USBD: Invalid configuration descriptor
Definition: windrvr.h:1462
@ WD_TOO_MANY_HANDLES
[0x20000022] Too Many Handles.
Definition: windrvr.h:1297
@ WD_USBD_STATUS_ISO_NOT_ACCESSED_LATE
[0xC0050000] The packet was not sent because the client submitted it too late to transmit:
Definition: windrvr.h:1516
@ WD_USBD_STATUS_INVALID_URB_FUNCTION
[0x80000200] USBD: Invalid URB function
Definition: windrvr.h:1409
@ WD_USBD_STATUS_NOT_ACCESSED
[0xC000000F] HC status: Not accessed
Definition: windrvr.h:1376
@ WD_INTERRUPT_NOT_ENABLED
[0x2000000d] Interrupt not enabled.
Definition: windrvr.h:1188
@ WD_USBD_STATUS_ERROR_BUSY
[0x80000400] Returned if client driver attempts to close an endpoint/interface or configuration with ...
Definition: windrvr.h:1418
@ WD_USBD_STATUS_XACT_ERROR
[0xC0000011] HC status: The host controller has set the Transaction Error (XactErr) bit in the transf...
Definition: windrvr.h:1382
@ WD_MORE_PROCESSING_REQUIRED
[0xC0000016] More Processing Required.
Definition: windrvr.h:1316
@ WD_UNKNOWN_PIPE_TYPE
[0x20000006] Obsolete.
Definition: windrvr.h:1155
@ WD_INVALID_HANDLE
[0x20000001] Invalid WinDriver handle.
Definition: windrvr.h:1132
@ WD_USBD_STATUS_DATA_UNDERRUN
[0xC0000009] HC status: Data underrrun
Definition: windrvr.h:1363
@ WD_OPERATION_FAILED
[0x20000020] Operation Failed.
Definition: windrvr.h:1287
@ WD_USB_DESCRIPTOR_ERROR
[0x20000012] USB Descriptor Error.
Definition: windrvr.h:1213
@ WD_USBD_STATUS_RESERVED1
[0xC000000A] HC status: Reserved1
Definition: windrvr.h:1366
@ WD_USBD_STATUS_RESERVED2
[0xC000000B] HC status: Reserved1
Definition: windrvr.h:1368
@ WD_USBD_STATUS_NOT_SUPPORTED
[0xC0000E00] Returned for APIS not supported/implemented
Definition: windrvr.h:1459
@ WD_USBD_STATUS_DEVICE_GONE
[0xC0007000] USBD: Device Gone
Definition: windrvr.h:1492
@ WD_USBD_STATUS_ISO_NOT_ACCESSED_BY_HW
Extended isochronous error codes returned by USBD.
Definition: windrvr.h:1506
@ WD_USBD_STATUS_DATA_BUFFER_ERROR
[0xC0000013] HC status: Data buffer error
Definition: windrvr.h:1391
@ WD_USBD_STATUS_ISO_TD_ERROR
[0xC0030000] Controller reported an error in the TD.
Definition: windrvr.h:1510
@ WD_USBD_STATUS_DEV_NOT_RESPONDING
[0xC0000005] HC status: Device not responding
Definition: windrvr.h:1351
@ WD_USBD_STATUS_FIFO
[0xC0000010] HC status: FIFO
Definition: windrvr.h:1378
@ WD_NO_LICENSE
0x[20000009] No License.
Definition: windrvr.h:1162
@ WD_INVALID_PARAMETER
[0x2000001b] Invalid Parameter.
Definition: windrvr.h:1267
@ WD_WRONG_UNIQUE_ID
[0x20000010] Wrong unique ID (USB).
Definition: windrvr.h:1204
@ WD_USBD_STATUS_INVALID_PARAMETER
[0x80000300] USBD: Invalid parameter
Definition: windrvr.h:1412
@ WD_USBD_STATUS_BAD_START_FRAME
[0x80000A00] Returned if the requested start frame is not within
Definition: windrvr.h:1442
@ WD_USBD_STATUS_SUCCESS
[0x00000000] Success
Definition: windrvr.h:1326
@ WD_USBD_STATUS_ERROR
[0x80000000] Error
Definition: windrvr.h:1329
@ WD_DATA_MISMATCH
[0x20000008] Data Mismatch.
Definition: windrvr.h:1158
@ WD_NO_RESOURCES_ON_DEVICE
[0x20000019] No Resources On Device.
Definition: windrvr.h:1253
@ WD_NO_EVENTS
[0x2000001a] No Events.
Definition: windrvr.h:1263
@ WD_USBD_STATUS_NO_BANDWIDTH
[0x80000700] Returned when there is not enough bandwidth available
Definition: windrvr.h:1430
@ WD_USBD_STATUS_BUFFER_UNDERRUN
[0xC000000D] HC status: Buffer underrun
Definition: windrvr.h:1373
@ WD_NOT_IMPLEMENTED
[0x2000000a] Function not implemented.
Definition: windrvr.h:1168
@ WD_READ_WRITE_CONFLICT
[0x20000003] Request to read from an OUT (write) pipe or request to write to an IN (read) pipe
Definition: windrvr.h:1145
@ WD_USBD_STATUS_FRAME_CONTROL_NOT_OWNED
[0xC0000D00] Returned by USBD if the caller does not own frame length control and attempts to release...
Definition: windrvr.h:1454
@ WD_DEVICE_NOT_FOUND
[0x2000000f] Device not found.
Definition: windrvr.h:1201
@ WD_NO_DEVICE_OBJECT
[0x20000023] No Device Object.
Definition: windrvr.h:1303
@ WD_USBD_STATUS_CANCELED
[0xC0010000] USBD: Transfer canceled
Definition: windrvr.h:1396
@ WD_INCORRECT_VERSION
[0x2000001c] Incorrect version.
Definition: windrvr.h:1271
@ WD_USBD_STATUS_PENDING
[0x40000000] Operation pending
Definition: windrvr.h:1327
@ WD_USBD_STATUS_TIMEOUT
[0xC0006000] USBD: Timeout
Definition: windrvr.h:1489
@ WD_USBD_STATUS_ISOCH_REQUEST_FAILED
[0xC0000B00] Returned by HCD (Host Controller Driver) if all packets in an isochronous transfer compl...
Definition: windrvr.h:1446
@ WD_FAILED_ENABLING_INTERRUPT
[0x2000000c] Failed Enabling Interrupts.
Definition: windrvr.h:1177
@ WD_KERPLUG_FAILURE
[0x2000000b] Kernel PlugIn failure.
Definition: windrvr.h:1173
@ WD_WINDRIVER_NOT_FOUND
[0x2000001e] Obsolete
Definition: windrvr.h:1281
@ WD_SET_CONFIGURATION_FAILED
[0x20000013] Set Configuration Failed (USB).
Definition: windrvr.h:1221
@ WD_USBD_STATUS_CRC
[0xC0000001] HC status: CRC
Definition: windrvr.h:1341
@ WD_USBD_STATUS_ENDPOINT_HALTED
Returned by HCD (Host Controller Driver) if a transfer is submitted to an endpoint that is stalled:
Definition: windrvr.h:1402
@ WD_USBD_STATUS_INTERNAL_HC_ERROR
[0x80000800] Generic HC (Host Controller) error:
Definition: windrvr.h:1433
@ WD_FAILED_USER_MAPPING
[0x20000017] Failed to map memory to User Space.
Definition: windrvr.h:1234
@ WD_USBD_STATUS_INVALID_PIPE_HANDLE
[80000600] USBD: Invalid pipe handle
Definition: windrvr.h:1426
@ WD_STATUS_SUCCESS
[0] Operation completed successfully
Definition: windrvr.h:1127
@ WD_USBD_STATUS_INAVLID_PIPE_FLAGS
[0xC0005000] USBD: Invalid pipe flags
Definition: windrvr.h:1485
@ WD_INVALID_IOCTL
[0x2000001f] Invalid IOCTL.
Definition: windrvr.h:1282
@ WD_TIME_OUT_EXPIRED
[0x20000015] Time Out Expired.
Definition: windrvr.h:1227
@ WD_SYSTEM_INTERNAL_ERROR
[0x20000007] Internal System Error
Definition: windrvr.h:1156
@ WD_USBD_STATUS_BUFFER_TOO_SMALL
[0xC0003000] USBD: Buffer too small
Definition: windrvr.h:1477
@ WD_USBD_STATUS_INSUFFICIENT_RESOURCES
[0xC0001000] USBD: Insufficient resources
Definition: windrvr.h:1468
@ WD_USBD_STATUS_DATA_OVERRUN
[0xC0000008] HC status: Data overrun
Definition: windrvr.h:1360
@ WD_ZERO_PACKET_SIZE
[0x20000004] Maximum packet size is zero
Definition: windrvr.h:1148
@ WD_USBD_STATUS_ERROR_SHORT_TRANSFER
[0x80000900] Returned when a short packet terminates the transfer
Definition: windrvr.h:1437
@ WD_USBD_STATUS_STALL_PID
[0xC0000004] HC status: PID stall
Definition: windrvr.h:1349
@ WD_USBD_STATUS_PID_CHECK_FAILURE
[0xC0000006] HC status: PID check failed
Definition: windrvr.h:1354
@ WD_USBD_STATUS_ISO_NA_LATE_USBPORT
[0xC0040000] The packet was submitted in time by the client but
Definition: windrvr.h:1513
@ WD_CANT_OBTAIN_PDO
[0x20000014] Obsolete
Definition: windrvr.h:1226
@ WD_USBD_STATUS_BABBLE_DETECTED
[0xC0000012] HC status: Babble detected
Definition: windrvr.h:1388
@ WD_USBD_STATUS_HALTED
[0xC0000000] Halted
Definition: windrvr.h:1330
@ WD_INSUFFICIENT_RESOURCES
[0x20000005] Insufficient resources.
Definition: windrvr.h:1150
@ WD_USBD_STATUS_FRAME_CONTROL_OWNED
[0xC0000C00] Returned by USBD if the frame length control for a given
Definition: windrvr.h:1450
@ WD_USBD_STATUS_BTSTUFF
[0xC0000002] HC status: Bit stuffing
Definition: windrvr.h:1343
@ WD_USBD_STATUS_BUFFER_OVERRUN
[0xC000000C] HC status: Buffer overrun
Definition: windrvr.h:1370
@ WD_USBD_STATUS_SET_CONFIG_FAILED
[0xC0002000] USBD: Set configuration failed
Definition: windrvr.h:1472
@ WD_IRP_CANCELED
[0x20000016] IRP Cancelled.
Definition: windrvr.h:1231
@ WD_INVALID_PIPE_NUMBER
[0x20000002] USB: Invalid Pipe Number.
Definition: windrvr.h:1141
@ WD_OPERATION_ALREADY_DONE
[0x20000011] Operation Already Done.
Definition: windrvr.h:1207
@ WD_USBD_STATUS_STATUS_NOT_MAPPED
[0xC0008000] USBD: Status not mapped
Definition: windrvr.h:1495
@ WD_STATUS_INVALID_WD_HANDLE
[0xffffffff]
Definition: windrvr.h:1128
@ WD_USBD_STATUS_NO_MEMORY
[0x80000100] USBD: Out of memory
Definition: windrvr.h:1406
DEBUG_SECTION
Definition: windrvr.h:1028
@ S_MISC
Definition: windrvr.h:1035
@ S_IO
Definition: windrvr.h:1030
@ S_PLATFORM
Definition: windrvr.h:1045
@ S_DMA
Definition: windrvr.h:1034
@ S_LICENSE
Definition: windrvr.h:1036
@ S_EVENT
Definition: windrvr.h:1042
@ S_INT
Definition: windrvr.h:1032
@ S_USB
Definition: windrvr.h:1040
@ S_ALL
Definition: windrvr.h:1029
@ S_KER_PLUG
Definition: windrvr.h:1041
@ S_MEM
Definition: windrvr.h:1031
@ S_KER_BUF
Definition: windrvr.h:1044
@ S_KER_DRV
Definition: windrvr.h:1039
@ S_PCI
Definition: windrvr.h:1033
@ S_PNP
Definition: windrvr.h:1037
@ S_IPC
Definition: windrvr.h:1043
@ S_CARD_REG
Definition: windrvr.h:1038
struct WD_VERSION WD_VERSION_V30
struct WD_LICENSE WD_LICENSE_V122
WD_PCI_SCAN_OPTIONS
Definition: windrvr.h:929
@ WD_PCI_SCAN_BY_TOPOLOGY
Definition: windrvr.h:931
@ WD_PCI_SCAN_DEFAULT
Definition: windrvr.h:930
@ WD_PCI_SCAN_INCLUDE_DOMAINS
Definition: windrvr.h:933
@ WD_PCI_SCAN_REGISTERED
Definition: windrvr.h:932
WD_TRANSFER_CMD
IN WD_TRANSFER_CMD and WD_Transfer() DWORD stands for 32 bits and QWORD is 64 bit.
Definition: windrvr.h:398
@ WM_SWORD
Write memory string word.
Definition: windrvr.h:434
@ WM_SBYTE
Write memory string byte.
Definition: windrvr.h:433
@ RP_SDWORD
Read port string dword.
Definition: windrvr.h:414
@ WM_BYTE
Write memory byte.
Definition: windrvr.h:424
@ WM_SQWORD
Write memory string quad word.
Definition: windrvr.h:437
@ RM_DWORD
Read memory dword.
Definition: windrvr.h:423
@ WP_DWORD
Write port dword.
Definition: windrvr.h:408
@ RP_BYTE
Read port byte.
Definition: windrvr.h:403
@ WM_SDWORD
Write memory string dword.
Definition: windrvr.h:435
@ RM_WORD
Read memory word.
Definition: windrvr.h:422
@ RM_SBYTE
Read memory string byte.
Definition: windrvr.h:430
@ WP_SQWORD
Write port string qword.
Definition: windrvr.h:419
@ RM_BYTE
Read memory byte.
Definition: windrvr.h:421
@ WP_SBYTE
Write port string byte.
Definition: windrvr.h:415
@ WP_SWORD
Write port string word.
Definition: windrvr.h:416
@ RM_SWORD
Read memory string word.
Definition: windrvr.h:431
@ CMD_MASK
Interrupt Mask.
Definition: windrvr.h:401
@ WM_DWORD
Write memory dword.
Definition: windrvr.h:426
@ CMD_NONE
No command.
Definition: windrvr.h:399
@ RP_DWORD
Read port dword.
Definition: windrvr.h:405
@ CMD_END
End command.
Definition: windrvr.h:400
@ WP_BYTE
Write port byte.
Definition: windrvr.h:406
@ RP_QWORD
Read port qword.
Definition: windrvr.h:409
@ WM_QWORD
Write memory qword.
Definition: windrvr.h:428
@ RM_SDWORD
Read memory string dword.
Definition: windrvr.h:432
@ RM_QWORD
Read memory qword.
Definition: windrvr.h:427
@ WP_WORD
Write port word.
Definition: windrvr.h:407
@ WP_SDWORD
Write port string dword.
Definition: windrvr.h:417
@ RM_SQWORD
Read memory string quad word.
Definition: windrvr.h:436
@ RP_SWORD
Read port string word.
Definition: windrvr.h:413
@ WM_WORD
Write memory word.
Definition: windrvr.h:425
@ RP_SBYTE
Read port string byte.
Definition: windrvr.h:412
@ WP_QWORD
Write port qword.
Definition: windrvr.h:410
@ RP_WORD
Read port word.
Definition: windrvr.h:404
@ RP_SQWORD
Read port string qword.
Definition: windrvr.h:418
#define INVALID_HANDLE_VALUE
Definition: windrvr.h:1621
@ WD_IPC_MAX_PROCS
Definition: windrvr.h:838
#define WD_MAX_KP_NAME_LENGTH
Definition: windrvr.h:60
#define WIN32
Definition: windrvr.h:187
#define WD_Close
Definition: windrvr.h:1911
#define WD_CloseLocal(h)
Definition: windrvr.h:1860
@ WD_IPC_UID_UNICAST
Definition: windrvr.h:851
@ WD_IPC_SUBGROUP_MULTICAST
Definition: windrvr.h:852
@ WD_IPC_MULTICAST
Definition: windrvr.h:853
WD_EVENT_OPTION
Definition: windrvr.h:1543
@ WD_ACCEPT_CONTROL
used in WD_EVENT_SEND (acknowledge)
Definition: windrvr.h:1545
@ WD_ACKNOWLEDGE
Definition: windrvr.h:1544
#define BZERO(buf)
Definition: windrvr.h:1617
WD_PCI_SCAN_CAPS_OPTIONS
Definition: windrvr.h:946
@ WD_PCI_SCAN_CAPS_BASIC
Scan basic PCI capabilities.
Definition: windrvr.h:947
@ WD_PCI_SCAN_CAPS_EXTENDED
Scan extended (PCIe) PCI capabilities.
Definition: windrvr.h:948
struct WD_DEBUG WD_DEBUG_V40
DWORD WD_BUS_TYPE
Definition: windrvr.h:716
UINT64 PHYS_ADDR
Definition: windrvr.h:391
struct WD_DEBUG_DUMP WD_DEBUG_DUMP_V40
@ INTERRUPT_MESSAGE
Message-Signaled Interrupts (MSI).
Definition: windrvr.h:635
@ INTERRUPT_CMD_RETURN_VALUE
Obsolete.
Definition: windrvr.h:634
@ INTERRUPT_LATCHED
Legacy Latched Interrupts .
Definition: windrvr.h:623
@ INTERRUPT_MESSAGE_X
Extended Message-Signaled Interrupts (MSI-X).
Definition: windrvr.h:636
@ INTERRUPT_CMD_COPY
Copy any data read in the kernel as a result of a read transfer command, and return it to the user wi...
Definition: windrvr.h:626
@ INTERRUPT_LEVEL_SENSITIVE
Legacy Level Sensitive Interrupts.
Definition: windrvr.h:624
@ INTERRUPT_EDGE_SENSITIVE
Legacy Edge Sensitive Interrupts.
Definition: windrvr.h:631
@ INTERRUPT_DONT_GET_MSI_MESSAGE
Linux Only.
Definition: windrvr.h:638
struct WD_PCI_SCAN_CAPS WD_PCI_SCAN_CAPS_V118
struct WD_DMA_PAGE WD_DMA_PAGE_V80
struct WD_EVENT WD_EVENT_V121
struct WD_IPC_REGISTER WD_IPC_REGISTER_V121
struct WD_KERNEL_PLUGIN WD_KERNEL_PLUGIN_V40
DWORD DLLCALLCONV check_secureBoot_enabled(void)
Checks whether the Secure Boot feature is enabled on the system.
void(DLLCALLCONV * DMA_TRANSACTION_CALLBACK)(PVOID pData)
Definition: windrvr.h:544
struct WD_PCI_SRIOV WD_PCI_SRIOV_V122
const char *DLLCALLCONV WD_DriverName(const char *sName)
Sets the name of the WinDriver kernel module, which will be used by the calling application.
unsigned __int64 UINT64
Definition: windrvr.h:318
#define REGKEY_BUFSIZE
Definition: windrvr.h:1762
struct WD_IPC_SEND WD_IPC_SEND_V121
@ WD_PLATFORM_CARDS
Definition: windrvr.h:912
#define WD_PROCESS_NAME_LENGTH
Definition: windrvr.h:820
@ WD_USB_HARD_RESET
Definition: windrvr.h:1612
@ WD_USB_CYCLE_PORT
Definition: windrvr.h:1613
@ WD_PCI_MAX_CAPS
Definition: windrvr.h:936
@ WD_BUS_EISA
EISA, including ISA PnP.
Definition: windrvr.h:712
@ WD_BUS_ISA
ISA.
Definition: windrvr.h:711
@ WD_BUS_PLATFORM
Platform Device.
Definition: windrvr.h:714
@ WD_BUS_UNKNOWN
Unknown bus type.
Definition: windrvr.h:710
@ WD_BUS_PCI
PCI.
Definition: windrvr.h:713
@ WD_BUS_USB
USB.
Definition: windrvr.h:709
#define DLLCALLCONV
Definition: windrvr.h:32
WD_EVENT_ACTION
Definition: windrvr.h:1521
@ WD_POWER_SYSTEM_WORKING
Definition: windrvr.h:1530
@ WD_POWER_SYSTEM_SLEEPING3
Definition: windrvr.h:1533
@ WD_POWER_SYSTEM_HIBERNATE
Definition: windrvr.h:1534
@ WD_POWER_CHANGED_D0
Power states for the power management.
Definition: windrvr.h:1525
@ WD_OBSOLETE
Obsolete.
Definition: windrvr.h:1524
@ WD_POWER_SYSTEM_SLEEPING2
Definition: windrvr.h:1532
@ WD_POWER_CHANGED_D3
Definition: windrvr.h:1529
@ WD_POWER_SYSTEM_SHUTDOWN
Definition: windrvr.h:1535
@ WD_POWER_CHANGED_D2
Definition: windrvr.h:1528
@ WD_INSERT
Definition: windrvr.h:1522
@ WD_POWER_CHANGED_D1
Definition: windrvr.h:1527
@ WD_POWER_SYSTEM_SLEEPING1
Definition: windrvr.h:1531
@ WD_REMOVE
Definition: windrvr.h:1523
@ WD_IPC_UNICAST_MSG
Definition: windrvr.h:1536
@ WD_IPC_MULTICAST_MSG
Definition: windrvr.h:1537
@ WD_PCI_CARDS
Definition: windrvr.h:879
@ WD_PCI_CAP_ID_ALL
Definition: windrvr.h:938
UINT64 DMA_ADDR
Definition: windrvr.h:390
DWORD WD_EVENT_TYPE
Definition: windrvr.h:1564
struct WD_PCI_SCAN_CARDS WD_PCI_SCAN_CARDS_V124
WD_DMA_OPTIONS
Definition: windrvr.h:446
@ DMA_KERNEL_BUFFER_ALLOC
The system allocates a contiguous buffer.
Definition: windrvr.h:447
@ DMA_DISABLE_MERGE_ADJACENT_PAGES
Disable merge adjacent pages.
Definition: windrvr.h:496
@ DMA_TRANSACTION
Use this flag to use the DMA transaction mechanism.
Definition: windrvr.h:491
@ DMA_TO_DEVICE
memory pages are locked to be read by device
Definition: windrvr.h:467
@ DMA_KBUF_BELOW_16M
If DMA_KERNEL_BUFFER_ALLOC is used, this will make sure it is under 16M.
Definition: windrvr.h:450
@ DMA_ALLOW_NO_HCARD
Allow memory lock without hCard.
Definition: windrvr.h:475
@ DMA_FROM_DEVICE
memory pages are locked to be written by device
Definition: windrvr.h:464
@ DMA_GET_PREALLOCATED_BUFFERS_ONLY
Windows: Try to allocate buffers from preallocated buffers pool ONLY (if none of them are available,...
Definition: windrvr.h:487
@ DMA_GET_EXISTING_BUF
Get existing buffer by hDma handle.
Definition: windrvr.h:477
@ DMA_ALLOW_64BIT_ADDRESS
Use this value for devices that support 64-bit DMA addressing.
Definition: windrvr.h:472
@ DMA_OVERRIDE_CMA_VALIDATION
Linux: Override CMA validation checks for contiguous buffer locking.
Definition: windrvr.h:500
@ DMA_TO_FROM_DEVICE
memory pages are locked for both read and write
Definition: windrvr.h:469
@ DMA_LARGE_BUFFER
If DMA_LARGE_BUFFER is used, the maximum number of pages are dwPages, and not WD_DMA_PAGES.
Definition: windrvr.h:453
@ DMA_GPUDIRECT
Linux only.
Definition: windrvr.h:494
@ DMA_ALLOW_CACHE
Allow caching of contiguous memory.
Definition: windrvr.h:459
@ DMA_KERNEL_ONLY_MAP
Only map to kernel, dont map to user-mode.
Definition: windrvr.h:461
@ DMA_KBUF_ALLOC_SPECIFY_ADDRESS_WIDTH
When using this flag, the width of the address must be entered in the fourth byte of dwOptions and th...
Definition: windrvr.h:481
@ DMA_RESERVED_MEM
Definition: windrvr.h:479
@ WD_CARD_ITEMS
Definition: windrvr.h:800
@ WD_MATCH_EXCLUDE
Exclude if there is a match.
Definition: windrvr.h:525
unsigned int UINT32
Definition: windrvr.h:341
#define DEBUG_USER_BUF_LEN
Definition: windrvr.h:1077
struct WD_CARD_REGISTER WD_CARD_REGISTER_V118
WD_INTERRUPT_WAIT_RESULT
Definition: windrvr.h:652
@ INTERRUPT_INTERRUPTED
Wait was interrupted before an actual hardware interrupt was received.
Definition: windrvr.h:655
@ INTERRUPT_RECEIVED
Interrupt was received.
Definition: windrvr.h:653
@ INTERRUPT_STOPPED
Interrupt was disabled during wait.
Definition: windrvr.h:654
UINT32 KPTR
Definition: windrvr.h:381
#define WD_Open
Definition: windrvr.h:1912
struct WD_IPC_PROCESS WD_IPC_PROCESS_V121
WD_OS_INFO DLLCALLCONV get_os_type(void)
Retrieves the type of the operating system in section.
#define PAD_TO_64(pName)
Definition: windrvr_usb.h:15