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.

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

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:

  1. 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.
  2. Menghapus dari antrean kirim (un-link) semua struktur NET_BUFFER_LIST yang pengidentifikasi pembatalannya cocok dengan pengidentifikasi pembatalan yang ditentukan.
  3. 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.
Fungsi MiniportCancelSend driver menengah melakukan operasi berikut:
  1. Melakukan operasi dalam daftar sebelumnya untuk fungsi MiniportCancelSend driver miniport.
  2. Memanggil Fungsi NdisCancelSendNetBufferLists , menentukan pengikatan yang memetakan ke adaptor yang ditentukan NDIS dalam panggilan ke MiniportCancelSend.
NDIS memanggil MiniportCancelSend di IRQL <= DISPATCH_LEVEL.

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

Lihat juga

MiniportInitializeEx

NDIS_GET_NET_BUFFER_LIST_CANCEL_ID

NET_BUFFER

NET_BUFFER_LIST

NdisCancelSendNetBufferLists

NdisMSendNetBufferListsComplete