GPIO_CLIENT_ENABLE_INTERRUPT fungsi panggilan balik (gpioclx.h)
Fungsi panggilan balik peristiwa CLIENT_EnableInterrupt memungkinkan gangguan pada pin I/O (GPIO) tujuan umum yang dikonfigurasi sebagai input interupsi.
Sintaks
GPIO_CLIENT_ENABLE_INTERRUPT GpioClientEnableInterrupt;
NTSTATUS GpioClientEnableInterrupt(
[in] PVOID Context,
[in] PGPIO_ENABLE_INTERRUPT_PARAMETERS EnableParameters
)
{...}
Parameter
[in] Context
Penunjuk ke konteks perangkat driver pengontrol GPIO.
[in] EnableParameters
Penunjuk ke struktur GPIO_ENABLE_INTERRUPT_PARAMETERS yang menentukan pin GPIO dan menjelaskan atribut interupsi pin ini.
Nilai kembali
Fungsi CLIENT_EnableInterrupt mengembalikan STATUS_SUCCESS jika panggilan berhasil. Jika tidak, kode kesalahan akan menampilkan kode kesalahan yang sesuai.
Keterangan
Fungsi panggilan balik ini diimplementasikan oleh driver pengontrol GPIO. Ekstensi kerangka kerja GPIO (GpioClx) memanggil fungsi ini untuk mengaktifkan gangguan pada pin GPIO yang dikonfigurasi sebagai input permintaan interupsi.
Untuk mendaftarkan fungsi panggilan balik CLIENT_EnableInterrupt driver Anda, panggil metode GPIO_CLX_RegisterClient . Metode ini menerima, sebagai parameter input, penunjuk ke struktur GPIO_CLIENT_REGISTRATION_PACKET yang berisi penunjuk fungsi CLIENT_EnableInterrupt .
GpioClx selalu memanggil fungsi panggilan balik CLIENT_EnableInterrupt dan CLIENT_DisableInterrupt di IRQL = PASSIVE_LEVEL. Namun, jika register GPIO dipetakan memori, GpioClx memanggil fungsi panggilan balik terkait interupsi lainnya dari ISR-nya di DIRQL. Dalam hal ini, fungsi CLIENT_EnableInterrupt dan CLIENT_DisableInterrupt harus menggunakan kunci interupsi GPIO untuk menyinkronkan operasi terkait interupsi mereka ke ISR. Untuk informasi selengkapnya, lihat Mengganggu Sinkronisasi untuk Driver Pengontrol GPIO.
Contoh
Untuk menentukan fungsi panggilan balik CLIENT_EnableInterrupt , 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 fungsi panggilan balik CLIENT_EnableInterrupt yang diberi nama MyEvtGpioEnableInterrupt
, gunakan jenis fungsi GPIO_CLIENT_ENABLE_INTERRUPT, seperti yang ditunjukkan dalam contoh kode ini:
GPIO_CLIENT_ENABLE_INTERRUPT MyEvtGpioEnableInterrupt;
Kemudian, terapkan fungsi panggilan balik Anda sebagai berikut:
_Use_decl_annotations_
NTSTATUS
MyEvtGpioEnableInterrupt(
PVOID Context,
PGPIO_ENABLE_INTERRUPT_PARAMETERS InterruptParameters
)
{ ... }
Jenis fungsi GPIO_CLIENT_ENABLE_INTERRUPT ditentukan dalam file header Gpioclx.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 GPIO_CLIENT_ENABLE_INTERRUPT dalam file header digunakan. Untuk informasi selengkapnya tentang persyaratan untuk deklarasi fungsi, lihat Mendeklarasikan Fungsi dengan Menggunakan Jenis Peran Fungsi untuk Driver KMDF. Untuk informasi selengkapnya tentang Use_decl_annotations, lihat Perilaku Fungsi Anotasi.
Persyaratan
Persyaratan | Nilai |
---|---|
Klien minimum yang didukung | Didukung dimulai dengan Windows 8. |
Target Platform | Desktop |
Header | gpioclx.h |
IRQL | Dipanggil pada PASSIVE_LEVEL. |