GPIO_CLIENT_RECONFIGURE_INTERRUPT fungsi panggilan balik (gpioclx.h)
Fungsi panggilan balik peristiwa CLIENT_ReconfigureInterrupt mengonfigurasi ulang pin I/O tujuan umum (GPIO) yang digunakan sebagai input interupsi.
Sintaks
GPIO_CLIENT_RECONFIGURE_INTERRUPT GpioClientReconfigureInterrupt;
NTSTATUS GpioClientReconfigureInterrupt(
[in] PVOID Context,
[in] PGPIO_RECONFIGURE_INTERRUPTS_PARAMETERS ReconfigureParameters
)
{...}
Parameter
[in] Context
Penunjuk ke konteks perangkat driver pengontrol GPIO.
[in] ReconfigureParameters
Penunjuk ke struktur GPIO_RECONFIGURE_INTERRUPTS_PARAMETERS yang menentukan cara mengonfigurasi ulang pin interupsi GPIO.
Nilai kembali
Fungsi CLIENT_ReconfigureInterrupt mengembalikan STATUS_SUCCESS jika panggilan berhasil. Jika tidak, ia mengembalikan kode kesalahan yang sesuai.
Keterangan
Ekstensi kerangka kerja GPIO (GpioClx) mungkin memanggil fungsi CLIENT_ReconfigureInterrupt untuk mengubah mode interupsi atau mengganggu polaritas pin GPIO yang digunakan sebagai input interupsi.
Misalnya, jika perangkat keras pengontrol GPIO tidak secara langsung mendukung interupsi aktif-keduanya, tetapi dapat dikonfigurasi untuk mendukung interupsi mode tingkat aktif-tinggi dan aktif-rendah, GpioClx dapat meniru pin interupsi aktif-keduanya dengan memanggil fungsi CLIENT_ReconfigureInterrupt untuk mengonfigurasi pin GPIO secara bergantian untuk interupsi mode tingkat aktif dan aktif-rendah. Untuk informasi selengkapnya tentang interupsi aktif-keduanya, lihat deskripsi bendera EmulateActiveBoth di CONTROLLER_ATTRIBUTE_FLAGS.
GpioClx memanggil fungsi panggilan balik CLIENT_ReconfigureInterrupt 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_ReconfigureInterrupt 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_ReconfigureInterrupt , Anda harus terlebih dahulu memberikan deklarasi fungsi yang mengidentifikasi jenis fungsi panggilan balik yang Anda tentukan. Windows menyediakan sekumpulan tipe fungsi panggilan balik untuk driver. 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_ReconfigureInterrupt yang diberi nama MyEvtGpioReconfigureInterrupt
, gunakan jenis fungsi GPIO_CLIENT_RECONFIGURE_INTERRUPT, seperti yang ditunjukkan dalam contoh kode ini:
GPIO_CLIENT_RECONFIGURE_INTERRUPT MyEvtGpioReconfigureInterrupt;
Kemudian, terapkan fungsi panggilan balik Anda sebagai berikut:
_Use_decl_annotations_
NTSTATUS
MyEvtGpioReconfigureInterrupt(
PVOID Context,
PGPIO_RECONFIGURE_INTERRUPTS_PARAMETERS ReconfigureParameters
)
{ ... }
Jenis fungsi GPIO_CLIENT_RECONFIGURE_INTERRUPT didefinisikan 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_RECONFIGURE_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 | Lihat Keterangan. |
Lihat juga
CLIENT_CONTROLLER_BASIC_INFORMATION