FILTER_PAUSE fungsi panggilan balik (ndis.h)
NDIS memanggil fungsi FilterPause driver filter untuk memulai operasi jeda untuk modul filter yang ditentukan.
Sintaks
FILTER_PAUSE FilterPause;
NDIS_STATUS FilterPause(
[in] NDIS_HANDLE FilterModuleContext,
[in] PNDIS_FILTER_PAUSE_PARAMETERS PauseParameters
)
{...}
Parameter
[in] FilterModuleContext
Handel ke area konteks untuk modul filter yang harus dijeda oleh driver filter. Driver filter membuat dan menginisialisasi area konteks ini dalam fungsi FilterAttach .
[in] PauseParameters
Penunjuk ke NDIS_FILTER_PAUSE_PARAMETERS struktur yang menentukan parameter jeda untuk modul filter.
Mengembalikan nilai
Driver NDIS tidak dapat gagal dalam permintaan jeda. Driver filter harus memanggil fungsi NdisWriteEventLogEntry bersama dengan parameter yang menentukan alasan kesalahan yang terjadi.
Menampilkan kode | Deskripsi |
---|---|
|
FilterPause berhasil menjeda modul filter yang ditentukan. |
|
Driver filter akan menyelesaikan permintaan secara asinkron dengan panggilan ke fungsi NdisFPauseComplete . |
Keterangan
FilterPause adalah fungsi yang diperlukan. NDIS dapat memanggil FilterPause saat modul filter berada dalam status Berjalan . Modul filter memasuki status Jeda pada awal eksekusi dalam fungsi FilterPause .
Driver filter melakukan operasi berikut saat NDIS memanggil FilterPause:
- Harus memanggil Fungsi NdisFSendNetBufferListsComplete untuk setiap buffer pengiriman antrean yang dibuat driver yang terlalu berlebihan.
- Harus memanggil Fungsi NdisFReturnNetBufferLists untuk setiap buffer penerima antrean yang dibuat oleh driver yang mendasar.
- Harus menunggu NDIS mengembalikan semua permintaan pengiriman yang luar biasa yang berasal dari driver Fungsi FilterSendNetBufferListsComplete .
- Harus menunggu NDIS mengembalikan semua indikasi penerima yang beredar bahwa driver berasal dari Fungsi FilterReturnNetBufferLists .
Dalam status Jeda atau Dijeda , driver filter harus terus menangani permintaan OID atau indikasi status. Driver harus menolak panggilan ke Fungsi FilterSendNetBufferLists . Pengemudi dapat meneruskan panggilan ke Fungsi FilterReceiveNetBufferLists . Namun, driver tidak dapat melewati buffer apa pun yang dibuatnya. Driver tidak boleh berasal dari indikasi penerima atau mengirim permintaan.
Dalam status Dijeda , modul filter tidak boleh menghasilkan permintaan kirim atau menerima indikasi.
NDIS memanggil fungsi FilterRestart untuk memulai permintaan hidupkan ulang untuk modul filter yang berada dalam status Dijeda .
NDIS memanggil FilterPause di IRQL = PASSIVE_LEVEL.
Contoh
Untuk menentukan fungsi FilterPause , 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 FilterPause yang diberi nama "MyPause", gunakan jenis FILTER_PAUSE seperti yang ditunjukkan dalam contoh kode ini:
FILTER_PAUSE MyPause;
Kemudian, terapkan fungsi Anda sebagai berikut:
_Use_decl_annotations_
NDIS_STATUS
MyPause(
NDIS_HANDLE FilterModuleContext,
PNDIS_FILTER_PAUSE_PARAMETERS FilterPauseParameters
)
{...}
Jenis fungsi FILTER_PAUSE 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 FILTER_PAUSE 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 |
Lihat juga
FilterSendNetBufferListsComplete NdisFSendNetBufferListsCompleteSaran dan Komentar
https://aka.ms/ContentUserFeedback.
Segera hadir: Sepanjang tahun 2024 kami akan menghentikan penggunaan GitHub Issues sebagai mekanisme umpan balik untuk konten dan menggantinya dengan sistem umpan balik baru. Untuk mengetahui informasi selengkapnya, lihat:Kirim dan lihat umpan balik untuk