// wdm.h
NTSYSAPI NTSTATUS RtlIoEncodeMemIoResource(
[in] PIO_RESOURCE_DESCRIPTOR Descriptor,
[in] UCHAR Type,
[in] ULONGLONG Length,
[in] ULONGLONG Alignment,
[in] ULONGLONG MinimumAddress,
[in] ULONGLONG MaximumAddress
);
View the official Windows Driver Kit DDI reference
No description available.
The RtlIoEncodeMemIoResource routine updates an IO_RESOURCE_DESCRIPTOR structure to describe a range of memory or I/O port addresses.
Descriptor
[in]A pointer to the IO_RESOURCE_DESCRIPTOR structure to update.
Type
[in]The resource type of the address range. This parameter can be CmResourceTypeMemory, CmResourceTypeMemoryLarge, or CmResourceTypePort.
Length
[in]The length, in bytes, of the range of assignable addresses.
Alignment
[in]The alignment, in bytes, of the starting address of address range.
MinimumAddress
[in]The minimum address that can be assigned to the device.
MaximumAddress
[in]The maximum address that can be assigned to the device.
RtlIoEncodeMemIoResource returns an NTSTATUS value. This routine might return one of the following values:
Return code | Description |
---|---|
STATUS_SUCCESS | The IO_RESOURCE_DESCRIPTOR structure was updated. |
STATUS_UNSUCCESSFUL | The specified value for Length or Alignment could not be encoded in an IO_RESOURCE_DESCRIPTOR structure. |
STATUS_INVALID_PARAMETER | One or more of the specified parameters were invalid. |
Addresses that are larger than 32 bits in length must satisfy certain alignment restrictions, or else the routine returns STATUS_UNSUCCESSFUL.
Address length | Alignment restriction |
---|---|
40 bits | Lowest 8 bits must be zero. |
48 bits | Lowest 16 bits must be zero. |
64 bits | Lowest 32 bits must be zero. |