Bagikan melalui


GPIO_CLIENT_RESTORE_BANK_HARDWARE_CONTEXT fungsi panggilan balik (gpioclx.h)

Fungsi panggilan balik peristiwa CLIENT_RestoreBankHardwareContext memulihkan konteks perangkat keras dari bank pin I/O tujuan umum (GPIO).

Sintaks

GPIO_CLIENT_RESTORE_BANK_HARDWARE_CONTEXT GpioClientRestoreBankHardwareContext;

void GpioClientRestoreBankHardwareContext(
  [in] PVOID Context,
  [in] PGPIO_SAVE_RESTORE_BANK_HARDWARE_CONTEXT_PARAMETERS Parameters
)
{...}

Parameter

[in] Context

Penunjuk ke konteks perangkat driver pengontrol GPIO.

[in] Parameters

Penunjuk ke struktur GPIO_SAVE_RESTORE_BANK_HARDWARE_CONTEXT_PARAMETERS yang menjelaskan pin bank GPIO untuk dipulihkan.

Nilai kembali

Tidak ada

Keterangan

Fungsi CLIENT_RestoreBankHardwareContext mengembalikan STATUS_SUCCESS jika panggilan berhasil. Jika tidak, kode status kesalahan akan ditampilkan.

Jika bank pin GPIO mendukung manajemen daya tingkat komponen, GpioClx dapat mengalihkan bank ke status Fx berdaya rendah jika bank menganggur. Jika bank pengontrol GPIO kehilangan konteks perangkat kerasnya dalam status Fx, driver pengontrol GPIO harus menyimpan konteks ini sebelum transisi F0-ke-Fx, dan, kemudian, memulihkan konteks setelah transisi Fx-ke-F0. Saat ini, F1 adalah satu-satunya status berdaya rendah yang didefinisikan untuk pengontrol GPIO yang menggunakan GpioClx.

GpioClx memanggil fungsi CLIENT_RestoreBankHardwareContext untuk memulihkan konteks perangkat keras bank yang sebelumnya disimpan. Konteks perangkat keras sebelumnya disimpan oleh fungsi panggilan balik peristiwa CLIENT_SaveBankHardwareContext .

Beberapa perangkat pengontrol GPIO memungkinkan bank pin yang dipilih untuk dihidupkan dan dimatikan secara independen dari bank lain dalam perangkat yang sama. Dengan demikian, daya dapat dihemat dengan mematikan bank yang menganggur.

Untuk mendaftarkan fungsi panggilan balik CLIENT_RestoreBankHardwareContext 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_RestoreBankHardwareContext .

GpioClx memanggil fungsi panggilan balik CLIENT_RestoreBankHardwareContext 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 di anggota Bendera struktur ini, GpioClx memanggil fungsi CLIENT_RestoreBankHardwareContext 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_RestoreBankHardwareContext , 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_RestoreBankHardwareContext yang diberi nama MyEvtGpioRestoreBankHardwareContext, gunakan jenis fungsi GPIO_CLIENT_RESTORE_BANK_HARDWARE_CONTEXT, seperti yang ditunjukkan dalam contoh kode ini:

GPIO_CLIENT_RESTORE_BANK_HARDWARE_CONTEXT MyEvtGpioRestoreBankHardwareContext;</pre>

Kemudian, terapkan fungsi panggilan balik Anda sebagai berikut:

_Use_decl_annotations_
NTSTATUS
  MyEvtGpioRestoreBankHardwareContext(
    PVOID Context,
    PGPIO_SAVE_RESTORE_BANK_HARDWARE_CONTEXT_PARAMETERS Parameters
    )
{ ... }

Jenis fungsi GPIO_CLIENT_RESTORE_BANK_HARDWARE_CONTEXT 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_RESTORE_BANK_HARDWARE_CONTEXT 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

CLIENT_SaveBankHardwareContext

GPIO_CLIENT_REGISTRATION_PACKET

GPIO_CLX_RegisterClient

GPIO_SAVE_RESTORE_BANK_HARDWARE_CONTEXT_PARAMETERS