HW_PASSIVE_INITIALIZE_ROUTINE 콜백 함수(storport.h)
HwStorPassiveInitializeRoutine 콜백 루틴은 현재 IRQL이 PASSIVE_LEVEL 때 HwStorInitialize 루틴 이후에 호출됩니다. HwStorPassiveInitializeRoutine 콜백은 StorPortEnablePassiveInitialization 루틴을 호출하여 설정됩니다. 미니포트의 DPC(지연 프로시저 호출)의 초기화는 HwStorPassiveInitializeRoutine 콜백에서 발생합니다.
구문
HW_PASSIVE_INITIALIZE_ROUTINE HwPassiveInitializeRoutine;
BOOLEAN HwPassiveInitializeRoutine(
PVOID DeviceExtension
)
{...}
매개 변수
DeviceExtension
반환 값
미니포트가 DPC 처리를 성공적으로 초기 화하면 HwStorPassiveInitializeRoutine 루틴이 TRUE 를 반환하고 초기화 프로세스가 실패한 경우 FALSE 를 반환합니다.
설명
HwStorPassiveInitializeRoutine 루틴은 미니포트 드라이버에서 사용할 모든 DPC를 초기화해야 합니다. 포트 드라이버는 스핀 잠금을 보유하지 않고 PASSIVE_LEVEL HwStorPassiveInitializeRoutine 을 호출합니다. 이 루틴이 호출되는 동안 인터럽트는 사용하도록 설정됩니다.
HwStorPassiveInitializeRoutine 이름은 자리 표시자일 뿐입니다. 이 콜백 루틴의 실제 프로토타입은 다음과 같이 Storport.h 에 정의됩니다.
typedef
BOOLEAN
(*PHW_PASSIVE_INITIALIZE_ROUTINE) (
_In_ PVOID DeviceExtension
);
포트 드라이버는 스핀 잠금을 획득하지 않고 PASSIVE IRQL에서 HwStorPassiveInitializeRoutine 루틴을 호출합니다.
예제
HwStorPassiveInitializeRoutine 콜백 함수를 정의하려면 먼저 정의하는 콜백 함수의 형식을 식별하는 함수 선언을 제공해야 합니다. Windows는 드라이버에 대한 콜백 함수 형식 집합을 제공합니다. 콜백 함수 형식을 사용하여 함수를 선언하면 드라이버에 대한 코드 분석, SDV( 정적 드라이버 검증 도구 ) 및 기타 확인 도구에서 오류를 찾을 수 있으며 Windows 운영 체제용 드라이버를 작성하기 위한 요구 사항입니다.
예를 들어 MyHwPassiveInitialize라는 HwStorPassiveInitializeRoutine 콜백 루틴을 정의하려면 다음 코드 예제와 같이 HW_PASSIVE_INITIALIZE_ROUTINE 형식을 사용합니다.
HW_PASSIVE_INITIALIZE_ROUTINE MyHwPassiveInitialize;
그런 다음 다음과 같이 콜백 루틴을 구현합니다.
_Use_decl_annotations_
BOOLEAN
MyHwPassiveInitialize (
_In_ PVOID DeviceExtension
);
{
...
}
HW_PASSIVE_INITIALIZE_ROUTINE 함수 형식은 Storport.h 헤더 파일에 정의되어 있습니다. 코드 분석 도구를 실행할 때 오류를 보다 정확하게 식별하려면 함수 정의에 Use_decl_annotations 주석을 추가해야 합니다. Use_decl_annotations 주석은 헤더 파일의 HW_PASSIVE_INITIALIZE_ROUTINE 함수 형식에 적용되는 주석이 사용되도록 합니다. 함수 선언 요구 사항에 대한 자세한 내용은 Storport 드라이버에 함수 역할 형식을 사용하여 함수 선언을 참조하세요. Use_decl_annotations 대한 자세한 내용은 함수 동작 주석 지정을 참조하세요.
요구 사항
요구 사항 | 값 |
---|---|
대상 플랫폼 | 유니버설 |
헤더 | storport.h(Storport.h 포함) |
IRQL | PASSIVE_LEVEL(설명 섹션 참조) |