MINIPORT_CANCEL_SEND fungsi panggilan balik (ndis.h)
NDIS memanggil fungsi MiniportCancelSend driver miniport untuk membatalkan transmisi semua struktur NET_BUFFER_LIST yang ditandai dengan pengidentifikasi pembatalan tertentu.
Sintaks
MINIPORT_CANCEL_SEND MiniportCancelSend;
void MiniportCancelSend(
[in] NDIS_HANDLE MiniportAdapterContext,
[in] PVOID CancelId
)
{...}
Parameter
[in] MiniportAdapterContext
Handel ke area konteks yang dialokasikan driver miniport dalam fungsi MiniportInitializeEx-nya . Driver miniport menggunakan area konteks ini untuk mempertahankan informasi status tentang adaptor.
[in] CancelId
Pengidentifikasi pembatalan. Pengidentifikasi ini menentukan struktur NET_BUFFER_LIST yang sedang dibatalkan.
Nilai kembali
Tidak ada
Keterangan
Driver miniport dan driver perantara yang mengantre mengirim struktur NET_BUFFER_LIST mengekspor fungsi MiniportCancelSend . Fungsi MiniportCancelSend membatalkan transmisi tertunda dari struktur NET_BUFFER_LIST yang ditentukan.
Ketika driver NDIS yang terlalu berlebih memanggil Fungsi NdisCancelSendNetBufferLists , NDIS memanggil fungsi MiniportCancelSend dari driver tingkat bawah yang sesuai pada pengikatan. NDIS melakukan panggilan ini hanya jika driver tingkat bawah mengekspor fungsi MiniportCancelSend .
Fungsi MiniportCancelSend driver miniport melakukan operasi berikut:
- Melintasi daftar struktur NET_BUFFER_LIST antreannya untuk adaptor yang ditentukan dan memanggil NDIS_GET_NET_BUFFER_LIST_CANCEL_ID makro untuk mendapatkan pengidentifikasi pembatalan untuk setiap struktur NET_BUFFER_LIST yang diantrekan. Driver miniport membandingkan pengidentifikasi pembatalan yang NDIS_GET_NET_BUFFER_LIST_CANCEL_ID kembali dengan pengidentifikasi pembatalan yang diteruskan NDIS ke MiniportCancelSend.
- Menghapus dari antrean kirim (un-link) semua struktur NET_BUFFER_LIST yang pengidentifikasi pembatalannya cocok dengan pengidentifikasi pembatalan yang ditentukan.
- Memanggil Fungsi NdisMSendNetBufferListsComplete untuk semua struktur NET_BUFFER_LIST yang tidak ditautkan untuk mengembalikan struktur . Driver miniport mengatur bidang status struktur NET_BUFFER_LIST ke NDIS_STATUS_SEND_ABORTED.
- Melakukan operasi dalam daftar sebelumnya untuk fungsi MiniportCancelSend driver miniport.
- Memanggil Fungsi NdisCancelSendNetBufferLists , menentukan pengikatan yang memetakan ke adaptor yang ditentukan NDIS dalam panggilan ke MiniportCancelSend.
Contoh
Untuk menentukan fungsi MiniportCancelSend , Anda harus terlebih dahulu memberikan deklarasi fungsi yang mengidentifikasi jenis fungsi yang Anda tentukan. Windows menyediakan sekumpulan tipe fungsi panggilan balik untuk driver. 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 MiniportCancelSend yang diberi nama "MyCancelSend", gunakan jenis MINIPORT_CANCEL_SEND seperti yang ditunjukkan dalam contoh kode ini:
MINIPORT_CANCEL_SEND MyCancelSend;
Kemudian, terapkan fungsi Anda sebagai berikut:
_Use_decl_annotations_
VOID
MyCancelSend(
NDIS_HANDLE MiniportAdapterContext,
PVOID CancelId
)
{...}
Jenis fungsi MINIPORT_CANCEL_SEND 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 MINIPORT_CANCEL_SEND 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 |