Jungo WinDriver  
Official Documentation
wdc_lib.h
Go to the documentation of this file.
1/* @JUNGO_COPYRIGHT@ */
2
3#ifndef _WDC_LIB_H_
4#define _WDC_LIB_H_
5
6/*********************************************************************
7* File: wdc_lib.h - Shared WD card (WDC) library header. *
8* This file defines the WDC library's high-level *
9* interface *
10**********************************************************************/
11
12#if defined(__KERNEL__)
13 #include "kpstdlib.h"
14#endif
15#include "windrvr.h"
16#include "windrvr_int_thread.h"
17#include "windrvr_events.h"
18#include "bits.h"
19#include "pci_regs.h"
20
21#ifdef __cplusplus
22 extern "C" {
23#endif
24/**************************************************************
25 General definitions
26 **************************************************************/
27
28#define MAX_NAME 128
29#define MAX_DESC 128
30#define MAX_NAME_DISPLAY 22
31
33typedef void *WDC_DEVICE_HANDLE;
34
35#ifndef __KERNEL__
37typedef struct {
43#endif
44
46typedef struct {
47 DWORD dwNumCaps;
51
52/* Driver open options */
53/* Basic driver open flags */
54#define WDC_DRV_OPEN_CHECK_VER 0x1
57#define WDC_DRV_OPEN_REG_LIC 0x2
58#define WDC_DRV_OPEN_AGENT_DEFAULT_WAIT 0x10
59#define WDC_DRV_OPEN_AGENT_LONG_WAIT 0x20
61#define WDC_DRV_OPEN_AGENT_INFINITE_WAIT 0x40
63/* Convenient driver open options */
64#define WDC_DRV_OPEN_BASIC 0x0
68#define WDC_DRV_OPEN_KP WDC_DRV_OPEN_BASIC
70#define WDC_DRV_OPEN_ALL (WDC_DRV_OPEN_CHECK_VER | WDC_DRV_OPEN_REG_LIC | WDC_DRV_OPEN_AGENT_DEFAULT_WAIT)
71#if defined(__KERNEL__)
72 #define WDC_DRV_OPEN_DEFAULT WDC_DRV_OPEN_KP
73#else
74 #define WDC_DRV_OPEN_DEFAULT WDC_DRV_OPEN_CHECK_VER | WDC_DRV_OPEN_REG_LIC
75#endif
77
78/* Debug information display options */
79#define WDC_DBG_OUT_DBM 0x1
81#define WDC_DBG_OUT_FILE 0x2
84#define WDC_DBG_LEVEL_ERR 0x10
85#define WDC_DBG_LEVEL_TRACE 0x20
88#define WDC_DBG_NONE 0x100
91#define WDC_DBG_DEFAULT (WDC_DBG_OUT_DBM | WDC_DBG_LEVEL_TRACE)
92
93#define WDC_DBG_DBM_ERR (WDC_DBG_OUT_DBM | WDC_DBG_LEVEL_ERR)
94#define WDC_DBG_DBM_TRACE (WDC_DBG_OUT_DBM | WDC_DBG_LEVEL_TRACE)
95
96#if !defined(__KERNEL__)
97 #define WDC_DBG_FILE_ERR (WDC_DBG_OUT_FILE | WDC_DBG_LEVEL_ERR)
98 #define WDC_DBG_FILE_TRACE (WDC_DBG_OUT_FILE | WDC_DBG_LEVEL_TRACE)
99
100 #define WDC_DBG_DBM_FILE_ERR \
101 (WDC_DBG_OUT_DBM | WDC_DBG_OUT_FILE | WDC_DBG_LEVEL_ERR)
102 #define WDC_DBG_DBM_FILE_TRACE \
103 (WDC_DBG_OUT_DBM | WDC_DBG_OUT_FILE | WDC_DBG_LEVEL_TRACE)
104
105 #define WDC_DBG_FULL \
106 (WDC_DBG_OUT_DBM | WDC_DBG_OUT_FILE | WDC_DBG_LEVEL_TRACE)
107#else
108 #define WDC_DBG_FULL (WDC_DBG_OUT_DBM | WDC_DBG_LEVEL_TRACE)
109#endif
110
111typedef DWORD WDC_DBG_OPTIONS;
112
114#define WDC_SLEEP_BUSY 0
115#define WDC_SLEEP_NON_BUSY SLEEP_NON_BUSY
116typedef DWORD WDC_SLEEP_OPTIONS;
117
118/* -----------------------------------------------
119 Memory / I/O / Registers
120 ----------------------------------------------- */
122struct WDC_ADDR_DESC;
123
124typedef enum {
126 WDC_READ = 0x2,
129
131typedef enum {
132 WDC_ADDR_RW_DEFAULT = 0x0,
137
138/* Memory/I/O address size and access mode definitions (size - in bytes) */
139#define WDC_SIZE_8 ((DWORD)sizeof(BYTE))
140#define WDC_SIZE_16 ((DWORD)sizeof(WORD))
141#define WDC_SIZE_32 ((DWORD)sizeof(UINT32))
142#define WDC_SIZE_64 ((DWORD)sizeof(UINT64))
143typedef DWORD WDC_ADDR_SIZE;
144
145typedef enum {
151
152#define WDC_ADDR_MODE_TO_SIZE(mode) (DWORD)mode
153#define WDC_ADDR_SIZE_TO_MODE(size) (((size) > WDC_SIZE_32) ? WDC_MODE_64 : \
154 ((size) > WDC_SIZE_16) ? WDC_MODE_32 : \
155 ((size) > WDC_SIZE_8) ? WDC_MODE_16 : WDC_MODE_8)
156
158#define WDC_AD_CFG_SPACE 0xFF
159
160/**************************************************************
161 Function Prototypes
162 **************************************************************/
163/* -----------------------------------------------
164 General
165 ----------------------------------------------- */
178
187
195
205DWORD DLLCALLCONV WDC_Sleep(_In_ DWORD dwMicroSecs,
206 _In_ WDC_SLEEP_OPTIONS options);
207
227DWORD DLLCALLCONV WDC_Version(_Outptr_ CHAR *pcVersion, _In_ DWORD dwLen,
228 _Outptr_ DWORD *pdwVersion);
229
259 _In_ const CHAR *pcLicense);
260
274
278#ifndef __KERNEL__
303DWORD DLLCALLCONV WDC_PciScanDevices(_In_ DWORD dwVendorId,
304 _In_ DWORD dwDeviceId, _Outptr_ WDC_PCI_SCAN_RESULT *pPciScanResult);
305
331 _In_ DWORD dwDeviceId, _Outptr_ WDC_PCI_SCAN_RESULT *pPciScanResult);
332
358 _In_ DWORD dwDeviceId, _Outptr_ WDC_PCI_SCAN_RESULT *pPciScanResult);
359#endif
360
379 _Outptr_ DWORD *pdwOffset);
396 _Outptr_ WDC_PCI_HEADER_TYPE *pHeaderType);
397
414 _In_ DWORD dwCapId, _Outptr_ WDC_PCI_SCAN_CAPS_RESULT *pScanCapsResult);
415
433 _In_ DWORD dwCapId, _Outptr_ WDC_PCI_SCAN_CAPS_RESULT *pScanCapsResult);
434
453 _In_ DWORD dwCapId, _Outptr_ WDC_PCI_SCAN_CAPS_RESULT *pScanCapsResult);
454
465
476
480#ifndef __KERNEL__
495#endif
496
520 _In_ DWORD dwNumVFs);
521
534
549 _Outptr_ DWORD *pdwNumVFs);
550
554#if !defined(__KERNEL__)
582 _In_ const WD_PCI_CARD_INFO *pDeviceInfo, _In_ const PVOID pDevCtx);
583
613 _In_ const WD_CARD *pDeviceInfo, _In_ const PVOID pDevCtx);
614
628
640#endif
641
676 _In_ WD_TRANSFER *pTransCmds, _In_ DWORD dwCmds, _In_ BOOL fForceCleanup);
677
696 _In_ const CHAR *pcKPDriverName, _In_ PVOID pKPOpenData);
697
723 _In_ DWORD dwMsg, _Inout_ PVOID pData, _Outptr_ PDWORD pdwResult);
724
733#define WDC_ReadMem8(addr, off) *(volatile BYTE *)((UPTR)(addr) + (UPTR)(off))
734
738#define WDC_ReadMem16(addr, off) \
739 *(volatile WORD *)((UPTR)(addr) + (UPTR)(off))
740
744#define WDC_ReadMem32(addr, off) \
745 *(volatile UINT32 *)((UPTR)(addr) + (UPTR)(off))
746
750#define WDC_ReadMem64(addr, off) \
751 *(volatile UINT64 *)((UPTR)(addr) + (UPTR)(off))
752
753
757#define WDC_WriteMem8(addr, off, val) \
758 *(volatile BYTE * )(((UPTR)(addr) + (UPTR)(off))) = (val)
759
763#define WDC_WriteMem16(addr, off, val) \
764 *(volatile WORD * )(((UPTR)(addr) + (UPTR)(off))) = (val)
765
769#define WDC_WriteMem32(addr, off, val) \
770 *(volatile UINT32 *)(((UPTR)(addr) + (UPTR)(off))) = (val)
771
775#define WDC_WriteMem64(addr, off, val) \
776 *(volatile UINT64 *)(((UPTR)(addr) + (UPTR)(off))) = (val)
777
778
796 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _Outptr_ BYTE *pbVal);
797
813 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _Outptr_ WORD *pwVal);
814
830 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _Outptr_ UINT32 *pdwVal);
831
847 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _Outptr_ UINT64 *pqwVal);
848
863 _In_ KPTR dwOffset, _In_ BYTE *pbVal);
864
879 _In_ KPTR dwOffset, _In_ WORD *pwVal);
880
895 _In_ KPTR dwOffset, _In_ UINT32 *pdwVal);
896
911 _In_ KPTR dwOffset, _In_ UINT64 *pqwVal);
912
927 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ BYTE bVal);
928
943 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ WORD wVal);
944
959 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ UINT32 dwVal);
960
975 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ UINT64 qwVal);
976
990 _In_ KPTR dwOffset, _In_ BYTE bVal);
991
1005 _In_ KPTR dwOffset, _In_ WORD wVal);
1006
1020 _In_ KPTR dwOffset, _In_ UINT32 dwVal);
1021
1035 _In_ KPTR dwOffset, _In_ UINT64 qwVal);
1036
1037
1059 _In_ DWORD dwAddrSpace,_In_ KPTR dwOffset, _In_ DWORD dwBytes,
1060 _Outptr_ PVOID pData, _In_ WDC_ADDR_MODE mode,
1061 _In_ WDC_ADDR_RW_OPTIONS options);
1062
1083 _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ DWORD dwBytes,
1084 _In_ PVOID pData, _In_ WDC_ADDR_MODE mode,
1085 _In_ WDC_ADDR_RW_OPTIONS options);
1086
1088/* @snippet highlevel_examples.c WDC_ReadAddrBlock8 */
1089#define WDC_ReadAddrBlock8(hDev,dwAddrSpace,dwOffset,dwBytes,pData,options) \
1090 WDC_ReadAddrBlock(hDev, dwAddrSpace, dwOffset, dwBytes, pData, \
1091 WDC_MODE_8, options)
1092
1094/* @snippet highlevel_examples.c WDC_ReadAddrBlock16 */
1095#define WDC_ReadAddrBlock16(hDev,dwAddrSpace,dwOffset,dwBytes,pData,options) \
1096 WDC_ReadAddrBlock(hDev, dwAddrSpace, dwOffset, dwBytes, pData, \
1097 WDC_MODE_16, options)
1098
1100/* @snippet highlevel_examples.c WDC_ReadAddrBlock32 */
1101#define WDC_ReadAddrBlock32(hDev,dwAddrSpace,dwOffset,dwBytes,pData,options) \
1102 WDC_ReadAddrBlock(hDev, dwAddrSpace, dwOffset, dwBytes, pData, \
1103 WDC_MODE_32, options)
1104
1106/* @snippet highlevel_examples.c WDC_ReadAddrBlock64 */
1107#define WDC_ReadAddrBlock64(hDev,dwAddrSpace,dwOffset,dwBytes,pData,options) \
1108 WDC_ReadAddrBlock(hDev, dwAddrSpace, dwOffset, dwBytes, pData, \
1109 WDC_MODE_64, options)
1110
1112/* @snippet highlevel_examples.c WDC_WriteAddrBlock8 */
1113#define WDC_WriteAddrBlock8(hDev,dwAddrSpace,dwOffset,dwBytes,pData,options) \
1114 WDC_WriteAddrBlock(hDev, dwAddrSpace, dwOffset, dwBytes, pData, \
1115 WDC_MODE_8, options)
1116
1118/* @snippet highlevel_examples.c WDC_WriteAddrBlock16 */
1119#define WDC_WriteAddrBlock16(hDev,dwAddrSpace,dwOffset,dwBytes,pData,options) \
1120 WDC_WriteAddrBlock(hDev, dwAddrSpace, dwOffset, dwBytes, pData, \
1121 WDC_MODE_16, options)
1122
1124/* @snippet highlevel_examples.c WDC_WriteAddrBlock32 */
1125#define WDC_WriteAddrBlock32(hDev,dwAddrSpace,dwOffset,dwBytes,pData,options) \
1126 WDC_WriteAddrBlock(hDev, dwAddrSpace, dwOffset, dwBytes, pData, \
1127 WDC_MODE_32, options)
1128
1130/* @snippet highlevel_examples.c WDC_WriteAddrBlock64 */
1131#define WDC_WriteAddrBlock64(hDev,dwAddrSpace,dwOffset,dwBytes,pData,options) \
1132 WDC_WriteAddrBlock(hDev, dwAddrSpace, dwOffset, dwBytes, pData, \
1133 WDC_MODE_64, options)
1134
1146 _In_ DWORD dwNumTrans);
1147
1160 _In_ DWORD dwAddrSpace);
1161
1186 _In_ DWORD dwOffset, _Outptr_ PVOID pData, _In_ DWORD dwBytes);
1187
1205 _In_ DWORD dwOffset, _In_ PVOID pData, _In_ DWORD dwBytes);
1206
1207
1226 _In_ DWORD dwOffset, _Outptr_ PVOID pData, _In_ DWORD dwBytes);
1227
1243 _In_ DWORD dwOffset, _In_ PVOID pData, _In_ DWORD dwBytes);
1244
1265 _In_ DWORD dwOffset, _Outptr_ BYTE *pbVal);
1266
1284 _In_ DWORD dwOffset, _Outptr_ WORD *pwVal);
1285
1303 _In_ DWORD dwOffset, _Outptr_ UINT32 *pdwVal);
1304
1322 _In_ DWORD dwOffset, _Outptr_ UINT64 *pqwVal);
1323
1340 _In_ DWORD dwOffset, _In_ BYTE bVal);
1341
1358 _In_ DWORD dwOffset, _In_ WORD wVal);
1359
1377 _In_ DWORD dwOffset, _In_ UINT32 dwVal);
1378
1395 _In_ DWORD dwOffset, _In_ UINT64 qwVal);
1396
1415 _In_ DWORD dwOffset, _Outptr_ BYTE *pbVal);
1416
1432 _In_ DWORD dwOffset, _Outptr_ WORD *pwVal);
1433
1449 _In_ DWORD dwOffset, _Outptr_ UINT32 *pdwVal);
1450
1466 _In_ DWORD dwOffset, _Outptr_ UINT64 *pqwVal);
1467
1482 _In_ DWORD dwOffset, _In_ BYTE bVal);
1483
1498 _In_ DWORD dwOffset, _In_ WORD wVal);
1499
1514 _In_ DWORD dwOffset, _In_ UINT32 dwVal);
1515
1530 _In_ DWORD dwOffset, _In_ UINT64 qwVal);
1531
1535#if !defined(__KERNEL__)
1584 _Outptr_ PVOID *ppBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize,
1585 _Outptr_ WD_DMA **ppDma);
1586
1623 _In_ PVOID pBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize,
1624 _Outptr_ WD_DMA **ppDma);
1625
1626
1627typedef struct {
1632 PVOID pData;
1635
1681 _Outptr_ PVOID *ppBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize,
1682 _Outptr_ WD_DMA **ppDma, _In_ WDC_INTERRUPT_PARAMS *pInterruptParams,
1683 _In_ DWORD dwAlignment);
1684
1727 _In_ PVOID pBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize,
1728 _Outptr_ WD_DMA **ppDma, _In_ WDC_INTERRUPT_PARAMS *pInterruptParams,
1729 _In_ DWORD dwMaxTransferSize, _In_ DWORD dwTransferElementSize);
1730
1759 _In_ DMA_TRANSACTION_CALLBACK funcDMATransactionCallback,
1760 _In_ PVOID DMATransactionCallbackCtx);
1761
1788 _In_ BOOL fRunCallback);
1789
1809
1830
1868 _In_ PHYS_ADDR qwAddr, _Outptr_ PVOID *ppBuf, _In_ DWORD dwOptions,
1869 _In_ DWORD dwDMABufSize, _Outptr_ WD_DMA **ppDma);
1870
1871
1892
1895#define WDC_DMAGetGlobalHandle(pDma) ((pDma)->hDma)
1896
1912DWORD DLLCALLCONV WDC_DMABufGet(_In_ DWORD hDma, _Outptr_ WD_DMA **ppDma);
1913
1933
1953#endif
1954/* -----------------------------------------------
1955 Interrupts
1956 ----------------------------------------------- */
1957#if !defined(__KERNEL__)
2095 _In_ WD_TRANSFER *pTransCmds, _In_ DWORD dwNumCmds, _In_ DWORD dwOptions,
2096 _In_ INT_HANDLER funcIntHandler, _In_ PVOID pData, _In_ BOOL fUseKP);
2097
2114
2115#endif
2116
2132
2147const CHAR * DLLCALLCONV WDC_IntType2Str(_In_ DWORD dwIntType);
2148
2153#if !defined(__KERNEL__)
2210 _In_ DWORD dwActions, _In_ EVENT_HANDLER funcEventHandler,
2211 _In_ PVOID pData, _In_ BOOL fUseKP);
2212
2227
2228#endif
2229
2244
2286 _In_ const CHAR *pcDbgFile);
2287
2299void DLLCALLCONV WDC_Err(const CHAR *format, ...);
2300
2311void DLLCALLCONV WDC_Trace(const CHAR *format, ...);
2312
2313#ifdef __cplusplus
2314}
2315#endif
2316
2317#endif /* _WDC_LIB_H_ */
2318
WDC_PCI_HEADER_TYPE
Definition: pci_regs.h:15
DWORD dwAddrSpace
Address space number.
Definition: wdc_defs.h:28
Address space information struct.
Definition: wdc_defs.h:27
INT_HANDLER funcIntHandler
Definition: wdc_lib.h:1631
WD_TRANSFER * pTransCmds
Definition: wdc_lib.h:1628
DWORD dwNumCaps
Number of matching PCI capabilities.
Definition: wdc_lib.h:47
PCI capabilities scan results.
Definition: wdc_lib.h:46
DWORD dwNumDevices
Number of matching devices.
Definition: wdc_lib.h:38
PCI scan results.
Definition: wdc_lib.h:37
DWORD DLLCALLCONV WDC_DMAReservedBufLock(_In_ WDC_DEVICE_HANDLE hDev, _In_ PHYS_ADDR qwAddr, _Outptr_ PVOID *ppBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize, _Outptr_ WD_DMA **ppDma)
Locks a physical reserved memory buffer for DMA and returns the corresponding user mode address of lo...
DWORD WDC_SLEEP_OPTIONS
Definition: wdc_lib.h:116
DWORD DLLCALLCONV WDC_WriteAddrByAddrDesc16(_In_ struct WDC_ADDR_DESC *pAddrDesc, _In_ KPTR dwOffset, _In_ WORD wVal)
Writes 2 byte (16 bits) to a specified memory or I/O address.
#define WDC_SIZE_64
Definition: wdc_lib.h:142
DWORD DLLCALLCONV WDC_DMASGBufLock(_In_ WDC_DEVICE_HANDLE hDev, _In_ PVOID pBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize, _Outptr_ WD_DMA **ppDma)
Locks a pre-allocated user-mode memory buffer for DMA and returns the corresponding physical mappings...
DWORD DLLCALLCONV WDC_IsaDeviceOpen(_Outptr_ WDC_DEVICE_HANDLE *phDev, _In_ const WD_CARD *pDeviceInfo, _In_ const PVOID pDevCtx)
Allocates and initializes a WDC ISA device structure, registers the device with WinDriver,...
DWORD DLLCALLCONV WDC_PciWriteCfg8(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _In_ BYTE bVal)
Writes 1 byte (8 bits) to a specified offset in a PCI device's configuration space or a PCI Express d...
DWORD DLLCALLCONV WDC_Sleep(_In_ DWORD dwMicroSecs, _In_ WDC_SLEEP_OPTIONS options)
Delays execution for the specified duration of time (in microseconds).
DWORD DLLCALLCONV WDC_IntEnable(_In_ WDC_DEVICE_HANDLE hDev, _In_ WD_TRANSFER *pTransCmds, _In_ DWORD dwNumCmds, _In_ DWORD dwOptions, _In_ INT_HANDLER funcIntHandler, _In_ PVOID pData, _In_ BOOL fUseKP)
Enables interrupt handling for the device.
DWORD DLLCALLCONV WDC_DMATransactionUninit(_In_ WD_DMA *pDma)
Unlocks and frees the memory allocated for a DMA buffer transaction by a previous call to WDC_DMATran...
DWORD DLLCALLCONV WDC_PciReadCfgBySlot64(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _Outptr_ UINT64 *pqwVal)
Reads 8 bytes (64 bits) from a specified offset in a PCI device's configuration space or a PCI Expres...
DWORD DLLCALLCONV WDC_PciScanDevices(_In_ DWORD dwVendorId, _In_ DWORD dwDeviceId, _Outptr_ WDC_PCI_SCAN_RESULT *pPciScanResult)
Scans the PCI bus for all devices with the specified vendor and device ID combination and returns inf...
DWORD DLLCALLCONV WDC_DMASyncIo(_In_ WD_DMA *pDma)
Synchronizes the I/O caches with the DMA buffer, by flushing the data from the I/O caches and updatin...
DWORD WDC_DRV_OPEN_OPTIONS
Definition: wdc_lib.h:76
DWORD WDC_CardCleanupSetup(_In_ WDC_DEVICE_HANDLE hDev, _In_ WD_TRANSFER *pTransCmds, _In_ DWORD dwCmds, _In_ BOOL fForceCleanup)
Sets a list of transfer cleanup commands to be performed for the specified card on any of the followi...
DWORD DLLCALLCONV WDC_PciReadCfgBySlot16(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _Outptr_ WORD *pwVal)
Reads 2 bytes (16 bits) from a specified offset in a PCI device's configuration space or a PCI Expres...
void DLLCALLCONV WDC_Trace(const CHAR *format,...)
Displays debug trace messages according to the WDC debug options.
DWORD DLLCALLCONV WDC_MultiTransfer(_In_ WD_TRANSFER *pTransCmds, _In_ DWORD dwNumTrans)
Performs a group of memory and/or I/O read/write transfers.
DWORD DLLCALLCONV WDC_PciSriovDisable(_In_ WDC_DEVICE_HANDLE hDev)
Disables SR-IOV for a supported device and removes all the assigned VFs.
void DLLCALLCONV WDC_Err(const CHAR *format,...)
Displays debug error messages according to the WDC debug options.
DWORD DLLCALLCONV WDC_WriteAddrByAddrDesc32(_In_ struct WDC_ADDR_DESC *pAddrDesc, _In_ KPTR dwOffset, _In_ UINT32 dwVal)
Writes 4 byte (32 bits) to a specified memory or I/O address.
DWORD DLLCALLCONV WDC_ReadAddrByAddrDesc16(_In_ struct WDC_ADDR_DESC *pAddrDesc, _In_ KPTR dwOffset, _In_ WORD *pwVal)
Reads 2 byte (16 bits) from a specified memory or I/O address.
DWORD DLLCALLCONV WDC_WriteAddr16(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ WORD wVal)
writes 2 byte (16 bits) to a specified memory or I/O address.
DWORD DLLCALLCONV WDC_PciGetHeaderType(_In_ WDC_DEVICE_HANDLE hDev, _Outptr_ WDC_PCI_HEADER_TYPE *pHeaderType)
Retrieves the PCI device's configuration space header type.
DWORD DLLCALLCONV WDC_DMATransactionSGInit(_In_ WDC_DEVICE_HANDLE hDev, _In_ PVOID pBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize, _Outptr_ WD_DMA **ppDma, _In_ WDC_INTERRUPT_PARAMS *pInterruptParams, _In_ DWORD dwMaxTransferSize, _In_ DWORD dwTransferElementSize)
Initializes the transaction and locks a pre-allocated user-mode memory buffer for DMA.
DWORD DLLCALLCONV WDC_IsaDeviceClose(_In_ WDC_DEVICE_HANDLE hDev)
Uninitializes a WDC ISA device structure and frees the memory allocated for it.
DWORD DLLCALLCONV WDC_SetDebugOptions(_In_ WDC_DBG_OPTIONS dbgOptions, _In_ const CHAR *pcDbgFile)
Sets debug options for the WDC library - see the description of WDC_DBG_OPTIONS for details regarding...
WDC_ADDR_MODE
Definition: wdc_lib.h:145
@ WDC_MODE_64
Definition: wdc_lib.h:149
@ WDC_MODE_32
Definition: wdc_lib.h:148
@ WDC_MODE_8
Definition: wdc_lib.h:146
@ WDC_MODE_16
Definition: wdc_lib.h:147
DWORD DLLCALLCONV WDC_PciGetExpressOffset(_In_ WDC_DEVICE_HANDLE hDev, _Outptr_ DWORD *pdwOffset)
Retrieves the PCI Express configuration registers' offset in the device's configuration space.
DWORD DLLCALLCONV WDC_ReadAddrByAddrDesc8(_In_ struct WDC_ADDR_DESC *pAddrDesc, _In_ KPTR dwOffset, _In_ BYTE *pbVal)
Reads 1 byte (8 bits) from a specified memory or I/O address.
DWORD DLLCALLCONV WDC_DMATransactionRelease(_In_ WD_DMA *pDma)
Terminates a specified DMA transaction without deleting the associated WD_DMA transaction structure.
WDC_DIRECTION
Definition: wdc_lib.h:124
@ WDC_READ_WRITE
Definition: wdc_lib.h:127
@ WDC_READ
Definition: wdc_lib.h:126
@ WDC_WRITE
Definition: wdc_lib.h:125
DWORD DLLCALLCONV WDC_DMATransactionExecute(_Inout_ WD_DMA *pDma, _In_ DMA_TRANSACTION_CALLBACK funcDMATransactionCallback, _In_ PVOID DMATransactionCallbackCtx)
Begins the execution of a specified DMA transaction.
DWORD DLLCALLCONV WDC_PciDeviceOpen(_Outptr_ WDC_DEVICE_HANDLE *phDev, _In_ const WD_PCI_CARD_INFO *pDeviceInfo, _In_ const PVOID pDevCtx)
Allocates and initializes a WDC PCI device structure, registers the device with WinDriver,...
DWORD DLLCALLCONV WDC_DMASyncCpu(_In_ WD_DMA *pDma)
Synchronizes the cache of all CPUs with the DMA buffer, by flushing the data from the CPU caches.
DWORD DLLCALLCONV WDC_PciWriteCfg64(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _In_ UINT64 qwVal)
Writes 8 bytes (64 bits) to a specified offset in a PCI device's configuration space or a PCI Express...
DWORD DLLCALLCONV WDC_PciWriteCfgBySlot64(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _In_ UINT64 qwVal)
writes 8 bytes (64 bits) to a specified offset in a PCI device's configuration space or a PCI Express...
PVOID DLLCALLCONV WDC_GetDevContext(_In_ WDC_DEVICE_HANDLE hDev)
Returns the device's user context information.
DWORD DLLCALLCONV WDC_ReadAddr8(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _Outptr_ BYTE *pbVal)
Read/write a device's address space (8/16/32/64 bits)
DWORD DLLCALLCONV WDC_ReadAddrBlock(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ DWORD dwBytes, _Outptr_ PVOID pData, _In_ WDC_ADDR_MODE mode, _In_ WDC_ADDR_RW_OPTIONS options)
Reads a block of data from the device.
DWORD DLLCALLCONV WDC_CallKerPlug(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwMsg, _Inout_ PVOID pData, _Outptr_ PDWORD pdwResult)
Sends a message from a user-mode application to a Kernel PlugIn driver.
DWORD DLLCALLCONV WDC_WriteAddrBlock(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ DWORD dwBytes, _In_ PVOID pData, _In_ WDC_ADDR_MODE mode, _In_ WDC_ADDR_RW_OPTIONS options)
Writes a block of data to the device.
DWORD DLLCALLCONV WDC_PciSriovGetNumVFs(_In_ WDC_DEVICE_HANDLE hDev, _Outptr_ DWORD *pdwNumVFs)
Gets the number of virtual functions assigned to a supported device.
DWORD DLLCALLCONV WDC_DriverClose(void)
Closes the WDC WinDriver handle (acquired and stored by a previous call to WDC_DriverOpen()) and unin...
DWORD DLLCALLCONV WDC_PciReadCfg(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _Outptr_ PVOID pData, _In_ DWORD dwBytes)
Identify device by handle.
DWORD DLLCALLCONV WDC_DMATransactionContigInit(_In_ WDC_DEVICE_HANDLE hDev, _Outptr_ PVOID *ppBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize, _Outptr_ WD_DMA **ppDma, _In_ WDC_INTERRUPT_PARAMS *pInterruptParams, _In_ DWORD dwAlignment)
Initializes the transaction, allocates a contiguous DMA buffer, locks it in physical memory,...
DWORD DLLCALLCONV WDC_DMABufUnlock(_In_ WD_DMA *pDma)
Unlocks and frees the memory allocated for a DMA buffer by a previous call to WDC_DMAContigBufLock(),...
DWORD DLLCALLCONV WDC_PciWriteCfgBySlot(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _In_ PVOID pData, _In_ DWORD dwBytes)
Write data to a specified offset in a PCI device's configuration space or a PCI Express device's exte...
#define WDC_SIZE_16
Definition: wdc_lib.h:140
BOOL DLLCALLCONV WDC_IntIsEnabled(_In_ WDC_DEVICE_HANDLE hDev)
Checks if a device's interrupts are currently enabled.
DWORD DLLCALLCONV WDC_PciGetExpressGen(_In_ WDC_DEVICE_HANDLE hDev)
Retrieves the PCI Express generation of a device.
DWORD DLLCALLCONV WDC_ReadAddrByAddrDesc64(_In_ struct WDC_ADDR_DESC *pAddrDesc, _In_ KPTR dwOffset, _In_ UINT64 *pqwVal)
Reads 8 byte (64 bits) from a specified memory or I/O address.
DWORD DLLCALLCONV WDC_PciDeviceClose(_In_ WDC_DEVICE_HANDLE hDev)
Uninitializes a WDC PCI device structure and frees the memory allocated for it.
const CHAR *DLLCALLCONV WDC_IntType2Str(_In_ DWORD dwIntType)
Converts interrupt type to string.
DWORD DLLCALLCONV WDC_WriteAddr32(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ UINT32 dwVal)
writes 4 byte (32 bits) to a specified memory or I/O address.
DWORD DLLCALLCONV WDC_EventRegister(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwActions, _In_ EVENT_HANDLER funcEventHandler, _In_ PVOID pData, _In_ BOOL fUseKP)
Registers the application to receive Plug-and-Play and power management events notifications for the ...
DWORD DLLCALLCONV WDC_WriteAddrByAddrDesc8(_In_ struct WDC_ADDR_DESC *pAddrDesc, _In_ KPTR dwOffset, _In_ BYTE bVal)
Writes 1 byte (8 bits) to a specified memory or I/O address.
HANDLE DLLCALLCONV WDC_GetWDHandle(void)
Get a handle to WinDriver.
DWORD WDC_ADDR_SIZE
Definition: wdc_lib.h:143
DWORD DLLCALLCONV WDC_DMABufGet(_In_ DWORD hDma, _Outptr_ WD_DMA **ppDma)
Retrieves a contiguous DMA buffer which was allocated by another process.
DWORD DLLCALLCONV WDC_IntDisable(_In_ WDC_DEVICE_HANDLE hDev)
Disables interrupt interrupt handling for the device, pursuant to a previous call to WDC_IntEnable()
DWORD DLLCALLCONV WDC_PciScanCaps(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwCapId, _Outptr_ WDC_PCI_SCAN_CAPS_RESULT *pScanCapsResult)
Scans the basic PCI capabilities of the given device for the specified capability (or for all capabil...
DWORD DLLCALLCONV WDC_PciReadCfg16(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _Outptr_ WORD *pwVal)
Reads 2 bytes (16 bits) from a specified offset in a PCI device's configuration space or a PCI Expres...
BOOL DLLCALLCONV WDC_AddrSpaceIsActive(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace)
Checks if the specified memory or I/O address space is active ,i.e., if its size is not zero.
DWORD DLLCALLCONV WDC_PciWriteCfgBySlot16(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _In_ WORD wVal)
writes 2 bytes (16 bits) to a specified offset in a PCI device's configuration space or a PCI Express...
DWORD DLLCALLCONV WDC_KernelPlugInOpen(_In_ WDC_DEVICE_HANDLE hDev, _In_ const CHAR *pcKPDriverName, _In_ PVOID pKPOpenData)
Opens a handle to a Kernel PlugIn driver.
DWORD DLLCALLCONV WDC_PciGetDeviceInfo(_Inout_ WD_PCI_CARD_INFO *pDeviceInfo)
Retrieves a PCI device's resources information (memory and I/O ranges and interrupt information).
#define WDC_SIZE_8
Definition: wdc_lib.h:139
DWORD DLLCALLCONV WDC_DMAContigBufLock(_In_ WDC_DEVICE_HANDLE hDev, _Outptr_ PVOID *ppBuf, _In_ DWORD dwOptions, _In_ DWORD dwDMABufSize, _Outptr_ WD_DMA **ppDma)
Allocates a contiguous DMA buffer, locks it in physical memory, and returns mappings of the allocated...
DWORD DLLCALLCONV WDC_PciReadCfg8(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _Outptr_ BYTE *pbVal)
Read/write 8/16/32/64 bits from the PCI configuration space.
DWORD DLLCALLCONV WDC_PciReadCfg64(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _Outptr_ UINT64 *pqwVal)
Reads 8 bytes (64 bits) from a specified offset in a PCI device's configuration space or a PCI Expres...
DWORD DLLCALLCONV WDC_ReadAddr16(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _Outptr_ WORD *pwVal)
reads 2 byte (16 bits) from a specified memory or I/O address.
DWORD DLLCALLCONV WDC_DMATransferCompletedAndCheck(_Inout_ WD_DMA *pDma, _In_ BOOL fRunCallback)
Notifies WinDriver that a device's DMA transfer operation is completed.
DWORD DLLCALLCONV WDC_PciScanRegisteredDevices(_In_ DWORD dwVendorId, _In_ DWORD dwDeviceId, _Outptr_ WDC_PCI_SCAN_RESULT *pPciScanResult)
Scans the PCI bus for all devices with the specified vendor and device ID combination that have been ...
DWORD DLLCALLCONV WDC_PciGetExpressGenBySlot(_In_ WD_PCI_SLOT *pPciSlot)
Retrieves the PCI Express generation of a device.
DWORD DLLCALLCONV WDC_PciReadCfg32(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _Outptr_ UINT32 *pdwVal)
Reads 4 bytes (32 bits) from a specified offset in a PCI device's configuration space or a PCI Expres...
DWORD DLLCALLCONV WDC_ReadAddrByAddrDesc32(_In_ struct WDC_ADDR_DESC *pAddrDesc, _In_ KPTR dwOffset, _In_ UINT32 *pdwVal)
Reads 4 byte (32 bits) from a specified memory or I/O address.
DWORD DLLCALLCONV WDC_Version(_Outptr_ CHAR *pcVersion, _In_ DWORD dwLen, _Outptr_ DWORD *pdwVersion)
Returns the version number of the WinDriver kernel module used by the WDC library.
DWORD DLLCALLCONV WDC_PciWriteCfgBySlot8(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _In_ BYTE bVal)
writes 1 byte (8 bits) to a specified offset in a PCI device's configuration space or a PCI Express d...
WDC_ADDR_RW_OPTIONS
Read/write address options.
Definition: wdc_lib.h:131
@ WDC_ADDR_RW_DEFAULT
Default: memory resource - direct access; autoincrement on block transfers.
Definition: wdc_lib.h:132
@ WDC_ADDR_RW_NO_AUTOINC
Hold device address constant while reading/writing a block.
Definition: wdc_lib.h:134
DWORD DLLCALLCONV WDC_PciReadCfgBySlot32(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _Outptr_ UINT32 *pdwVal)
Reads 4 bytes (32 bits) from a specified offset in a PCI device's configuration space or a PCI Expres...
#define WDC_SIZE_32
Definition: wdc_lib.h:141
WD_BUS_TYPE DLLCALLCONV WDC_GetBusType(_In_ WDC_DEVICE_HANDLE hDev)
Returns the device's bus type: WD_BUS_PCI, WD_BUS_ISA or WD_BUS_UNKNOWN.
DWORD DLLCALLCONV WDC_WriteAddr8(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ BYTE bVal)
writes 1 byte (8 bits) to a specified memory or I/O address.
DWORD DLLCALLCONV WDC_ReadAddr32(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _Outptr_ UINT32 *pdwVal)
reads 4 byte (32 bits) from a specified memory or I/O address.
DWORD DLLCALLCONV WDC_PciReadCfgBySlot8(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _Outptr_ BYTE *pbVal)
Read/write 8/16/32/64 bits from the PCI configuration space.
DWORD DLLCALLCONV WDC_PciSriovEnable(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwNumVFs)
SR-IOV API functions are not part of the standard WinDriver API, and not included in the standard ver...
DWORD DLLCALLCONV WDC_PciScanDevicesByTopology(_In_ DWORD dwVendorId, _In_ DWORD dwDeviceId, _Outptr_ WDC_PCI_SCAN_RESULT *pPciScanResult)
Scans the PCI bus for all devices with the specified vendor and device ID combination and returns inf...
DWORD DLLCALLCONV WDC_WriteAddrByAddrDesc64(_In_ struct WDC_ADDR_DESC *pAddrDesc, _In_ KPTR dwOffset, _In_ UINT64 qwVal)
Writes 8 byte (64 bits) to a specified memory or I/O address.
DWORD WDC_DBG_OPTIONS
Definition: wdc_lib.h:111
DWORD DLLCALLCONV WDC_WriteAddr64(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _In_ UINT64 qwVal)
writes 8 byte (64 bits) to a specified memory or I/O address.
DWORD DLLCALLCONV WDC_PciWriteCfg(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _In_ PVOID pData, _In_ DWORD dwBytes)
Writes data to a specified offset in a PCI device's configuration space or a PCI Express device's ext...
DWORD DLLCALLCONV WDC_PciWriteCfgBySlot32(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _In_ UINT32 dwVal)
writes 4 bytes (32 bits) to a specified offset in a PCI device's configuration space or a PCI Express...
DWORD DLLCALLCONV WDC_PciWriteCfg32(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _In_ UINT32 dwVal)
Writes 4 bytes (32 bits) to a specified offset in a PCI device's configuration space or a PCI Express...
DWORD DLLCALLCONV WDC_ReadAddr64(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwAddrSpace, _In_ KPTR dwOffset, _Outptr_ UINT64 *pqwVal)
reads 8 byte (64 bits) from a specified memory or I/O address.
BOOL DLLCALLCONV WDC_EventIsRegistered(_In_ WDC_DEVICE_HANDLE hDev)
Checks if the application is currently registered to receive Plug-and-Play and power management notif...
DWORD DLLCALLCONV WDC_PciReadCfgBySlot(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwOffset, _Outptr_ PVOID pData, _In_ DWORD dwBytes)
Read/write a block of any length from the PCI configuration space.
DWORD DLLCALLCONV WDC_EventUnregister(_In_ WDC_DEVICE_HANDLE hDev)
Unregisters an application from a receiving Plug-and-Play and power management notifications for a de...
DWORD DLLCALLCONV WDC_PciScanCapsBySlot(_In_ WD_PCI_SLOT *pPciSlot, _In_ DWORD dwCapId, _Outptr_ WDC_PCI_SCAN_CAPS_RESULT *pScanCapsResult)
Scans the basic PCI capabilities of the given device for the specified capability (or for all capabil...
DWORD DLLCALLCONV WDC_PciWriteCfg16(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwOffset, _In_ WORD wVal)
Writes 2 bytes (16 bits) to a specified offset in a PCI device's configuration space or a PCI Express...
DWORD DLLCALLCONV WDC_PciScanExtCaps(_In_ WDC_DEVICE_HANDLE hDev, _In_ DWORD dwCapId, _Outptr_ WDC_PCI_SCAN_CAPS_RESULT *pScanCapsResult)
Scans the extended (PCI Express) PCI capabilities of the given device for the specified capability (o...
DWORD DLLCALLCONV WDC_DriverOpen(_In_ WDC_DRV_OPEN_OPTIONS openOptions, _In_ const CHAR *pcLicense)
Opens and stores a handle to WinDriver's kernel module and initializes the WDC library according to t...
void * WDC_DEVICE_HANDLE
Handle to device information struct.
Definition: wdc_lib.h:33
#define _Inout_
Definition: windrvr.h:38
unsigned short int WORD
Definition: windrvr.h:337
unsigned char BYTE
Definition: windrvr.h:336
#define _Outptr_
Definition: windrvr.h:40
DWORD WD_BUS_TYPE
Definition: windrvr.h:702
UINT64 PHYS_ADDR
Definition: windrvr.h:386
void(DLLCALLCONV * DMA_TRANSACTION_CALLBACK)(PVOID pData)
Definition: windrvr.h:534
#define _In_
Definition: windrvr.h:37
unsigned __int64 UINT64
Definition: windrvr.h:318
@ WD_PCI_MAX_CAPS
Definition: windrvr.h:903
#define DLLCALLCONV
Definition: windrvr.h:32
@ WD_PCI_CARDS
Definition: windrvr.h:863
unsigned int UINT32
Definition: windrvr.h:341
UINT32 KPTR
Definition: windrvr.h:376
void(* EVENT_HANDLER)(WD_EVENT *pEvent, void *pData)
void(DLLCALLCONV * INT_HANDLER)(PVOID pData)