다음을 통해 공유


PCI_MSIX_SET_ENTRY 콜백 함수(wdm.h)

SetTableEntry 루틴은 MSI-X 하드웨어 인터럽트 테이블의 테이블 항목에 대한 메시지 ID를 설정합니다.

구문

PCI_MSIX_SET_ENTRY PciMsixSetEntry;

NTSTATUS PciMsixSetEntry(
  [in] PVOID Context,
  [in] ULONG TableEntry,
  [in] ULONG MessageNumber
)
{...}

매개 변수

[in] Context

인터페이스별 컨텍스트 정보에 대한 포인터입니다. 호출자는 인터페이스에 대한 PCI_MSIX_TABLE_CONFIG_INTERFACE 구조체의 Context 멤버로 전달되는 값을 전달합니다.

[in] TableEntry

MSI-X 하드웨어 인터럽트 테이블의 테이블 항목 인덱스입니다.

[in] MessageNumber

인터럽트 메시지 ID입니다. 이 값은 드라이버의 메시지 신호 인터럽트도 설명하는 IO_INTERRUPT_MESSAGE_INFO 구조체의 MessageInfo 멤버에 있는 인터럽트 항목의 인덱스이기도 합니다. IoConnectInterruptEx 함수는 이 구조체에 대한 포인터를 제공합니다.

반환 값

SetTableEntry 루틴은 다음 NTSTATUS 값 중 하나를 반환할 수 있습니다.

반환 코드 설명
STATUS_SUCCESS
작업이 성공적으로 완료되었습니다.
STATUS_INVALID_PARAMETER
디바이스는 MSI-X를 사용하지 않거나 TableEntry 또는 MessageNumber 매개 변수가 디바이스에 할당된 인터럽트 리소스에 해당하지 않습니다.

설명

기본적으로 운영 체제는 테이블 항목의 인덱스를 인터럽트 메시지 ID로 할당합니다. 메시지보다 더 많은 테이블 항목이 있는 경우 시스템은 나머지 테이블 항목을 메시지 0에 해당하도록 설정합니다. 드라이버는 SetTableEntry 루틴을 사용하여 다른 메시지 ID를 할당할 수 있습니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows Vista에서 SP1(서비스 팩 1), Windows Server 2008 이상 버전의 Windows 운영 체제에서 사용할 수 있습니다.
대상 플랫폼 데스크톱
헤더 wdm.h(Wdm.h, Ntddk.h, Ntifs.h 포함)
IRQL <= DIRQL

추가 정보

IO_INTERRUPT_MESSAGE_INFO

IoConnectInterruptEx

PCI_MSIX_TABLE_CONFIG_INTERFACE