//0x288 bytes (sizeof)
struct _ADAPTER_OBJECT
{
struct _HALP_DMA_ADAPTER_OBJECT AdapterObject; //0x0
struct _HALP_DMA_MASTER_ADAPTER_OBJECT* MasterAdapter; //0xa0
struct _LIST_ENTRY WaitQueueEntry; //0xa8
union
{
struct _KDEVICE_QUEUE ChannelWaitQueue; //0xb8
struct
{
ULONGLONG ResourceWaitLock; //0xb8
struct _LIST_ENTRY ResourceWaitQueue; //0xc0
struct _LIST_ENTRY ChannelResourceWaitQueue; //0xd0
};
};
UCHAR ResourceQueueBusy; //0xe0
ULONG MapRegistersPerChannel; //0xe8
VOID* MapRegisterBase; //0xf0
ULONG NumberOfMapRegisters; //0xf8
ULONG MaxTransferLength; //0xfc
VOID* CrashDumpRegisterBase[2]; //0x100
ULONG NumberOfCrashDumpRegisters[2]; //0x110
ULONG CrashDumpRegisterRefCount[2]; //0x118
struct _LIST_ENTRY AdapterCrashDumpList; //0x120
struct _MDL* MapRegisterMdl; //0x130
ULONGLONG MapRegisterMdlLock; //0x138
struct _EX_PUSH_LOCK ExpiredLock; //0x140
VOID* AllocationHandle; //0x148
VOID* VirtualAddress; //0x150
UCHAR IsAllocationMdlBased; //0x158
UCHAR NoLocalPool; //0x159
UCHAR ExpiredFlag; //0x15a
struct _WAIT_CONTEXT_BLOCK* CurrentWcb; //0x160
struct _DMA_TRANSFER_CONTEXT* CurrentTransferContext; //0x168
struct _HALP_DMA_CONTROLLER* DmaController; //0x170
ULONG Controller; //0x178
ULONG ChannelNumber; //0x17c
ULONG RequestLine; //0x180
ULONG RequestedChannelCount; //0x184
ULONG AllocatedChannelCount; //0x188
ULONG AllocatedChannels[8]; //0x18c
VOID* ChannelAdapter; //0x1b0
UCHAR NeedsMapRegisters; //0x1b8
UCHAR MasterDevice; //0x1b9
UCHAR ScatterGather; //0x1ba
UCHAR AutoInitialize; //0x1bb
UCHAR IgnoreCount; //0x1bc
UCHAR CacheCoherent; //0x1bd
union
{
struct
{
UCHAR Dma32BitAddresses; //0x1c0
UCHAR Dma64BitAddresses; //0x1c1
};
ULONG DmaAddressWidth; //0x1c0
};
enum _DMA_WIDTH DmaPortWidth; //0x1c4
union _LARGE_INTEGER DeviceAddress; //0x1c8
struct _LIST_ENTRY AdapterList; //0x1d0
struct _WORK_QUEUE_ITEM WorkItem; //0x1e0
struct _HALP_DMA_DOMAIN_OBJECT* DomainPointer; //0x200
enum _HALP_DMA_TRANSLATION_TYPE TranslationType; //0x208
UCHAR AdapterInUse; //0x20c
struct _DEVICE_OBJECT* DeviceObject; //0x210
struct _EXT_IOMMU_DEVICE_ID* DeviceId; //0x218
struct _IOMMU_DMA_DEVICE* IommuDevice; //0x220
struct _MDL* ScatterGatherMdl; //0x228
struct _IOMMU_DMA_LOGICAL_ADDRESS_TOKEN* LowMemoryLogicalAddressToken; //0x230
ULONGLONG LowMemoryLogicalAddressQueueLock; //0x238
struct _LIST_ENTRY LowMemoryLogicalAddressQueue; //0x240
UCHAR LowMemoryLogicalAddressQueueInUse; //0x250
struct _HALP_EMERGENCY_LA_QUEUE_ENTRY LowMemoryLogicalAddressQueueEntry; //0x258
enum _HALP_DMA_ADAPTER_ALLOCATION_STATE AllocationState; //0x270
ULONG ScatterGatherBufferLength; //0x274
struct _SCATTER_GATHER_LIST ScatterGatherBuffer; //0x278
};