This function sets up driver access to device I/O ports with the NdisRawReadPortXXX and NdisRawWritePortXXX functions and claims the range of I/O port addresses in the registry for that driver’s NIC.
| Header file: | Ndis.h |
| Windows CE versions: | 2.0 and later |
NDIS_STATUS NdisMRegisterIoPortRange( OUT PVOID *PortOffset,
IN NDIS_HANDLE MiniportAdapterHandle, IN UINT InitialPort,
IN UINT NumberOfPorts );
Returns one of the following:
An NIC driver calls this function from its MiniportInitialize function. MiniportInitialize must call NdisMSetAttributes or NdisMSetAttributesEx before calling this function.
This function maps a bus-relative device address range that the miniport can use subsequently to access an I/O port range on its NIC by calling the NdisRawXXX functions. A successful call claims the specified range of I/O ports in the registry for the caller’s NIC.
Because the parameters passed to the NdisRawXXX have been mapped, these functions run significantly faster than the corresponding NdisImmediateXXXPortXXX. After a successful call to this function, a miniport cannot call any of the NdisImmediateXXXPortXXX functions with either bus-relative addresses or mapped virtual addresses within such an I/O port range.
If its call to this function fails, MiniportInitialize releases all resources that it has already allocated for its NIC, and then fails initialization for that NIC.
Drivers of NICs with device registers in the host memory space call NdisMMapIoSpace and, subsequently, the NdisRead/WriteRegisterXXX functions to access the NIC registers.
A driver that calls this function runs at IRQL PASSIVE_LEVEL.
NdisMDeregisterIoPortRange, NdisMMapIoSpace, NdisRawReadPortBufferUchar, NdisRawReadPortBufferUlong, NdisRawReadPortBufferUshort, NdisRawReadPortUchar, NdisRawReadPortUlong, NdisRawReadPortUshort, NdisRawWritePortUchar, NdisRawWritePortUlong, NdisRawWritePortUshort