MINIPORT_HALT fungsi panggilan balik (ndis.h)

NDIS memanggil fungsi MiniportHaltEx driver miniport untuk membebaskan sumber daya saat adaptor miniport dihapus, dan untuk menghentikan perangkat keras. Fungsi ini menempatkan miniport ke dalam status Dihentikan, di mana tidak ada panggilan balik lain yang dapat terjadi (termasuk MiniportShutdownEx). Untuk informasi selengkapnya tentang status driver miniport, lihat Status dan Operasi Adaptor Miniport.

Catatan Anda harus mendeklarasikan fungsi dengan menggunakan jenis MINIPORT_HALT . Untuk informasi selengkapnya, lihat bagian Contoh berikut ini.
 

Sintaks

MINIPORT_HALT MiniportHalt;

void MiniportHalt(
  [in] NDIS_HANDLE MiniportAdapterContext,
  [in] NDIS_HALT_ACTION HaltAction
)
{...}

Parameter

[in] MiniportAdapterContext

Handel ke area konteks yang dialokasikan driver miniport dalam fungsi MiniportInitializeEx-nya . Driver miniport menggunakan area konteks ini untuk mempertahankan informasi status untuk adaptor miniport.

[in] HaltAction

Alasan untuk menghentikan adaptor miniport. Jenis dapat berupa salah satu dari nilai berikut:

NdisHaltDeviceDisabled

NDIS menghentikan adaptor miniport sebagai respons terhadap pesan penghapusan Plug and Play (PnP).

NdisHaltDeviceInstanceDeInitialized

NDIS menghentikan adaptor miniport sebagai respons terhadap driver perantara yang memanggil Fungsi NdisIMDeInitializeDeviceInstance .

NdisHaltDevicePoweredDown

NDIS menghentikan adaptor miniport karena sistem akan dalam keadaan tidur.

NdisHaltDeviceSurpriseRemoved

Adaptor miniport telah terkejut dihapus dan perangkat keras tidak ada.

NdisHaltDeviceFailed

Adaptor miniport sedang dihapus karena kegagalan perangkat keras. Baik driver miniport yang disebut fungsi NdisMRemoveMiniport atau driver bus tidak menyalakan NIC saat dilanjutkan.

NdisHaltDeviceInitializationFailed

NDIS tidak dapat menginisialisasi adaptor miniport karena alasan yang tidak diketahui setelah fungsi MiniportInitializeEx berhasil diselesaikan.

NdisHaltDeviceStopped

NDIS menghentikan adaptor miniport sebagai respons terhadap pesan perangkat berhenti PnP.

Nilai kembali

Tidak ada

Keterangan

Driver menentukan titik masuk MiniportHaltEx saat memanggil Fungsi NdisMRegisterMiniportDriver .

NDIS dapat memanggil MiniportHaltEx kapan saja setelah fungsi MiniportInitializeEx driver berhasil dikembalikan. Jika driver mengontrol NIC fisik, MiniportHaltEx harus menghentikan NIC. Jika driver perantara NDIS memanggil Fungsi NdisIMDeInitializeDeviceInstance , NDIS memanggil fungsi MiniportHaltEx untuk perangkat virtual driver.

MiniportHaltEx harus membebaskan semua sumber daya yang dialokasikan di MiniportInitializeEx untuk perangkat. MiniportHaltEx juga membebaskan sumber daya lain yang dialokasikan driver dalam operasi berikutnya untuk perangkat tersebut. Driver harus memanggil timbal balik fungsi NdisXxx yang awalnya dialokasikan sumber dayanya. Sebagai aturan umum, fungsi MiniportHaltEx harus memanggil fungsi NdisXxx timbal balik ke panggilan driver yang dibuat dari MiniportInitializeEx.

Jika NIC menghasilkan gangguan, fungsi MiniportHaltEx driver miniport dapat didahulukan oleh fungsi MiniportInterrupt driver hingga panggilan MiniportHaltEx ke Fungsi NdisMDeregisterInterruptEx kembali. Fungsi MiniportHaltEx driver seperti itu harus menonaktifkan gangguan, dan memanggil NdisMDeregisterInterruptEx sesegera mungkin. Perhatikan bahwa driver dapat terus mengalami gangguan hingga NdisMDeregisterInterruptEx kembali. NdisMDeregisterInterruptEx tidak kembali sampai driver menyelesaikan semua DPC terjadwal (lihat fungsi MiniportInterruptDPC untuk informasi selengkapnya).

