MINIPORT_RESTART 콜백 함수(ndis.h)

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

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

구문

MINIPORT_RESTART MiniportRestart;

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

매개 변수

[in] MiniportAdapterContext

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

RestartParameters

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

반환 값

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

반환 코드 설명
NDIS_STATUS_SUCCESS

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

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

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

NDIS_STATUS_FAILURE
위의 상태 값은 적용되지 않습니다. 이 경우 드라이버는 실패 이유를 지정하는 매개 변수를 사용하여 NdisWriteErrorLogEntry 함수를 호출해야 합니다.

설명

드라이버는 NdisMRegisterMiniportDriver 함수를 호출할 때 MiniportRestart 진입점을 지정합니다.

MiniportAdapterContext 매개 변수로 지정된 미니포트 어댑터는 NDIS가 MiniportRestart를 호출할 때 다시 시작 상태로 들어갑니다.

NDIS가 MiniportRestart를 호출할 때 미니포트 드라이버는 다음과 같습니다.

  • 송신 및 수신 작업을 다시 시작하는 데 필요한 모든 작업을 완료해야 합니다.
  • 필요에 따라 NDIS_MINIPORT_RESTART_PARAMETERS 구조체의 RestartAttributes 멤버에 지정된 다시 시작 특성을 수정합니다. RestartAttributes의 포인터가 NULL인 경우 미니포트 드라이버는 다시 시작 특성 목록을 수정하거나 추가하면 안 됩니다. RestartAttributes의 포인터가 NULL이 아닌 경우 NDIS_RESTART_ATTRIBUTES 구조를 가리킵니다. 미니포트 드라이버가 다시 시작되지 않는 경우 특성을 수정하면 안 됩니다.
  • NdisMIndicateStatusEx 함수를 사용하여 상태 표시를 제공할 수 있습니다.
  • MiniportOidRequest 함수에서 상태 요청을 처리해야 합니다.
미니포트 드라이버가 다시 시작 특성 목록을 수정하는 경우 미니포트 드라이버는 다음과 같습니다.
  • 다시 시작 특성 목록에 새 미디어별 특성을 추가할 수 있습니다. 이 경우 미니포트 드라이버는 새 NDIS_RESTART_ATTRIBUTES 구조(예: NdisAllocateMemoryWithTagPriority 함수)를 할당하고 새 특성에 대한 메모리 공간을 제공해야 합니다. 다시 시작 특성을 지나치게 많은 드라이버에 전파한 후 NDIS는 미니포트 드라이버에 대한 특성 메모리를 해제합니다.
  • 다시 시작 특성 목록에서 미디어별 특성을 수정할 수 있습니다. 미니포트 드라이버에 더 많은 메모리 공간이 필요한 경우 NdisFreeMemory 함수를 사용하여 NDIS_RESTART_ATTRIBUTES 구조를 해제하고 수정된 정보를 포함하도록 새 구조를 할당할 수 있습니다. 다시 시작 특성을 지나치게 많은 드라이버에 전파한 후 NDIS는 미니포트 드라이버에 대한 특성 메모리를 해제합니다.
  • NDIS_RESTART_GENERAL_ATTRIBUTES 구조체의 모든 필드를 수정할 수 있습니다. NDIS가 NDIS_MINIPORT_RESTART_PARAMETERS 구조체의 RestartAttributes 멤버에 NULL이 아닌 포인터를 제공하는 경우 특성 목록에는 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 구조체의 헤더 멤버에 지정된 NDIS_OBJECT_HEADER 구조체에서 Revision 멤버를 확인하여 구조체의 버전을 결정해야 합니다.
NDIS는 다시 시작 작업이 완료될 때까지 미니포트 어댑터(예: 중지, 초기화, 전원 변경 또는 일시 중지 요청)에 대한 다른 PnP(플러그 앤 플레이) 작업을 시작하지 않습니다.

미니포트 드라이버가 송신 및 수신 작업을 성공적으로 다시 시작한 후 다시 시작 작업을 완료해야 합니다. 드라이버가 MiniportRestart에서 NDIS_STATUS_SUCCESS 반환하면 다시 시작 작업이 완료됩니다. 드라이버가 NDIS_STATUS_PENDING 반환하는 경우 다시 시작 작업을 계속할 수 있습니다. 드라이버가 NdisMRestartComplete 함수를 호출한 후 다시 시작 작업이 완료됩니다. 다시 시작 작업이 완료되면 미니포트 어댑터가 실행 중 상태가 됩니다.

미니포트 드라이버는 NDIS가 MiniportRestart 를 호출하고 드라이버가 NdisMRestartComplete를 호출하기 직전에 미니포트 어댑터에 대해 수신된 패킷을 나타내는 것을 다시 시작할 수 있습니다. 미니포트 드라이버는 드라이버가 다시 시작 요청을 완료한 후 보내기 요청을 수락할 준비가 되어 있어야 합니다.

미니포트 드라이버가 송신 및 수신 작업을 다시 시작하지 않는 경우 드라이버는 MiniportRestart에서 적절한 오류 상태를 반환해야 합니다. 이 경우 드라이버는 시작된 송신 또는 수신 작업을 중지한 다음 일시 중지 됨 상태로 돌아가야 합니다.

NDIS는 IRQL = PASSIVE_LEVEL MiniportRestart 를 호출합니다.

예제

MiniportRestart 함수를 정의하려면 먼저 정의하려는 함수의 형식을 식별하는 함수 선언을 제공해야 합니다. Windows 드라이버에 대한 함수 형식 집합을 제공합니다. 함수 형식을 사용하여 함수를 선언하면 드라이버, SDV(정적 드라이버 검증 도구) 및 기타 확인 도구에 대한 Code Analysis 오류를 찾을 수 있으며 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