NDIS_MINIPORT_OFFLOAD_BLOCK_LIST 結構 (ndischimney.h)

[TCP chimney 卸除功能已被取代,不應使用。

NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構是 TCP chimney 卸除狀態樹狀結構的基本建置組塊。 卸除狀態樹狀結構可以包含一或多個NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構。

語法

typedef struct _NDIS_MINIPORT_OFFLOAD_BLOCK_LIST {
  IN NDIS_OBJECT_HEADER                Header;
  IN _NDIS_MINIPORT_OFFLOAD_BLOCK_LIST *NextBlock;
#if ...
  struct                               _NDIS_MINIPORT_OFFLOAD_BLOCK_LIST;
  IN _NDIS_MINIPORT_OFFLOAD_BLOCK_LIST *DependentBlockList;
#else
  struct                               _NDIS_MINIPORT_OFFLOAD_BLOCK_LIST;
#endif
  OUT NDIS_STATUS                      Status;
  IN PVOID                             NdisReserved[2];
  IN OUT PVOID                         *MiniportOffloadContext;
  IN NDIS_HANDLE                       NdisOffloadHandle;
  IN PVOID                             ProtocolReserved[2];
  IN PVOID                             MiniportReserved[2];
  IN PVOID                             ImReserved[2];
  IN PVOID                             Scratch[2];
  IN PVOID                             SourceHandle;
  IN NDIS_PORT_NUMBER                  PortNumber;
  IN OUT PNET_BUFFER_LIST              NetBufferListChain;
} NDIS_MINIPORT_OFFLOAD_BLOCK_LIST, *PNDIS_MINIPORT_OFFLOAD_BLOCK_LIST;

成員

Header

NDIS_MINIPORT_OFFLOAD_BLOCK_LIST 結構的標頭。 標頭的格式為 NDIS_OBJECT_HEADER 結構。 NDIS_OBJECT_HEADER 結構包含NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的修訂編號、緊接在記憶體中NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的卸除狀態類型,以及NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的大小,包括標頭,以位元組為單位。

NDIS_OBJECT_HEADER 結構的 Type 成員表示卸除狀態的類型,並隱含地指出緊接在記憶體中NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的特定卸除狀態結構 (或結構) 。

支援下列OFFLOAD_STATE_TYPE值:

NeighborOffloadConstState

指定常數芳鄰狀態。 此狀態的格式為 NEIGHBOR_OFFLOAD_STATE_CONST 結構。

NeighborOffloadCachedState

指定快取的芳鄰狀態。 此狀態的格式為 NEIGHBOR_OFFLOAD_STATE_CACHED 結構。

NeighborOffloadDelegatedState

指定委派的芳鄰狀態。 此狀態的格式為 NEIGHBOR_OFFLOAD_STATE_DELEGATED 結構。

NeighborOffloadState

指定所有鄰近狀態資訊,包括常數、快取和委派的芳鄰狀態。 此狀態的格式為NEIGHBOR_OFFLOAD_STATE_CONST結構,後面接著NEIGHBOR_OFFLOAD_STATE_CACHED結構,後面接著NEIGHBOR_OFFLOAD_STATE_DELEGATED結構。

Ip4OffloadConstState

指定IPv4) (常數路徑狀態。 此狀態的格式為 PATH_OFFLOAD_STATE_CONST 結構。

Ip4OffloadCachedState

指定IPv4 () 的快取路徑狀態。 此狀態的格式為 PATH_OFFLOAD_STATE_CACHED 結構。

Ip4OffloadDelegatedState

指定IPv4) (委派的路徑狀態。 此狀態的格式為 PATH_OFFLOAD_STATE_DELEGATED 結構。 目前沒有委派的路徑狀態。 PATH_OFFLOAD_STATE_DELEGATED 結構不包含任何變數。

Ip4OffloadState

指定IPv4) (的所有路徑狀態,包括常數、快取和委派的路徑狀態。 此狀態的格式為PATH_OFFLOAD_STATE_CONST結構,後面接著PATH_OFFLOAD_STATE_CACHED結構,後面接著PATH_OFFLOAD_STATE_DELEGATED結構。

Ip6OffloadConstState

指定IPv6) (常數路徑狀態。 此狀態的格式為PATH_OFFLOAD_STATE_CONST結構。

Ip6OffloadCachedState

指定IPv6) (快取的路徑狀態。 此狀態的格式為PATH_OFFLOAD_STATE_CACHED結構。

Ip6OffloadDelegatedState

指定 IPv6) (委派的路徑狀態。 此狀態的格式為 PATH_OFFLOAD_STATE_DELEGATED 結構。 目前沒有委派的路徑狀態。 PATH_OFFLOAD_STATE_DELEGATED 結構不包含任何變數。

Ip6OffloadState

指定IPv6) (的所有路徑狀態資訊,包括常數、快取和委派的路徑狀態。 此狀態的格式為PATH_OFFLOAD_STATE_CONST結構,後面接著PATH_OFFLOAD_STATE_CACHED結構,後面接著PATH_OFFLOAD_STATE_DELEGATED結構。

TcpOffloadConstState

指定常數 TCP 狀態。 此狀態的格式為 TCP_OFFLOAD_STATE_CONST 結構。

TcpOffloadCachedState

指定快取的 TCP 狀態。 此狀態的格式為 TCP_OFFLOAD_STATE_CACHED 結構。

TcpOffloadDelegatedState

指定委派的 TCP 狀態。 此狀態的格式為 TCP_OFFLOAD_STATE_DELEGATED 結構。

TcpOffloadResourceState

保留的。 目前不會使用這個OFFLOAD_STATE_TYPE值以及TCP_OFFLOAD_RESOURCE_STATE結構。

TcpOffloadState

指定所有 TCP 狀態資訊,包括常數、快取和委派的 TCP 狀態。 此狀態的格式為TCP_OFFLOAD_STATE_CONST結構,後面接著TCP_OFFLOAD_STATE_CACHED結構,後面接著TCP_OFFLOAD_STATE_DELEGATED結構。

FilterReservedOffloadState

保留給篩選驅動程式。

NextBlock

卸除狀態層上下一個NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的指標, (芳鄰、路徑或 TCP) 由標頭成員的 Type 成員表示。 NDIS_MINIPORT_OFFLOAD_BLOCK_LIST透過 NextBlock 指標鏈接的結構一律位於卸除狀態的相同層。 NULLNextBlock 值表示這個層級沒有額外的下一個NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構。

_NDIS_MINIPORT_OFFLOAD_BLOCK_LIST

DependentBlockList

位於卸除狀態相依層之NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的指標, (卸除狀態樹狀結構中較高層) 。 針對 TCP chimney 卸除:

  • 鄰近層NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的 DependentBlockList 成員只能指向路徑層的NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構。
  • 路徑層上NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的 DependentBlockList 成員只能指向 TCP 層的NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構。
  • TCP 層NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的 DependentBlockList 成員一律為 NULL
NULLDependentBlockList 值表示沒有相依NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構。

Status

起始卸除、查詢卸除、更新卸除、失效卸載或終止卸除作業的完成狀態,卸除目標在與 NDIS_MINIPORT_OFFLOAD_BLOCK_LIST 結構相關聯或參考的狀態上執行的卸除作業。 視作業而定,卸除目標會將下列其中一個NDIS_STATUS值寫入 Status 成員:

NDIS_STATUS_SUCCESS

起始卸除:卸除目標已成功卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,以及與所有立即相依NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態。

查詢、更新、失效或終止卸除:卸除目標已成功對與 NDIS_MINIPORT_OFFLOAD_BLOCK_LIST 結構相關聯或參考的狀態執行作業。

NDIS_STATUS_OFFLOAD_PARTIAL_SUCCESS

起始卸除:卸除目標已成功卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,但無法卸除與一或多個立即相依NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_FAILURE

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態。 無法分類失敗的原因。

查詢、更新、失效或終止卸除:卸除目標無法在與 NDIS_MINIPORT_OFFLOAD_BLOCK_LIST 結構相關聯的或參考狀態上執行作業。

NDIS_STATUS_RESOURCES

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,因為卸除目標無法配置足夠的主機記憶體。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_TCP_ENTRIES

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,因為卸除目標無法配置 TCP 連線狀態物件。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_PATH_ENTRIES

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,因為卸除目標無法配置路徑狀態物件。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_NEIGHBOR_ENTRIES

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,因為卸除目標無法配置鄰近狀態物件。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_HW_ADDRESS_ENTRIES

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,因為主機堆棧在 中指定了非 NULLDlSourceAddress 成員 NEIGHBOR_OFFLOAD_STATE_CONST 結構,卸除目標不支援可設定的來源 MAC 位址,或無法接受其他來源 MAC 位址。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_IP_ADDRESS_ENTRIES

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,因為卸除目標無法為 SourceAddress 指標所參考的來源IP位址配置數據結構 PATH_OFFLOAD_STATE_CONST 結構。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_TCP_XMIT_BUFFER

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,因為卸除目標無法配置足夠的 TCP 傳輸緩衝區。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_TCP_RCV_BUFFER

起始卸除:卸除目標無法卸除與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態,因為卸除目標無法配置足夠的 TCP 接收緩衝區。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_TCP_RCV_WINDOW

起始卸除:卸除目標無法卸除與 NDIS_MINIPORT_OFFLOAD_BLOCK_LIST 結構相關聯的狀態,因為 中指定的 InitialRcvWnd 成員 TCP_OFFLOAD_STATE_CACHED 結構大於卸除目標可以支援。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_VLAN_ENTRIES

起始卸除:卸除目標已用盡資源來追蹤其他 VLAN 標識碼。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_VLAN_MISMATCH

起始卸除:鄰近 VlanId 不是零,且不符合其中一個介面 VLAN 標識符。

查詢、更新、失效或終止卸除:不允許的狀態值。

NDIS_STATUS_OFFLOAD_PATH_MTU

TCP 連線的路徑 MTU 大於卸除目標支援的路徑。

查詢、更新、失效或終止卸除:不允許的狀態值。

NdisReserved[2]

保留供 NDIS 使用。

MiniportOffloadContext

卸除目標寫入 PVOID 值的記憶體位置指標。 PVOID 值會參考卸除內容區域,其中卸除目標會儲存與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的狀態。 如果狀態是卸除目標要卸除的新狀態, MiniportOffloadContext 所指向的記憶體位置會包含 NULL 值。 卸除狀態之後,卸除目標會將 PVOID 值寫入此記憶體位置。 卸除目標所提供的 PVOID 值會參考卸除狀態卸除所在的卸除內容區域。 如果 MiniportOffloadContext 成員本身為 NULL,則NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構是卸除狀態樹狀結構中的佔位符。

NdisOffloadHandle

卸除目標在後續呼叫中提供的句柄 NdisTcpOffloadEventHandler 函式或當發出與此NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯卸除狀態的指示時,NdisTcpOffloadReceiveHandler 函式。

ProtocolReserved[2]

保留供通訊協定驅動程式使用,此區域可用於自己的用途。 卸除目標不得修改此值。

MiniportReserved[2]

保留供卸除目標使用,此區域可用於自己的用途,例如將與NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構相關聯的卸除狀態排入佇列。

ImReserved[2]

保留供中繼驅動程式使用,此區域可用於自己的用途。 卸除目標不得修改此值。

Scratch[2]

卸除目標可以使用此區域進行內部追蹤。 只有在卸除目標擁有NDIS_MINIPORT_OFFLOAD_BLOCK_LIST擁有權時,此區域中的資訊才有效。

SourceHandle

此成員對卸除目標而言並不重要。 卸除目標不得修改此成員。

PortNumber

識別迷你埠配接器埠的埠號碼。 若要指派迷你埠適配卡埠號碼,請呼叫 NdisMAllocatePort 函式。 零值會識別迷你埠配接器的預設埠。 如果迷你埠驅動程式尚未為指定的適配卡配置埠,請使用預設埠。

NetBufferListChain

當主機堆疊指定 NULL 值時, NetBufferListChain 並不重要,而且卸除目標可以忽略。

當主機堆疊指定非 NULL 值時, NetBufferListChain 會指向可以是獨立結構或這類結構連結清單中的第一個結構 NET_BUFFER_LIST 結構。 鏈接清單中的每個NET_BUFFER_LIST結構都會描述一個 NET_BUFFER 結構。 NET_BUFFER結構會對應至記憶體描述項鍊結, (MDL) 。 NET_BUFFER_LIST和相關聯的結構會鎖定,使其保留在物理記憶體中。 不過,它們不會對應至系統記憶體。

與NET_BUFFER結構相關聯的 MDL 包含主機堆疊在卸除作業過程中傳遞至卸除目標的數據。 卸除目標會呼叫適當的 NdisTcpOffloadXxxComplete 函式,以異步方式完成這類數據回到主機堆棧。 目前,連結清單只能包含一種類型的數據:未處理的傳送數據。 如需詳細資訊,請參閱 在卸除作業期間和之後處理未處理傳送的數據

卸除目標可以在終止 TCP 連線的卸除時,將未處理傳送的數據傳遞至主機堆疊。 在此情況下,卸除目標會在呼叫 時指定 NetBufferListChain 成員的非 NULL NdisMTerminateOffloadComplete 函 式。 如果卸除目標未針對即將終止的 TCP 連線傳遞傳送數據,則必須為 NetBufferListChain 成員指定 NULL 值。

備註

NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構可以連結在一起,以建置 TCP chimney 卸除狀態樹狀結構的架構。

透過 NDIS,主機堆疊會傳遞 OffloadBlockList 指標,此指標會將卸除狀態樹狀結構參考到卸除目標的下列其中一個函式:

卸除目標會將相同的指標傳遞至對應的完成函式,以將樹狀結構傳回主機堆棧: NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構可以緊接著記憶體中的 卸除狀態結構 ,其中包含要卸除、查詢、更新、失效或終止的狀態。 NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的 Type 成員 的 Header 會指定卸除狀態的類型,並藉由隱含地指定在記憶體中NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構之後的特定卸除狀態結構 (或結構) 。

主機堆疊和卸除目標會使用 NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的 *MiniportOffloadContextNdisOffloadHandle 成員來參考卸除狀態。 如需詳細資訊,請參閱 儲存和參考卸除狀態

NDIS_MINIPORT_OFFLOAD_BLOCK_LIST 結構可以在卸除狀態樹狀結構中執行數個函式的其中一個。 它可以做為佔位元、連結器,也可以傳達要由卸除目標卸除的新狀態。 如需詳細資訊,請參閱 佔位元、連結器和新增卸除

完成起始卸除、查詢卸除、更新卸除、失效卸除或終止卸載作業之前,卸除目標必須將完成狀態寫入狀態樹狀結構中每個NDIS_MINIPORT_OFFLOAD_BLOCK_LIST結構的 Status 成員。

規格需求

需求
標頭 ndischimney.h (包括 Ndischimney.h)

另請參閱

MiniportInitiateOffload

MiniportInvalidateOffload

MiniportQueryOffload

MiniportTerminateOffload

MiniportUpdateOffload

NDIS_OBJECT_HEADER

NEIGHBOR_OFFLOAD_STATE_CACHED

NEIGHBOR_OFFLOAD_STATE_DELEGATED

NdisMAllocatePort

NdisMInitiateOffloadComplete

NdisMInvalidateOffloadComplete NdisMQueryOffloadStateComplete NdisMTerminateOffloadComplete

NdisMUpdateOffloadComplete

NdisTcpOffloadEventHandler

NdisTcpOffloadReceiveHandler

PATH_OFFLOAD_STATE_CACHED

PATH_OFFLOAD_STATE_CONST

PATH_OFFLOAD_STATE_DELEGATED

TCP_OFFLOAD_STATE_CACHED

TCP_OFFLOAD_STATE_CONST

TCP_OFFLOAD_STATE_DELEGATED