FILTER_DIRECT_OID_REQUEST_COMPLETE fungsi panggilan balik (ndis.h)

NDIS memanggil fungsi FilterDirectOidRequestComplete untuk menyelesaikan permintaan OID langsung driver filter yang mengkueri atau mengatur informasi dalam driver yang mendasar.

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

Sintaks

FILTER_DIRECT_OID_REQUEST_COMPLETE FilterDirectOidRequestComplete;

void FilterDirectOidRequestComplete(
  [in] NDIS_HANDLE FilterModuleContext,
  [in] PNDIS_OID_REQUEST OidRequest,
  [in] NDIS_STATUS Status
)
{...}

Parameter

[in] FilterModuleContext

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

[in] OidRequest

Penunjuk ke struktur NDIS_OID_REQUEST yang sebelumnya diteruskan driver filter ke Fungsi NdisFDirectOidRequest .

[in] Status

Status akhir permintaan yang ditetapkan driver atau NDIS yang mendasar. Parameter ini menentukan apa yang dilakukan FilterDirectOidRequestComplete dengan informasi di OidRequest . Untuk daftar nilai status yang mungkin, lihat nilai yang dikembalikan dari NdisFDirectOidRequest.

Mengembalikan nilai

Tidak ada

Keterangan

FilterDirectOidRequestComplete adalah fungsi opsional. Jika driver filter tidak menggunakan permintaan OID langsung, driver dapat mengatur titik masuk untuk fungsi ini ke NULL saat memanggil Fungsi NdisFRegisterFilterDriver . Jika driver filter menentukan fungsi FilterDirectOidRequest , driver filter tersebut harus menyediakan fungsi FilterDirectOidRequestComplete .

Jika fungsi NdisFDirectOidRequest mengembalikan NDIS_STATUS_PENDING, NDIS harus memanggil fungsi FilterDirectOidRequestComplete untuk menyelesaikan permintaan OID.

Jika driver filter meneruskan permintaan yang diterimanya dalam fungsi FilterDirectOidRequest ,
FilterDirectOidRequestComplete harus meneruskan status penyelesaian ke tumpukan driver dengan memanggil
Fungsi NdisFDirectOidRequestComplete . Dalam hal ini, driver filter harus memanggil NdisFreeCloneOidRequest, untuk membebaskan struktur NDIS_OID_REQUEST , sebelum memanggil
NdisFDirectOidRequestComplete.

Driver filter harus melacak permintaan yang berasal dan memastikan bahwa ia tidak memanggil NdisFDirectOidRequestComplete saat NDIS memanggil FilterDirectOidRequestComplete untuk permintaan tersebut.

NDIS memanggil FilterDirectOidRequestComplete di IRQL <= DISPATCH_LEVEL.

Contoh

Untuk menentukan fungsi FilterDirectOidRequestComplete , 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 FilterDirectOidRequestComplete yang diberi nama "MyDirectOidRequestComplete", gunakan jenis FILTER_DIRECT_OID_REQUEST_COMPLETE seperti yang ditunjukkan dalam contoh kode ini:

FILTER_DIRECT_OID_REQUEST_COMPLETE MyDirectOidRequestComplete;

Kemudian, terapkan fungsi Anda sebagai berikut:

_Use_decl_annotations_
VOID
 MyDirectOidRequestComplete(
    NDIS_HANDLE  FilterModuleContext,
    PNDIS_OID_REQUEST  OidRequest,
    NDIS_STATUS Status
    )
  {...}

Jenis fungsi FILTER_DIRECT_OID_REQUEST_COMPLETE 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_DIRECT_OID_REQUEST_COMPLETE 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.1 dan yang lebih baru.
Target Platform Windows
Header ndis.h (termasuk Ndis.h)
IRQL <= DISPATCH_LEVEL

Lihat juga

FilterAttach

FilterDirectOidRequest

NDIS_OID_REQUEST

NdisFDirectOidRequest

NdisFDirectOidRequestComplete

NdisFRegisterFilterDriver

NdisFreeCloneOidRequest