다음을 통해 공유


MINIPORT_RESTART 콜백 함수(ndis.h)

MiniportRestart 함수는 일시 중지된 미니포트 어댑터에 대한 다시 시작 요청을 시작합니다.

참고MINIPORT_RESTART 형식을 사용하여 함수를 선언해야 합니다. 자세한 내용은 다음 예제 섹션을 참조하세요.
 

통사론

MINIPORT_RESTART MiniportRestart;

NDIS_STATUS MiniportRestart(
  [in] NDIS_HANDLE MiniportAdapterContext,
       PNDIS_MINIPORT_RESTART_PARAMETERS RestartParameters
)
{...}

매개 변수

[in] MiniportAdapterContext

미니포트 드라이버가 MiniportInitializeEx에 할당한 컨텍스트 영역에 대한 핸들이. 미니포트 드라이버는 이 컨텍스트 영역을 사용하여 미니포트 어댑터의 상태 정보를 유지 관리합니다.

RestartParameters

에 대한 포인터 미니포트 어댑터의 다시 시작 매개 변수를 정의하는 NDIS_MINIPORT_RESTART_PARAMETERS 구조체입니다.

반환 값

MiniportRestart 다음 상태 값 중 하나를 반환합니다.

반환 코드 묘사
NDIS_STATUS_SUCCESS

MiniportRestart 미니포트 어댑터를 통해 네트워크 데이터 흐름을 성공적으로 다시 시작했습니다.

NDIS_STATUS_PENDING
MiniportRestart 다시 시작 작업을 완료하지 않았으며 작업이 비동기적으로 완료됩니다. 미니포트 드라이버는 작업이 완료되면 NdisMRestartComplete 함수를 호출해야 합니다.
NDIS_STATUS_RESOURCES

리소스가 부족하여 MiniportRestart 실패했습니다.

NDIS_STATUS_FAILURE
이전 상태 값은 적용되지 않습니다. 이 경우 드라이버는 실패 이유를 지정하는 매개 변수를 사용하여 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_ATTRIBUTESData 멤버에는 NDIS_RESTART_GENERAL_ATTRIBUTES 구조가 포함되어 있습니다.
  • 다음을 확인해야 합니다. NDIS_RESTART_GENERAL_ATTRIBUTES 구조체에는 올바른 정보가 포함됩니다. NDIS_RESTART_GENERAL_ATTRIBUTES 구조체에 필요한 정보가 포함되어 있는지 확인하려면 먼저 NDIS_RESTART_GENERAL_ATTRIBUTES 구조체의 Header 멤버에 지정된 NDIS_OBJECT_HEADER 구조체에서 Revision 멤버를 확인하여 구조체의 버전을 결정해야 합니다.
NDIS는 다시 시작 작업이 완료될 때까지 미니포트 어댑터(예: 중지, 초기화, 전원 변경 또는 일시 중지 요청)에 대한 다른 PnP(플러그 앤 플레이) 작업을 시작하지 않습니다.

미니포트 드라이버가 송신 및 수신 작업을 성공적으로 다시 시작한 후에는 다시 시작 작업을 완료해야 합니다. 드라이버가 MiniportRestartNDIS_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

참고 항목

MiniportInitializeEx

MiniportOidRequest

MiniportPause

NDIS_MINIPORT_RESTART_PARAMETERS

NDIS_OBJECT_HEADER

NDIS_RESTART_ATTRIBUTES

NDIS_RESTART_GENERAL_ATTRIBUTES NdisAllocateMemoryWithTagPriority

NdisFreeMemory

NdisMIndicateStatusEx

NdisMRegisterMiniportDriver

NdisMRestartComplete

NdisWriteErrorLogEntry

OID_GEN_MINIPORT_RESTART_ATTRIBUTES