MINIPORT_SYNCHRONIZE_INTERRUPT fungsi panggilan balik (ndis.h)

Driver miniport harus menyediakan handler MiniportSynchronizeInterrupt jika ada fungsi driver yang berjalan kurang dari DIRQL berbagi sumber daya dengan fungsi MiniportInterrupt .

Untuk gangguan yang disinyalir pesan, driver miniport menyediakan handler MiniportSynchronizeMessageInterrupt jika ada fungsi driver yang berjalan kurang dari sumber daya berbagi DIRQL untuk pesan yang disinyalir mengganggu fungsi MiniportMessageInterrupt .

Catatan Anda harus mendeklarasikan fungsi ini dengan menggunakan jenis MINIPORT_SYNCHRONIZE_INTERRUPT untuk interupsi sinyal non-pesan, atau dengan menggunakan jenis MINIPORT_SYNCHRONIZE_MESSAGE_INTERRUPT untuk gangguan sinyal pesan. Untuk informasi selengkapnya, lihat bagian Contoh berikut ini.
 

Sintaks

MINIPORT_SYNCHRONIZE_INTERRUPT MiniportSynchronizeInterrupt;

BOOLEAN MiniportSynchronizeInterrupt(
  [in] NDIS_HANDLE SynchronizeContext
)
{...}

Parameter

[in] SynchronizeContext

Handel ke area konteks yang disediakan ketika MiniportXxx driver miniport atau fungsi internal yang disebut Fungsi NdisMSynchronizeWithInterruptEx .

Nilai kembali

MiniportSynchronizeInterrupt mengembalikan nilai Boolean dengan arti yang ditentukan driver. NDIS mengembalikan nilai yang sama saat NDIS kembali dari NdisMSynchronizeWithInterruptEx.

Keterangan

Catatan Informasi di bagian ini juga dapat berlaku untuk interupsi bersinyalir pesan dengan mengganti "MiniportInterrupt" untuk "MiniportMessageInterrupt," dan dengan mengganti "MiniportSynchronizeInterrupt" untuk "MiniportSynchronizeMessageInterrupt."
 
Jika ada fungsi driver miniport yang berjalan kurang dari DIRQL berbagi sumber daya, seperti register NIC, dengan fungsi MiniportInterrupt driver, driver tersebut tidak dapat mengakses sumber daya tersebut secara langsung. Jika fungsi prioritas yang lebih rendah seperti itu mencoba mengakses sumber daya bersama secara langsung, fungsi tersebut mungkin didahulukan oleh MiniportInterrupt, yang dapat mengambil alih perubahan status fungsi driver prioritas yang lebih rendah.

Untuk menyinkronkan akses ke sumber daya bersama dengan MiniportInterrupt, fungsi driver prioritas yang lebih rendah harus memanggil Fungsi NdisMSynchronizeWithInterruptEx . Fungsi MiniportSynchronizeInterrupt driver mengakses sumber daya bersama di DIRQL. Memanggil NdisMSynchronizeWithInterruptEx mencegah kondisi balapan dan kebuntuan dalam pembalap miniport seperti itu.

Setiap fungsi driver prioritas yang lebih rendah yang berbagi sumber daya di antara mereka sendiri (tetapi tidak dengan fungsi apa pun yang berjalan di DIRQL) harus menggunakan kunci putar untuk melindungi sumber daya bersama tersebut.

MiniportSynchronizeInterrupt berjalan di DIRQL yang ditetapkan ketika fungsi MiniportInitializeEx driver memanggil Fungsi NdisMRegisterInterruptEx . Seperti fungsi driver apa pun yang berjalan di DIRQL, MiniportSynchronizeInterrupt harus mengembalikan kontrol kembali ke pemanggil secepat mungkin, dan hanya dapat memanggil fungsi NdisXxx yang aman untuk dipanggil di IRQL apa pun.

Contoh

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

MINIPORT_SYNCHRONIZE_INTERRUPT MySynchronizeInterrupt;

Kemudian, terapkan fungsi Anda sebagai berikut:

_Use_decl_annotations_
BOOLEAN
 MySynchronizeInterrupt(
    NDIS_HANDLE  SynchronizeContext
    )
  {...}

Untuk menentukan fungsi MiniportSynchronizeMessageInterrupt untuk interupsi sinyal pesan, gunakan jenis MINIPORT_SYNCHRONIZE_MESSAGE_INTERRUPT seperti yang ditunjukkan dalam contoh kode ini:

MINIPORT_SYNCHRONIZE_MESSAGE_INTERRUPT MySynchronizeMessageInterrupt;

Kemudian, terapkan fungsi Anda sebagai berikut:

_Use_decl_annotations_
BOOLEAN
 MySynchronizeMessageInterrupt(
    NDIS_HANDLE  SynchronizeContext
    )
  {...}

Jenis fungsi MINIPORT_SYNCHRONIZE_INTERRUPT dan MINIPORT_SYNCHRONIZE_MESSAGE_INTERRUPT 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 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 Lihat bagian Keterangan

Lihat juga

MiniportInetrrupt

MiniportInitializeEx

NdisAllocateSpinLock

NdisMRegisterInterruptEx

NdisMSynchronizeWithInterruptEx