GPIO_CLIENT_WRITE_PINS_MASK fungsi panggilan balik (gpioclx.h)
Fungsi panggilan balik peristiwa CLIENT_WriteGpioPinsUsingMask menulis ke sekumpulan pin I/O tujuan umum (GPIO) yang dikonfigurasi sebagai output data.
Sintaks
GPIO_CLIENT_WRITE_PINS_MASK GpioClientWritePinsMask;
NTSTATUS GpioClientWritePinsMask(
[in] PVOID Context,
[in] PGPIO_WRITE_PINS_MASK_PARAMETERS WriteParameters
)
{...}
Parameter
[in] Context
Penunjuk ke konteks perangkat driver pengontrol GPIO.
[in] WriteParameters
Penunjuk ke struktur GPIO_WRITE_PINS_MASK_PARAMETERS yang menjelaskan bank pin GPIO dan yang berisi data untuk menulis ke pin ini.
Nilai kembali
Fungsi CLIENT_WriteGpioPinsUsingMask 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. GpioClx memanggil fungsi ini untuk menulis ke sekumpulan pin GPIO yang ditunjuk.
Pin GPIO yang akan ditulis oleh fungsi ini ditunjuk oleh dua masker 64-bit. Masker pertama menentukan sekelompok pin GPIO yang akan diatur ke 1; sedikit dalam masker ini adalah 1 jika pin GPIO yang sesuai akan diatur ke 1. Masker kedua menentukan sekelompok pin GPIO yang akan diatur ke 0; sedikit dalam masker ini adalah 1 jika pin GPIO yang sesuai akan diatur ke 0.
Untuk mendaftarkan fungsi panggilan balik CLIENT_WriteGpioPinsUsingMask 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_WriteGpioPinsUsingMask .
Fungsi CLIENT_WriteGpioPinsUsingMask dapat dipanggil dari rutinitas layanan interupsi (ISR) di GpioClx. ISR ini berjalan 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, ISR GpioClx berjalan di DIRQL dan memanggil fungsi CLIENT_WriteGpioPinsUsingMask di DIRQL. Jika tidak, ISR berjalan pada PASSIVE_LEVEL dan memanggil fungsi di PASSIVE_LEVEL. Untuk informasi selengkapnya tentang bit bendera ini, lihat Fungsi Panggilan Balik GPIO Opsional dan diperlukan.
Contoh
Untuk menentukan fungsi panggilan balik CLIENT_WriteGpioPinsUsingMask , 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_WriteGpioPinsUsingMask yang diberi nama MyEvtGpioWriteGpioPinsUsingMask
, gunakan jenis fungsi GPIO_CLIENT_WRITE_PINS_MASK, seperti yang ditunjukkan dalam contoh kode ini:
GPIO_CLIENT_WRITE_PINS_MASK MyEvtGpioWritePinsUsingMask;
Kemudian, terapkan fungsi panggilan balik Anda sebagai berikut:
_Use_decl_annotations_
VOID
MyEvtGpioWritePinsUsingMask(
PVOID Context,
PGPIO_WRITE_PINS_MASK_PARAMETERS WriteParameters
)
{ ... }
Jenis fungsi GPIO_CLIENT_WRITE_PINS_MASK 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_WRITE_PINS_MASK 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