EVT_SERCX2_CUSTOM_RECEIVE_TRANSACTION_INITIALIZE fungsi panggilan balik (sercx.h)
Fungsi panggilan balik peristiwa EvtSerCx2CustomReceiveTransactionInitialize dipanggil oleh versi 2 dari ekstensi kerangka kerja serial (SerCx2) untuk menyiapkan perangkat keras pengontrol serial untuk melakukan transaksi penerimaan kustom baru.
Sintaks
EVT_SERCX2_CUSTOM_RECEIVE_TRANSACTION_INITIALIZE EvtSercx2CustomReceiveTransactionInitialize;
void EvtSercx2CustomReceiveTransactionInitialize(
[in] SERCX2CUSTOMRECEIVETRANSACTION CustomReceiveTransaction,
[in] PMDL Mdl,
[in] ULONG Offset,
[in] ULONG Length
)
{...}
Parameter
[in] CustomReceiveTransaction
Handel SERCX2CUSTOMRECEIVETRANSACTION ke objek transaksi penerima kustom. Driver pengontrol serial sebelumnya disebut metode SerCx2CustomReceiveTransactionCreate untuk membuat objek ini.
[in] Mdl
Penunjuk ke MDL yang menjelaskan halaman memori yang dibentangkan oleh buffer baca untuk transaksi penerima kustom. Daftar sebar/kumpulkan untuk transfer DMA akan menggunakan wilayah memori ini yang ditentukan oleh parameter Offset dan Panjang .
[in] Offset
Offset awal untuk transfer data. Parameter ini adalah offset byte dari awal wilayah buffer yang dijelaskan oleh MDL. Jika MDL menentukan total N byte ruang buffer, kemungkinan nilai Offset berada dalam rentang 0 hingga N–1.
[in] Length
Ukuran, dalam byte, dari transfer data. Jika MDL menentukan total N byte ruang buffer, kemungkinan nilai Panjang berada dalam rentang 1 hingga N–Offset.
Nilai kembali
Tidak ada
Keterangan
Driver pengontrol serial Anda dapat, sebagai opsi, menerapkan fungsi ini. Jika diimplementasikan, driver mendaftarkan fungsi dalam panggilan SerCx2CustomReceiveTransactionCreate yang membuat objek penerima kustom.
Driver Anda harus menerapkan fungsi EvtSerCx2CustomReceiveTransactionInitialize jika perlu menginisialisasi pengontrol serial dan perangkat keras terkait sebagai persiapan untuk transaksi penerimaan kustom baru. SerCx2 memanggil fungsi ini, jika diimplementasikan, sebelum memulai transaksi penerima kustom. Menanggapi panggilan ini, driver pengontrol serial harus memanggil metode SerCx2CustomReceiveTransactionInitializeComplete untuk memberi tahu SerCx2 setelah inisialisasi selesai.
Untuk informasi selengkapnya, lihat SerCx2 Custom-Receive Transactions.
Contoh
Untuk menentukan fungsi panggilan balik EvtSerCx2CustomReceiveTransactionInitialize , 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 EvtSerCx2CustomReceiveTransactionInitialize yang diberi nama MyCustomReceiveTransactionInitialize
, gunakan jenis fungsi EVT_SERCX2_CUSTOM_RECEIVE_TRANSACTION_INITIALIZE , seperti yang ditunjukkan dalam contoh kode ini:
EVT_SERCX2_CUSTOM_RECEIVE_TRANSACTION_INITIALIZE MyCustomReceiveTransactionInitialize;
Kemudian, terapkan fungsi panggilan balik Anda sebagai berikut:
_Use_decl_annotations_
VOID
MyCustomReceiveTransactionInitialize(
SERCX2CUSTOMRECEIVETRANSACTION CustomReceiveTransaction,
WDFREQUEST Request,
PMDL Mdl,
ULONG Offset,
ULONG Length
)
{...}
Jenis fungsi EVT_SERCX2_CUSTOM_RECEIVE_TRANSACTION_INITIALIZE ditentukan dalam file header Sercx.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 EVT_SERCX2_CUSTOM_RECEIVE_TRANSACTION_INITIALIZE 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 | Tersedia dimulai dengan Windows 8.1. |
Target Platform | Desktop |
Header | sercx.h |
IRQL | Dipanggil di IRQL <= DISPATCH_LEVEL. |
Lihat juga
SERCX2CUSTOMRECEIVETRANSACTION
Saran dan Komentar
https://aka.ms/ContentUserFeedback.
Segera hadir: Sepanjang tahun 2024 kami akan menghentikan penggunaan GitHub Issues sebagai mekanisme umpan balik untuk konten dan menggantinya dengan sistem umpan balik baru. Untuk mengetahui informasi selengkapnya, lihat:Kirim dan lihat umpan balik untuk