FILTER_OID_REQUEST_COMPLETE fungsi panggilan balik (ndis.h)
NDIS memanggil fungsi FilterOidRequestComplete untuk menyelesaikan permintaan driver filter yang mengkueri atau mengatur informasi dalam driver yang mendasar.
Sintaks
FILTER_OID_REQUEST_COMPLETE FilterOidRequestComplete;
void FilterOidRequestComplete(
[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 NdisFOidRequest .
[in] Status
Status akhir permintaan yang ditetapkan oleh driver yang mendasar atau oleh NDIS. Parameter ini menentukan apa yang dilakukan FilterOidRequestComplete dengan informasi di OidRequest . Untuk daftar nilai status yang mungkin, lihat nilai pengembalian NdisFOidRequest.
Nilai kembali
Tidak ada
Keterangan
FilterOidRequestComplete adalah fungsi opsional. Jika driver filter tidak menggunakan permintaan OID, itu dapat mengatur titik masuk untuk fungsi ini ke NULL saat memanggil fungsi NdisFRegisterFilterDriver . Jika driver filter menentukan fungsi FilterOidRequest , driver filter harus menyediakan fungsi FilterOidRequestComplete .
Jika fungsi NdisFOidRequest mengembalikan NDIS_STATUS_PENDING, NDIS harus memanggil fungsi FilterOidRequestComplete untuk menyelesaikan permintaan OID.
Jika driver filter meneruskan permintaan yang diterimanya dalam fungsi FilterOidRequest , FilterOidRequestComplete harus meneruskan status penyelesaian ke atas tumpukan driver dengan memanggil fungsi NdisFOidRequestComplete . Driver filter harus memanggil NdisFreeCloneOidRequest, untuk membebaskan struktur NDIS_OID_REQUEST, sebelum memanggil NdisFOidRequestComplete.
Driver filter harus melacak permintaan yang berasal dan memastikan bahwa ia tidak memanggil NdisFOidRequestComplete saat NDIS memanggil FilterOidRequestComplete untuk permintaan tersebut.
NDIS memanggil FilterOidRequestComplete di IRQL <= DISPATCH_LEVEL.
Contoh
Untuk menentukan fungsi FilterOidRequestComplete , 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 FilterOidRequestComplete yang diberi nama "MyOidRequestComplete", gunakan jenis FILTER_OID_REQUEST_COMPLETE seperti yang ditunjukkan dalam contoh kode ini:
FILTER_OID_REQUEST_COMPLETE MyOidRequestComplete;
Kemudian, terapkan fungsi Anda sebagai berikut:
_Use_decl_annotations_
NDIS_STATUS
MyOidRequestComplete(
NDIS_HANDLE FilterModuleContext,
PNDIS_OID_REQUEST OidRequest,
NDIS_STATUS Status
)
{...}
Jenis fungsi FILTER_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_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.0 dan yang lebih baru. |
Target Platform | Windows |
Header | ndis.h (termasuk Ndis.h) |
IRQL | <= DISPATCH_LEVEL |
Lihat juga
Saran 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