HW_MESSAGE_SIGNALED_INTERRUPT_ROUTINE fungsi panggilan balik (storport.h)

Rutinitas HwMSInterruptRoutine menangani interupsi bersinyali pesan (MSI).

Sintaks

HW_MESSAGE_SIGNALED_INTERRUPT_ROUTINE HwMessageSignaledInterruptRoutine;

BOOLEAN HwMessageSignaledInterruptRoutine(
  IN PVOID HwDeviceExtension,
  IN ULONG MessageId
)
{...}

Parameter

HwDeviceExtension

Pointer ke ekstensi perangkat keras untuk adaptor bus host (HBA).

MessageId

Pengidentifikasi pesan.

Nilai kembali

HwMSInterruptRoutine mengembalikan TRUE jika menentukan bahwa HBA menghasilkan MSI. Jika HBA tidak menghasilkan MSI, HwMSInterruptRoutine mengembalikan FALSE.

Keterangan

HwMSInterruptRoutine driver miniport memproses pesan sinyal interupsi (MSI) yang dihasilkan oleh HBA. Driver miniport menunjukkan bahwa HBA-nya menghasilkan MSI dengan mengatur anggota HwMSInterruptRoutine dari struktur PORT_CONFIGURATION_INFORMATION untuk menunjuk ke rutinitas HwMSInterruptRoutine . Jika HBA tidak menghasilkan MSI, driver miniport harus mengatur HwMSInterruptRoutine ke NULL.

Jika anggota InterruptSynchronizationMode dari struktur PORT_CONFIGURATION_INFORMATION diatur ke InterruptSynchronizeAll, driver Storport menyinkronkan semua MSI yang berasal dari adaptor yang dikelolanya atau perangkat yang terhubung ke adaptor. Ketika gangguan terjadi, driver Storport memanggil rutinitas HwMSInterruptRoutine driver miniport di DIRQL setelah memperoleh kunci spin yang mengganggu.

Jika anggota InterruptSynchronizationMode dari struktur PORT_CONFIGURATION_INFORMATION diatur ke InterruptSynchronizePerMessage, driver Storport memanggil rutinitas HwMSInterruptRoutine driver miniport di IRQL = DIRQL, menahan kunci spin interupsi yang sesuai dengan pengidentifikasi pesan (ID) yang ditunjukkan dalam parameter MessageID . HBA dapat mengganggu rutinitas HwMSInterruptRoutine untuk interupsi untuk ID pesan lain, sehingga driver Storport mungkin melakukan panggilan berlapis ke HwMSInterruptRoutine, atau menjalankan instans HwMSInterruptRoutine yang berbeda secara bersamaan pada prosesor yang berbeda. Untuk menyinkronkan akses ke data sensitif oleh berbagai instans HwMSInterruptRoutine, miniport harus memanggil rutinitas StorPortAcquireMSISpinLock dan StorPortReleaseMSISpinLock untuk memperoleh dan melepaskan kunci putar untuk ID pesan selain ID di MessageID.

Driver miniport dapat mengambil informasi tambahan tentang pesan dengan memanggil rutinitas StorPortGetMSIInfo .

Ini tidak boleh memanggil rutinitas StorPortGetMSIInfo dari dalam rutinitas HwMSInterruptRoutine .

Nama HwMSInterruptRoutine hanyalah tempat penampung. Prototipe aktual untuk rutinitas ini didefinisikan dalam Storport.h sebagai berikut:

typedef
BOOLEAN
  HW_MESSAGE_SIGNALED_INTERRUPT_ROUTINE (
    _In_ PVOID  HwDeviceExtension,
    _In_ ULONG  MessageId
    );

Contoh

Untuk menentukan fungsi panggilan balik HwMSInterruptRoutine , Anda harus terlebih dahulu memberikan deklarasi fungsi yang mengidentifikasi jenis fungsi panggilan balik yang Anda tentukan. Windows menyediakan sekumpulan tipe fungsi panggilan balik untuk pengandar. Mendeklarasikan fungsi menggunakan jenis fungsi panggilan balik 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 rutinitas panggilan balik HwMSInterruptRoutine yang diberi nama MyHwMSIRoutine, gunakan jenis HW_MESSAGE_SIGNALED_INTERRUPT_ROUTINE seperti yang ditunjukkan dalam contoh kode ini:

HW_MESSAGE_SIGNALED_INTERRUPT_ROUTINE MyHwMSIRoutine;

Kemudian, terapkan rutinitas panggilan balik Anda sebagai berikut:

_Use_decl_annotations_
BOOLEAN
MyHwMSIRoutine (
  _In_ PVOID  DeviceExtension,
  _In_ ULONG  MessageId
  );
  {
      ...
  }

Jenis fungsi HW_MESSAGE_SIGNALED_INTERRUPT_ROUTINE ditentukan dalam file header Storport.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 HW_MESSAGE_SIGNALED_INTERRUPT_ROUTINE dalam file header digunakan. Untuk informasi selengkapnya tentang persyaratan untuk deklarasi fungsi, lihat Mendeklarasikan Fungsi Menggunakan Jenis Peran Fungsi untuk Driver Storport. Untuk informasi tentang Use_decl_annotations, lihat Perilaku Fungsi Anotasi.

Persyaratan

Persyaratan Nilai
Target Platform Universal
Header storport.h (termasuk Storport.h)
IRQL DIRQL

Lihat juga

PORT_CONFIGURATION_INFORMATION

StorPortAcquireMSISpinLock

StorPortGetMSIInfo

StorPortReleaseMSISpinLock