共用方式為


IMiniportMidi::Init 方法 (portcls.h)

方法 Init 會初始化 MIDI 迷你埠物件。

語法

NTSTATUS Init(
  [in]  PUNKNOWN      UnknownAdapter,
  [in]  PRESOURCELIST ResourceList,
  [in]  PPORTMIDI     Port,
  [out] PSERVICEGROUP *ServiceGroup
);

參數

[in] UnknownAdapter

要初始化迷你埠物件的配接器物件的 IUnknown 介面指標。 此參數是選擇性的,可以指定為 NULL。 如需詳細資訊,請參閱接下來的<備註>一節。

[in] ResourceList

在初始化期間提供給迷你埠驅動程式之資源清單物件的 IResourceList 介面指標。 將這個參考傳遞至迷你埠驅動程序之後,埠驅動程式即可自由檢查資源清單的內容,但不會修改此列表的內容。 如需詳細資訊,請參閱接下來的<備註>一節。

[in] Port

系結至這個迷你埠物件的 IPortMidi 物件的指標。 呼叫端會指定此參數的有效非 NULL 指標值。

[out] ServiceGroup

服務群組的輸出指標。 此參數指向呼叫端配置的指標變數,此方法會將指標寫入迷你埠驅動程式服務群組物件的 IServiceGroup 介面。 這是正在註冊以進行中斷通知的服務群組。 呼叫端會指定此參數的有效非 NULL 指標值。

傳回值

Init 如果呼叫成功,會傳回STATUS_SUCCESS。 否則,方法會傳回適當的錯誤碼。

備註

UnknownAdapter 參數是選擇性的:

  • 如果 UnknownAdapter 不是 NULL,此方法會 Init 查詢 UnknownAdapter 物件是否有其 IInterruptSync 介面。
  • 如果 UnknownAdapterNULL,方法會 Init 呼叫 PcNewInterruptSync 來建立新的 IInterruptSync 物件。 在此情況下, ResourceList 指向的資源清單會提供新 IInterruptSync 物件所使用的中斷資源。
不論是哪一種情況,Init方法都會在 IInterruptSync 物件上呼叫 RegisterServiceRoutine 方法,以便將迷你埠驅動程式的中斷服務例程新增至中斷同步處理例程清單 (ISR) 。 當配接器驅動程式稍後釋放埠物件時,埠驅動程序會釋放其 IInterruptSync 對象的參考。

UnknownAdapterResourceList 參數是適配卡驅動程式先前傳遞為參數給 IPortMidi 物件的 Init 方法的相同指標值, (請參閱 IPort::Init) 。

UnknownAdapterResourceListPortServiceGroup 參數會遵循 COM 對象的參考計數慣例

規格需求

需求
目標平台 Universal
標頭 portcls.h (包含 Portcls.h)
IRQL PASSIVE_LEVEL

另請參閱

IInterruptSync

IMiniportMidi

IPort::Init

IPortMidi

IResourceList

IServiceGroup

PcNewInterruptSync