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 값 중 하나를 반환할 수 있습니다.
반환 코드 | 설명 |
---|---|
|
작업이 성공적으로 완료되었습니다. |
|
디바이스는 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 |