GPIO_CLIENT_RELEASE_CONTROLLER fungsi panggilan balik (gpioclx.h)
Fungsi panggilan balik peristiwa CLIENT_ReleaseController melakukan operasi yang diperlukan ketika perangkat pengontrol I/O (GPIO) tujuan umum tidak lagi dapat diakses.
Sintaks
GPIO_CLIENT_RELEASE_CONTROLLER GpioClientReleaseController;
NTSTATUS GpioClientReleaseController(
[in] WDFDEVICE Device,
[in] PVOID Context
)
{...}
Parameter
[in] Device
Handel WDFDEVICE ke objek perangkat kerangka kerja yang mewakili pengontrol GPIO.
[in] Context
Penunjuk ke konteks perangkat driver pengontrol GPIO.
Nilai kembali
Fungsi CLIENT_ReleaseController mengembalikan STATUS_SUCCESS jika panggilan berhasil. Jika tidak, ia mengembalikan kode kesalahan yang sesuai.
Keterangan
Fungsi panggilan balik ini diimplementasikan oleh driver pengontrol GPIO. Ekstensi kerangka kerja GPIO (GpioClx) memanggil fungsi ini setelah perangkat pengontrol GPIO tidak lagi dapat diakses.
Selama panggilan balik CLIENT_ReleaseController , driver pengontrol GPIO harus merilis sumber daya perangkat keras apa pun yang diperolehnya sebagai akibat dari panggilan sebelumnya ke fungsi panggilan balik CLIENT_PrepareController . Dalam kasus perangkat pengontrol GPIO yang dipetakan memori, driver harus membatalkan pemetaan rentang alamat memori atau rentang yang ditetapkan ke register perangkat keras. Untuk pengontrol yang tidak dipetakan memori, driver harus menutup koneksi logis yang dibuka sebelumnya ke pengontrol.
Untuk mendaftarkan fungsi panggilan balik CLIENT_ReleaseController 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_ReleaseController .
Meskipun fungsi panggilan balik CLIENT_ReleaseController dipanggil di IRQL = PASSIVE_LEVEL, Anda tidak boleh membuat fungsi ini dapat dipaginasi. Panggilan balik CLIENT_ReleaseController berada di jalur waktu penting untuk memulihkan daya ke perangkat di platform perangkat keras dan, karena alasan performa, itu tidak boleh ditunda oleh kesalahan halaman.
Contoh
Untuk menentukan fungsi panggilan balik CLIENT_ReleaseController , 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_ReleaseController yang diberi nama MyEvtGpioReleaseController
, gunakan jenis fungsi GPIO_CLIENT_RELEASE_CONTROLLER, seperti yang ditunjukkan dalam contoh kode ini:
GPIO_CLIENT_RELEASE_CONTROLLER MyEvtGpioReleaseController;
Kemudian, terapkan fungsi panggilan balik Anda sebagai berikut:
_Use_decl_annotations_
NTSTATUS
MyEvtGpioReleaseController(
WDFDEVICE Device,
PVOID Context
)
{ ... }
Jenis fungsi GPIO_CLIENT_RELEASE_CONTROLLER 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_RELEASE_CONTROLLER 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 di PASSIVE_LEVEL. |