Jika driver memiliki fungsi NetTimerCallback yang terkait dengan objek timer yang bisa berada dalam antrean timer sistem, MiniportHaltEx harus memanggil fungsi NdisCancelTimerObject . Jika NdisCancelTimerObject gagal, timer bisa saja diaktifkan. Dalam hal ini, driver harus menunggu fungsi timer selesai sebelum driver kembali dari MiniportHaltEx.

NDIS tidak memanggil MiniportHaltEx jika ada permintaan OID yang luar biasa atau mengirim permintaan. NDIS tidak mengirimkan permintaan lebih lanjut untuk perangkat yang terpengaruh setelah NDIS memanggil MiniportHaltEx.

Jika driver harus menunggu operasi apa pun selesai, MiniportHaltEx dapat menggunakan fungsi NdisWaitEvent atau fungsi NdisMSleep .

NDIS memanggil MiniportHaltEx di IRQL = PASSIVE_LEVEL.

Contoh

Untuk menentukan fungsi MiniportHaltEx , Anda harus terlebih dahulu memberikan deklarasi fungsi yang mengidentifikasi jenis fungsi yang Anda tentukan. Windows menyediakan sekumpulan tipe fungsi untuk pengandar. Mendeklarasikan fungsi menggunakan jenis fungsi membantu Analisis Kode untuk Driver, Pemverifikasi Driver Statis (SDV), dan alat verifikasi lainnya menemukan kesalahan, dan itu adalah persyaratan untuk menulis driver untuk sistem operasi Windows.

Misalnya, untuk menentukan fungsi MiniportHaltEx yang diberi nama "MyHaltEx", gunakan jenis MINIPORT_HALT seperti yang ditunjukkan dalam contoh kode ini:

MINIPORT_HALT MyHaltEx;

Kemudian, terapkan fungsi Anda sebagai berikut:

_Use_decl_annotations_
VOID
 MyHaltEx(
    NDIS_HANDLE  MiniportAdapterContext,
    NDIS_HALT_ACTION  HaltAction
    )
  {...}

Jenis fungsi MINIPORT_HALT didefinisikan dalam file header Ndis.h. Untuk mengidentifikasi kesalahan secara lebih akurat saat Anda menjalankan alat analisis kode, pastikan untuk menambahkan anotasi Use_decl_annotations ke definisi fungsi Anda. Anotasi Use_decl_annotations memastikan bahwa anotasi yang diterapkan ke jenis fungsi MINIPORT_HALT dalam file header digunakan. Untuk informasi selengkapnya tentang persyaratan untuk deklarasi fungsi, lihat Mendeklarasikan Fungsi dengan Menggunakan Jenis Peran Fungsi untuk Driver NDIS.

Untuk informasi tentang Use_decl_annotations, lihat Perilaku Fungsi Anotasi.

Persyaratan

Persyaratan Nilai
Klien minimum yang didukung Didukung di NDIS 6.0 dan yang lebih baru.
Target Platform Windows
Header ndis.h (termasuk Ndis.h)
IRQL PASSIVE_LEVEL
Aturan kepatuhan DDI WlanAssociation, WlanConnectionRoaming, WlanDisassociation, WlanTimedAssociation, WlanTimedConnectionRoaming, WlanTimedConnectRequest, WlanTimedLinkQuality, WlanTimedScan

Lihat juga

Status Adaptor Driver Miniport

Menghentikan Adaptor Miniport

Status dan Operasi Adapter Miniport

Fungsi Reset dan Pengandar Miniport Dihentikan

MiniportInitializeEx

MiniportInterrupt

MiniportInterruptDPC

MiniportReturnNetBufferLists

NdisCancelTimerObject

NdisIMDeInitializeDeviceInstance

NdisMDeregisterInterruptEx

NdisMRegisterMiniportDriver

NdisMRemoveMiniport

NdisMSleep

NdisWaitEvent

NetTimerCallback