MINIPORT_RESTART 콜백 함수(ndis.h)
MiniportRestart 함수는 일시 중지된 미니포트 어댑터에 대한 다시 시작 요청을 시작합니다.
구문
MINIPORT_RESTART MiniportRestart;
NDIS_STATUS MiniportRestart(
[in] NDIS_HANDLE MiniportAdapterContext,
PNDIS_MINIPORT_RESTART_PARAMETERS RestartParameters
)
{...}
매개 변수
[in] MiniportAdapterContext
MiniportInitializeEx 함수에 미니포트 드라이버가 할당한 컨텍스트 영역에 대한 핸들입니다. 미니포트 드라이버는 이 컨텍스트 영역을 사용하여 미니포트 어댑터에 대한 상태 정보를 유지 관리합니다.
RestartParameters
에 대한 포인터 미니 포트 어댑터의 다시 시작 매개 변수를 정의하는 NDIS_MINIPORT_RESTART_PARAMETERS 구조체입니다.
반환 값
MiniportRestart는 다음 상태 값 중 하나를 반환합니다.
반환 코드 | 설명 |
---|---|
|
MiniportRestart 가 미니포트 어댑터를 통해 네트워크 데이터 흐름을 성공적으로 다시 시작했습니다. |
|
MiniportRestart 가 다시 시작 작업을 완료하지 않았으며 작업이 비동기적으로 완료됩니다. 미니포트 드라이버는 작업이 완료되면 NdisMRestartComplete 함수를 호출해야 합니다. |
|
리소스가 부족하여 MiniportRestart가 실패했습니다. |
|
위의 상태 값은 적용되지 않습니다. 이 경우 드라이버는 실패 이유를 지정하는 매개 변수를 사용하여 NdisWriteErrorLogEntry 함수를 호출해야 합니다. |
설명
드라이버는 를 호출할 때 MiniportRestart 진입점을 지정합니다. NdisMRegisterMiniportDriver 함수.
MiniportAdapterContext 매개 변수로 지정된 미니포트 어댑터는 NDIS가 MiniportRestart를 호출할 때 다시 시작 상태로 들어갑니다.
NDIS가 미니포트 드라이버인 MiniportRestart를 호출하는 경우:
- 보내기 및 수신 작업을 다시 시작하는 데 필요한 작업을 완료해야 합니다.
- 필요에 따라 의 RestartAttributes 멤버에 지정된 다시 시작 특성을 수정합니다. NDIS_MINIPORT_RESTART_PARAMETERS 구조체입니다. RestartAttributes의 포인터가 NULL인 경우 미니포트 드라이버는 다시 시작 특성 목록을 수정하거나 추가하면 안 됩니다. RestartAttributes의 포인터가 NULL이 아닌 경우 NDIS_RESTART_ATTRIBUTES 구조를 가리킵니다. 미니포트 드라이버가 다시 시작되지 않으면 특성을 수정하면 안 됩니다.
- 에 상태 표시를 제공할 수 있습니다. NdisMIndicateStatusEx 함수입니다.
- MiniportOidRequest 함수에서 상태 요청을 처리해야 합니다.
- 다시 시작 특성 목록에 새 미디어별 특성을 추가할 수 있습니다. 이 경우 미니포트 드라이버는 새 를 할당해야 합니다. NDIS_RESTART_ATTRIBUTES 구조(예: NdisAllocateMemoryWithTagPriority 함수 - 새 특성에 대한 메모리 공간을 제공합니다. 다시 시작 특성을 오버리싱 드라이버에 전파한 후 NDIS는 미니포트 드라이버의 특성 메모리를 해제합니다.
- 다시 시작 특성 목록에서 미디어별 특성을 수정할 수 있습니다. 미니포트 드라이버에 더 많은 메모리 공간이 필요한 경우 NdisFreeMemory 함수를 사용하여 NDIS_RESTART_ATTRIBUTES 구조를 해제하고 수정된 정보를 포함하도록 새 구조를 할당할 수 있습니다. 다시 시작 특성을 오버리싱 드라이버에 전파한 후 NDIS는 미니포트 드라이버의 특성 메모리를 해제합니다.
- 에서 모든 필드를 수정할 수 있습니다. NDIS_RESTART_GENERAL_ATTRIBUTES 구조체입니다. NDIS가 의 RestartAttributes 멤버에 NULL이 아닌 포인터를 제공하는 경우 NDIS_MINIPORT_RESTART_PARAMETERS 구조체의 특성 목록에는 NDIS_RESTART_ATTRIBUTES 구조체의 Oid 멤버가 있는 하나의 항목이 포함됩니다. OID_GEN_MINIPORT_RESTART_ATTRIBUTES 및 데이터 멤버에는 NDIS_RESTART_GENERAL_ATTRIBUTES 구조가 포함됩니다.
- 다음을 확인해야 합니다. NDIS_RESTART_GENERAL_ATTRIBUTES 구조체에는 올바른 정보가 포함됩니다. NDIS_RESTART_GENERAL_ATTRIBUTES 구조체에 필요한 정보가 포함되어 있는지 확인하려면 먼저 NDIS_RESTART_GENERAL_ATTRIBUTES 구조체의 Header 멤버에 지정된 NDIS_OBJECT_HEADER 구조체의 Revision 멤버를 확인하여 구조체의 버전을 확인해야 합니다.
미니포트 드라이버가 송신 및 수신 작업을 성공적으로 다시 시작한 후 다시 시작 작업을 완료해야 합니다. 드라이버가 MiniportRestart에서 NDIS_STATUS_SUCCESS 반환하면 다시 시작 작업이 완료됩니다. 드라이버가 NDIS_STATUS_PENDING 반환하는 경우 다시 시작 작업을 계속할 수 있습니다. 드라이버가 NdisMRestartComplete 함수를 호출한 후 다시 시작 작업이 완료됩니다. 다시 시작 작업이 완료되면 미니포트 어댑터가 실행 중 상태가 됩니다.
미니포트 드라이버는 NDIS가 MiniportRestart 를 호출하고 드라이버가 NdisMRestartComplete를 호출하기 직전에 미니포트 어댑터에 대해 수신된 패킷을 나타내는 것을 다시 시작할 수 있습니다. 미니포트 드라이버는 드라이버가 다시 시작 요청을 완료한 후 보내기 요청을 수락할 준비가 되어 있어야 합니다.
미니포트 드라이버가 송신 및 수신 작업을 다시 시작하지 않는 경우 드라이버는 MiniportRestart에서 적절한 오류 상태 반환해야 합니다. 이 경우 드라이버는 시작된 모든 송신 또는 수신 작업을 중지한 다음 일시 중지됨 상태로 돌아가야 합니다.
NDIS는 IRQL = PASSIVE_LEVEL MiniportRestart 를 호출합니다.
예
MiniportRestart 함수를 정의하려면 먼저 정의 중인 함수의 형식을 식별하는 함수 선언을 제공해야 합니다. Windows는 드라이버에 대한 함수 형식 집합을 제공합니다. 함수 형식을 사용하여 함수를 선언하면 드라이버에 대한 코드 분석, SDV( 정적 드라이버 검증 도구 ) 및 기타 확인 도구에서 오류를 찾을 수 있으며 Windows 운영 체제용 드라이버를 작성하기 위한 요구 사항입니다.예를 들어 " MyRestart"라는 MiniportRestart 함수를 정의하려면 다음 코드 예제와 같이 MINIPORT_RESTART 형식을 사용합니다.
MINIPORT_RESTART MyRestart;
그런 다음 다음과 같이 함수를 구현합니다.
_Use_decl_annotations_
NDIS_STATUS
MyRestart(
NDIS_HANDLE MiniportAdapterContext,
PNDIS_MINIPORT_RESTART_PARAMETERS RestartParameters
)
{...}
MINIPORT_RESTART 함수 형식은 Ndis.h 헤더 파일에 정의되어 있습니다. 코드 분석 도구를 실행할 때 오류를 보다 정확하게 식별하려면 함수 정의에 Use_decl_annotations 주석을 추가해야 합니다. Use_decl_annotations 주석은 헤더 파일의 MINIPORT_RESTART 함수 형식에 적용되는 주석이 사용되도록 합니다. 함수 선언 요구 사항에 대한 자세한 내용은 NDIS 드라이버에 함수 역할 형식을 사용하여 함수 선언을 참조하세요.
Use_decl_annotations 대한 자세한 내용은 함수 동작 주석 지정을 참조하세요.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | NDIS 6.0 이상에서 지원됩니다. |
대상 플랫폼 | Windows |
헤더 | ndis.h(Ndis.h 포함) |
IRQL | PASSIVE_LEVEL |