FILTER_STATUS fungsi panggilan balik (ndis.h)

Fungsi FilterStatus menunjukkan perubahan status yang dilaporkan oleh NDIS atau driver yang mendasar.

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

Sintaks

FILTER_STATUS FilterStatus;

void FilterStatus(
  [in] NDIS_HANDLE FilterModuleContext,
  [in] PNDIS_STATUS_INDICATION StatusIndication
)
{...}

Parameter

[in] FilterModuleContext

Handel ke area konteks untuk modul filter. Driver filter membuat dan menginisialisasi area konteks ini dalam fungsi FilterAttach .

[in] StatusIndication

Penunjuk ke struktur NDIS_STATUS_INDICATION yang berisi informasi status.

Nilai kembali

Tidak ada

Keterangan

FilterStatus adalah fungsi opsional. Jika driver filter tidak menggunakan indikasi status, itu dapat mengatur titik masuk untuk fungsi ini ke NULL ketika memanggil Fungsi NdisFRegisterFilterDriver .

Untuk menentukan status tautan, gunakan indikasi status dari driver yang mendasarinya, bukan kueri OID. Indikasi status ini akan meningkatkan performa sistem dan menghindari kemungkinan kondisi balapan.

Driver filter biasanya memanggil fungsi NdisFIndicateStatus di akhir fungsi FilterStatus-nya untuk meneruskan indikasi status ke driver yang terlalu berlebihan.

Driver filter dapat memfilter indikasi status tertentu atau mengubah status yang ditunjukkan. Untuk memfilter indikasi status, driver hanya tidak memanggil NdisFIndicateStatus.

NDIS memanggil FilterStatus di IRQL <= DISPATCH_LEVEL.

Contoh

Untuk menentukan fungsi FilterStatus , 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 FilterStatus yang bernama "MyStatus", gunakan jenis FILTER_STATUS seperti yang ditunjukkan dalam contoh kode ini:

FILTER_STATUS MyStatus;

Kemudian, terapkan fungsi Anda sebagai berikut:

_Use_decl_annotations_
VOID
 MyStatus(
    NDIS_HANDLE  FilterModuleContext,
    PNDIS_STATUS_INDICATION  StatusIndication
    )
  {...}

Jenis fungsi FILTER_STATUS ditentukan 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_STATUS 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 <= DISPATCH_LEVEL

Lihat juga

FilterAttach

NDIS_STATUS_INDICATION

NdisFIndicateStatus

NdisFRegisterFilterDriver