FILTER_DIRECT_OID_REQUEST fungsi panggilan balik (ndis.h)

NDIS memanggil fungsi FilterDirectOidRequest driver filter untuk memproses permintaan OID langsung yang terkait dengan modul filter yang ditentukan.

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

Sintaks

FILTER_DIRECT_OID_REQUEST FilterDirectOidRequest;

NDIS_STATUS FilterDirectOidRequest(
  [in] NDIS_HANDLE FilterModuleContext,
  [in] PNDIS_OID_REQUEST OidRequest
)
{...}

Parameter

[in] FilterModuleContext

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

[in] OidRequest

Penunjuk ke struktur NDIS_OID_REQUEST yang menentukan operasi yang diminta, termasuk kode OID_ Xx . Struktur dapat menentukan permintaan kueri atau permintaan yang ditetapkan

Nilai kembali

FilterDirectOidRequest mengembalikan salah satu nilai status berikut:

Menampilkan kode Deskripsi
NDIS_STATUS_SUCCESS
FilterDirectOidRequest berhasil menyelesaikan kueri driver filter atau mengatur operasi untuk modul filter ini.
NDIS_STATUS_PENDING
Driver filter akan menyelesaikan permintaan secara asinkron. Setelah driver menyelesaikan permintaan, driver harus memanggil Fungsi NdisFDirectOidRequestComplete untuk memberi tahu NDIS bahwa permintaan selesai.
NDIS_STATUS_INVALID_OID
Permintaan yang ditentukan OidRequest tidak valid atau tidak dikenali.
NDIS_STATUS_NOT_SUPPORTED
FilterDirectOidRequest tidak mendukung OID; OID bersifat opsional.
NDIS_STATUS_BUFFER_TOO_SHORT
Buffer yang disediakan OidRequest terlalu kecil untuk menyimpan data yang diminta.
NDIS_STATUS_INVALID_LENGTH
Untuk operasi kueri, anggota InformationBufferLength dari struktur NDIS_OID_REQUEST tidak cocok dengan panjang yang diperlukan OID yang diberikan. FilterDirectOidRequest mengembalikan ukuran buffer yang diperlukan, dalam byte, di anggota BytesNeeded dari struktur NDIS_OID_REQUEST.
NDIS_STATUS_INVALID_DATA
Untuk operasi set, data yang disediakan di anggota InformationBuffer dari struktur NDIS_OID_REQUEST tidak valid untuk OID yang diberikan.
NDIS_STATUS_NOT_ACCEPTED
FilterDirectOidRequest mencoba mengumpulkan informasi yang diminta tetapi tidak berhasil.
NDIS_STATUS_RESOURCES
FilterDirectOidRequest gagal karena sumber daya yang tidak mencukup.
NDIS_STATUS_FAILURE
N salah satu nilai pengembalian sebelumnya berlaku. Driver filter harus memanggil fungsi NdisWriteErrorLogEntry dengan parameter yang menentukan alasan kegagalan.

Keterangan

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

NDIS memanggil fungsi FilterDirectOidRequest driver filter untuk memproses permintaan OID langsung yang berasal dari driver yang terlalu berlebihan. Driver filter dapat meneruskan permintaan tersebut ke driver yang mendasar dengan memanggil fungsi NdisFDirectOidRequest . Sebagai opsi, driver filter juga dapat segera menyelesaikan permintaan tanpa meneruskan permintaan.

Sebelum driver memanggil NdisFDirectOidRequest, driver harus mengalokasikan struktur NDIS_OID_REQUEST dan mentransfer informasi permintaan ke struktur baru dengan memanggil Fungsi NdisAllocateCloneOidRequest .

Untuk menyelesaikan permintaan secara sinkron, driver filter mengembalikan NDIS_STATUS_SUCCESS atau status kegagalan. Jika driver kembali NDIS_STATUS_PENDING, driver harus memanggil Fungsi NdisFDirectOidRequestComplete untuk memberi tahu NDIS bahwa permintaan selesai.

Untuk operasi kueri, FilterDirectOidRequest mengembalikan informasi yang diminta di anggota InformationBuffer dan mengatur variabel di anggota BytesWritten dari struktur NDIS_OID_REQUEST ke jumlah informasi yang dikembalikannya. Driver yang mendasar melakukan ini jika driver filter meneruskan permintaan dengan NdisFDirectOidRequest.

Untuk operasi yang ditetapkan , FilterDirectOidRequest dapat menggunakan data di anggota InformationBuffer dari struktur NDIS_OID_REQUEST untuk mengatur informasi yang diperlukan OID yang diberikan. Dalam hal ini, FilterDirectOidRequest mengatur variabel di BytesRead ke jumlah data yang disediakan yang digunakannya. Driver yang mendasar mengatur BytesRead dengan cara ini jika driver filter meneruskan permintaan dengan NdisFDirectOidRequest.

NDIS tidak membuat serial permintaan yang dikirimnya ke FilterDirectOidRequest dengan permintaan OID lainnya. Driver filter harus dapat menangani beberapa panggilan ke FilterDirectOidRequest ketika permintaan lain yang dikirim ke FilterOidRequest atau FilterDirectOidRequest luar biasa.

NDIS memanggil FilterDirectOidRequest di IRQL <= DISPATCH_LEVEL.

Contoh

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

FILTER_DIRECT_OID_REQUEST MyDirectOidRequest;

Kemudian, terapkan fungsi Anda sebagai berikut:

_Use_decl_annotations_
NDIS_STATUS
 MyDirectOidRequest(
    NDIS_HANDLE  FilterModuleContext,
    PNDIS_OID_REQUEST  OidRequest
    )
  {...}

Jenis fungsi FILTER_DIRECT_OID_REQUEST 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_DIRECT_OID_REQUEST 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

FilterDirectOidRequestComplete

FilterOidRequest

NDIS_OID_REQUEST

NdisAllocateCloneOidRequest

NdisFDirectOidRequest

NdisFDirectOidRequestComplete

NdisWriteErrorLogEntry