HW_ADAPTER_CONTROL 콜백 함수(storport.h)
미니포트 드라이버의 HwStorAdapterControl 루틴은 전원 관리를 위해 HBA(호스트 버스 어댑터)를 중지하거나 다시 시작하는 등 어댑터의 상태 또는 동작을 제어하는 동기 작업을 수행하기 위해 호출됩니다.
구문
HW_ADAPTER_CONTROL HwAdapterControl;
SCSI_ADAPTER_CONTROL_STATUS HwAdapterControl(
[in] PVOID DeviceExtension,
[in] SCSI_ADAPTER_CONTROL_TYPE ControlType,
[in] PVOID Parameters
)
{...}
매개 변수
[in] DeviceExtension
미니포트 드라이버의 HBA당 스토리지 영역에 대한 포인터입니다.
[in] ControlType
각 컨트롤 형식이 미니포트 드라이버에 의해 작업을 시작하는 어댑터 제어 작업을 지정하는 SCSI_ADAPTER_CONTROL_TYPE 값입니다 . 자세한 내용은 SCSI_ADAPTER_CONTROL_TYPE 참조하세요.
[in] Parameters
ControlType과 관련된 정보를 포함하는 구조체 또는 값에 대한 포인터이거나 컨트롤 형식이 구조를 사용하지 않는 경우 NULL입니다. 모든 구조체는 호출자가 할당합니다. 자세한 내용은 SCSI_ADAPTER_CONTROL_TYPE 참조하세요.
반환 값
컨트롤 형식에 따라 HwStorAdapterControl 은 다음 SCSI_ADAPTER_CONTROL_STATUS 값 중 하나를 반환합니다.
반환 코드 | 설명 |
---|---|
ScsiAdapterControlSuccess | 미니포트 드라이버가 요청된 작업을 성공적으로 완료했습니다. 현재 HwStorAdapterControl 은 모든 컨트롤 형식에 대해 이 값을 반환해야 합니다. |
ScsiAdapterControlUnsuccessful | 어댑터 컨트롤 작업이 실패했습니다. |
설명
HwStorAdapterControl 은 필수 함수입니다.
Storport는 HBA가 초기화된 후 첫 번째 I/O 이전에 ScsiQuerySupportedControlTypes 컨트롤 형식을 사용하여 미니포트의 HwStorAdapterControl을 호출합니다. 미니포트 드라이버는 매개 변수의 SCSI_SUPPORTED_CONTROL_TYPE_LIST 구조체를 지원하는 작업으로 채웁니다. HwStorAdapterControl이 이 호출에서 반환되면 Storport 드라이버는 미니포트에서 지원하는 작업에 대해서만 미니포트 드라이버의 HwStorAdapterControl 콜백을 호출합니다.
Storport 드라이버와 함께 작동하는 미니포트 드라이버는 플러그 앤 플레이(PnP)를 지원해야 하므로 미니포트는 ScsiStopAdapter 및 ScsiRestartAdapter 컨트롤 형식을 지원해야 합니다.
다음 표에는 현재 IRQL 및 컨트롤 형식이 발급될 때 획득한 스핀 잠금이 나열되어 있습니다.
컨트롤 종류 | Irql | 스핀 잠금 |
---|---|---|
ScsiQuerySupportedControlTypes | PASSIVE_LEVEL | 없음 |
ScsiStopAdapter | DIRQL | 인터럽트락 |
ScsiRestartAdapter | DIRQL | 인터럽트락 |
ScsiSetBootConfig | PASSIVE_LEVEL | 없음 |
ScsiSetRunningConfig | PASSIVE_LEVEL | 없음 |
ScsiPowerSettingNotification | PASSIVE_LEVEL | 없음 |
ScsiAdapterPower | <= DISPATCH_LEVEL | 없음 |
ScsiAdapterPoFxPowerRequired | <= DISPATCH_LEVEL | 없음 |
ScsiAdapterPoFxPowerActive | <= DISPATCH_LEVEL | 없음 |
ScsiAdapterPoFxPowerSetFState | <= DISPATCH_LEVEL | 없음 |
ScsiAdapterPoFxPowerControl | <= DISPATCH_LEVEL | 없음 |
ScsiAdapterPrepareForBusReScan | PASSIVE_LEVEL | 없음 |
ScsiAdapterSystemPowerHints | PASSIVE_LEVEL | 없음 |
ScsiAdapterFilterResourceRequirements | < DISPATCH_LEVEL | 없음 |
ScsiAdapterPoFxMaxOperationalPower | PASSIVE_LEVEL | 없음 |
ScsiAdapterPoFxSetPerfState | <= DISPATCH_LEVEL | 없음 |
ScsiAdapterSurpriseRemoval | < DISPATCH_LEVEL | 없음 |
ScsiAdapterSerialNumber | < DISPATCH_LEVEL | 없음 |
ScsiAdapterCryptoOperation | PASSIVE_LEVEL | 없음 |
ScsiAdapterQueryFruId | PASSIVE_LEVEL | 없음 |
ScsiAdapterSetEventLogging | PASSIVE_LEVEL | 없음 |
HwStorAdapterControl 이름은 자리 표시자일 뿐입니다. 이 루틴의 실제 프로토타입은 다음과 같이 storport.h 에 정의됩니다.
typedef
SCSI_ADAPTER_CONTROL_STATUS
HW_ADAPTER_CONTROL (
_In_ PVOID DeviceExtension,
_In_ SCSI_ADAPTER_CONTROL_TYPE ControlType,
_In_ PVOID Parameters
);
예제
HwStorAdapterControl 콜백 함수를 정의하려면 먼저 정의 중인 콜백 함수의 형식을 식별하는 함수 선언을 제공해야 합니다. Windows는 드라이버에 대한 콜백 함수 형식 집합을 제공합니다. 콜백 함수 형식을 사용하여 함수를 선언하면 드라이버에 대한 코드 분석, SDV( 정적 드라이버 검증 도구 ) 및 기타 확인 도구에서 오류를 찾을 수 있으며 Windows 운영 체제용 드라이버를 작성하기 위한 요구 사항입니다.
예를 들어 MyHwAdapterControl이라는 HwStorAdapterControl 콜백 루틴을 정의하려면 다음 코드 예제와 같이 HW_ADAPTER_CONTROL 형식을 사용합니다.
HW_ADAPTER_CONTROL MyHwAdapterControl;
그런 다음 다음과 같이 콜백 루틴을 구현합니다.
_Use_decl_annotations_
SCSI_ADAPTER_CONTROL_STATUS
MyHwAdapterControl (
_In_ PVOID DeviceExtension,
_In_ SCSI_ADAPTER_CONTROL_TYPE ControlType,
_In_ PVOID Parameters
);
{
...
}
HW_ADAPTER_CONTROL 함수 형식은 Storport.h 헤더 파일에 정의되어 있습니다. 코드 분석 도구를 실행할 때 오류를 보다 정확하게 식별하려면 함수 정의에 Use_decl_annotations 주석을 추가해야 합니다. Use_decl_annotations 주석은 헤더 파일의 HW_ADAPTER_CONTROL 함수 형식에 적용되는 주석이 사용되도록 합니다. 함수 선언 요구 사항에 대한 자세한 내용은 Storport 드라이버에 함수 역할 형식을 사용하여 함수 선언을 참조하세요. Use_decl_annotations 대한 자세한 내용은 함수 동작 주석 지정을 참조하세요.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 8 |
대상 플랫폼 | 유니버설 |
헤더 | storport.h(Storport.h 포함) |
IRQL | 설명 부분을 참조하세요. |