GPIO_CLIENT_QUERY_ACTIVE_INTERRUPTS fungsi panggilan balik (gpioclx.h)
Fungsi panggilan balik peristiwa CLIENT_QueryActiveInterrupts meminta status sekumpulan pin I/O (GPIO) tujuan umum yang dikonfigurasi sebagai input interupsi.
Sintaks
GPIO_CLIENT_QUERY_ACTIVE_INTERRUPTS GpioClientQueryActiveInterrupts;
NTSTATUS GpioClientQueryActiveInterrupts(
[in] PVOID Context,
[in, out] PGPIO_QUERY_ACTIVE_INTERRUPTS_PARAMETERS QueryActiveParameters
)
{...}
Parameter
[in] Context
Penunjuk ke konteks perangkat driver pengontrol GPIO.
[in, out] QueryActiveParameters
Penunjuk ke struktur GPIO_QUERY_ACTIVE_INTERRUPTS_PARAMETERS yang, pada entri, menjelaskan pin interupsi GPIO untuk kueri, dan, saat keluar, berisi status interupsi aktif dan diaktifkan dari pin ini.
Nilai kembali
Fungsi CLIENT_QueryActiveInterrupts 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 mengkueri sekumpulan pin GPIO yang dikonfigurasi sebagai input permintaan interupsi.
Parameter QueryActiveParameters menunjuk ke struktur GPIO_QUERY_ACTIVE_INTERRUPTS_PARAMETERS yang dialokasikan pemanggil. Pemanggil menetapkan nilai anggota BankId dan EnabledMask dari struktur ini. Fungsi CLIENT_QueryActiveInterrupts menulis ke anggota ActiveMask struktur.
Pada entri, bit yang diatur dalam anggota EnabledMask harus cocok dengan set interupsi yang saat ini diaktifkan di bank. Saat kembali, bit yang diatur dalam anggota ActiveMask harus sesuai dengan gangguan yang diaktifkan dan aktif. Dengan demikian, jika sedikit di EnabledMask adalah nol, bit yang sesuai di ActiveMask harus nol.
Untuk mendaftarkan fungsi panggilan balik CLIENT_QueryActiveInterrupts 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_QueryActiveInterrupts .
GpioClx memanggil fungsi panggilan balik CLIENT_QueryActiveInterrupts baik di PASSIVE_LEVEL atau DIRQL, tergantung pada informasi perangkat yang disediakan fungsi panggilan balik CLIENT_QueryControllerBasicInformation ke GpioClx. Fungsi CLIENT_QueryControllerBasicInformation menyediakan informasi perangkat dalam bentuk struktur CLIENT_CONTROLLER_BASIC_INFORMATION . Jika bit bendera MemoryMappedController diatur dalam anggota Bendera struktur ini, GpioClx memanggil fungsi CLIENT_QueryActiveInterrupts di DIRQL, yang merupakan IRQL tempat ISR di GpioClx berjalan. Jika tidak, fungsi ini dipanggil pada PASSIVE_LEVEL. Untuk informasi selengkapnya tentang bit bendera ini, lihat Fungsi Panggilan Balik GPIO Opsional dan diperlukan.
Contoh
Untuk menentukan fungsi panggilan balik CLIENT_QueryActiveInterrupts , 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_QueryActiveInterrupts yang diberi nama MyEvtGpioQueryActiveInterrupts
, gunakan jenis fungsi GPIO_CLIENT_QUERY_ACTIVE_INTERRUPTS, seperti yang ditunjukkan dalam contoh kode ini:
GPIO_CLIENT_QUERY_ACTIVE_INTERRUPTS MyEvtGpioQueryActiveInterrupts;
Kemudian, terapkan fungsi panggilan balik Anda sebagai berikut:
_Use_decl_annotations_
NTSTATUS
MyEvtGpioQueryActiveInterrupts(
PVOID Context,
PGPIO_QUERY_ACTIVE_INTERRUPTS_PARAMETERS QueryActiveParameters
)
{ ... }
Jenis fungsi GPIO_CLIENT_QUERY_ACTIVE_INTERRUPTS 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_QUERY_ACTIVE_INTERRUPTS 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 | Lihat Keterangan. |
Lihat juga
CLIENT_CONTROLLER_BASIC_INFORMATION
CLIENT_QueryControllerBasicInformation