다음을 통해 공유


StorPortGetBusData 함수(storport.h)

StorPortGetBusData 루틴은 HBA를 초기화하는 데 필요한 버스 관련 구성 정보를 검색합니다.

구문

STORPORT_API ULONG StorPortGetBusData(
  [in]      PVOID DeviceExtension,
  [in]      ULONG BusDataType,
  [in]      ULONG SystemIoBusNumber,
  [in]      ULONG SlotNumber,
  [in, out] PVOID Buffer,
  [in]      ULONG Length
);

매개 변수

[in] DeviceExtension

미니포트 드라이버의 HBA당 스토리지 영역에 대한 포인터입니다.

[in] BusDataType

반환할 버스별 구성 데이터의 형식을 지정하는 BUS_DATA_TYPE 형식의 값을 포함합니다. 현재 이 값은 Cmos, EisaConfiguration, Pos 또는 PCIConfiguration 중 하나일 수 있습니다. 그러나 향후 추가 유형의 버스 구성이 지원될 예정입니다. 지원되는 형식의 상한은 항상 MaximumBusDataType입니다.

[in] SystemIoBusNumber

시스템이 할당한 I/O 버스 수를 지정합니다. 미니포트 드라이버의 HwStorFindAdapter 루틴은 처음에 PORT_CONFIGURATION_INFORMATION 설정된 SystemIoBusNumber 멤버에서 이 값을 가져옵니다.

[in] SlotNumber

디바이스의 논리적 슬롯 번호 또는 위치를 지정합니다.

PCIConfigurationBusDataType으로 지정된 경우 이 매개 변수를 PCI_SLOT_NUMBER 형식 값으로 지정해야 합니다.

[in, out] Buffer

구성 데이터가 반환되는 버퍼 또는 영역에 대한 포인터이거나 지정된 Length 가 0이면 OS 관련 포트 드라이버가 할당하는 버퍼에 대한 포인터를 반환하는 위치를 가리킵니다.

[in] Length

버퍼에서 반환할 최대 바이트 수를 지정하거나, 호출자가 데이터를 포함하도록 버퍼를 할당하기 위해 OS 관련 포트 드라이버가 필요한 경우 0을 지정합니다.

반환 값

StorPortGetBusData 는 버퍼에 저장된 구성 정보의 바이트 수를 반환합니다. 입력 BusDataTypePCIConfiguration이면 StorPortGetBusData 는 다음 값 중 하나를 반환하여 오류를 나타낼 수 있습니다.

반환 코드 설명
0(영) PCI 버스가 없습니다.
2 PCI 버스가 있지만 지정된 PCI SlotNumber에는 디바이스가 없습니다. 버퍼에는 PCI_COMMON_CONFIG VendorId 멤버의 PCI_INVALID_VENDOR_ID 값이 포함됩니다.

설명

미니포트 드라이버는 다음 루틴에서 StorPortGetBusData 를 호출할 수 있습니다.

다른 미니포트 드라이버 루틴에서 호출하면 호출자에 대한 시스템 오류 또는 잘못된 작업이 발생합니다.

StorPortGetBusData에서 반환된 구성 데이터는 미니포트 드라이버가 StorPortGetBusData를 다시 호출할 때까지만 유효합니다. 호출자의 HwStorFindAdapter 루틴이 컨트롤을 반환하는 즉시 반환된 구성 데이터가 유효하지 않습니다.

요구 사항

요구 사항
대상 플랫폼 유니버설
헤더 storport.h(Storport.h 포함)
라이브러리 Storport.lib

추가 정보

HwStorAdapterControl

HwStorFindAdapter

PORT_CONFIGURATION_INFORMATION

SCSI_ADAPTER_CONTROL_TYPE