다음을 통해 공유


IoStartNextPacket 함수(ntifs.h)

IoStartNextPacket 루틴은 지정된 디바이스 개체의 연결된 디바이스 큐에서 다음 IRP(있는 경우)를 큐에서 제거하고 드라이버의 StartIo 루틴을 호출합니다.

구문

void IoStartNextPacket(
  [in] PDEVICE_OBJECT DeviceObject,
  [in] BOOLEAN        Cancelable
);

매개 변수

[in] DeviceObject

IRP를 큐에서 해제할 디바이스 개체에 대한 포인터입니다.

[in] Cancelable

디바이스 큐의 IRP를 취소할 수 있는지 여부를 지정합니다.

반환 값

없음

설명

대상 DeviceObject에 대한 디바이스 큐에 현재 IRP가 없는 경우 이 루틴은 단순히 호출자에게 컨트롤을 반환합니다.

드라이버가 IoStartPacket을 호출할 때 취소 루틴에 대한 포인터를 전달한 경우 이 루틴의 Cancelable 매개 변수에 TRUE를 전달해야 합니다. Cancelable이 TRUE이면 I/O 관리자는 취소 스핀 잠금을 사용하여 디바이스 큐와 현재 IRP를 보호합니다.

StartIo 루틴이 없는 드라이버는 IoStartNextPacket을 호출할 수 없습니다.

StartIo 루틴에서 IoStartNextPacket을 호출하는 드라이버는 재귀 문제를 알고 있어야 합니다. 드라이버가 StartIo 루틴에서 연속적으로 많은 수의 요청에서 IoStartNextPacket을 호출할 수 있는 경우(예: 디바이스 오류가 발생하고 드라이버가 디바이스 큐를 지우는 경우) IoSetStartIoAttributes 루틴을 사용하여 디바이스에 대한 DeferredStartIo 특성을 설정해야 합니다. 이 특성은 이전 StartIo 호출이 반환될 때까지 다음 패킷이 발급되지 않도록 합니다.

IoStartNextPacket의 호출자는 IRQL = DISPATCH_LEVEL 실행 중이어야 합니다. 일반적으로 이 루틴은 디바이스 드라이버의 DpcForIsr 또는 CustomDpc 루틴에서 호출되며 둘 다 IRQL = DISPATCH_LEVEL 실행됩니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 2000
대상 플랫폼 유니버설
헤더 ntifs.h(Wdm.h, Ntddk.h, Ntifs.h 포함)
라이브러리 NtosKrnl.lib
DLL NtosKrnl.exe
IRQL DISPATCH_LEVEL(설명 섹션 참조)
DDI 규정 준수 규칙 HwStorPortProhibitedDDIs(storport), IrqlDispatch(storport), IrqlDispatch(storport), IrqlDispatch(wdm), SpinLockSafe(storport), SpinLockSafe(storport), SpinLockSafe(wdm), StartIoRecursion(wdm)

추가 정보

DEVICE_OBJECT

IoSetStartIoAttributes

IoStartNextPacketByKey

IoStartPacket