EVT_SPB_TARGET_DISCONNECT fungsi panggilan balik (spbcx.h)

Fungsi panggilan balik peristiwa EvtSpbTargetDisconnect driver pengontrol SPB menutup koneksi ke perangkat target yang sebelumnya dibuka oleh panggilan ke fungsi panggilan balik peristiwa EvtSpbTargetConnect driver.

Sintaks

EVT_SPB_TARGET_DISCONNECT EvtSpbTargetDisconnect;

void EvtSpbTargetDisconnect(
  [in] WDFDEVICE Controller,
  [in] SPBTARGET Target
)
{...}

Parameter

[in] Controller

Handel WDFDEVICE ke objek perangkat kerangka kerja yang mewakili pengontrol SPB.

[in] Target

Handel SPBTARGET ke target untuk ditutup. Targetnya adalah perangkat periferal atau port yang terpasang pada bus. Ekstensi kerangka kerja SPB (SpbCx) sebelumnya menetapkan handel ini ke target dalam panggilan balik EvtSpbTargetConnect yang membuka koneksi ke target.

Nilai kembali

Tidak ada

Keterangan

Implementasi fungsi ini oleh driver pengontrol SPB bersifat opsional.

SpbCx mengelola antrean I/O untuk pengontrol SPB. Jika driver pengontrol SPB mendaftarkan fungsi panggilan balik EvtSpbTargetDisconnect , SpbCx memanggil fungsi ini ketika klien (driver periferal) driver pengontrol mengirim permintaan IRP_MJ_CLOSE untuk menutup handel SPBTARGET. Handel ini mewakili koneksi ke perangkat target di bus yang dibuka klien dalam permintaan IRP_MJ_CREATE sebelumnya. Jika fungsi EvtSpbTargetDisconnect mengembalikan kode kesalahan, SpbCx gagal dalam permintaan IRP_MJ_CLOSE .

Fungsi EvtSpbTargetDisconnect dipanggil secara sinkron dari konteks utas penutup klien setelah semua operasi I/O yang dimulai klien berakhir dan setelah klien membuka kunci pengontrol (jika klien sebelumnya mengunci pengontrol).

Jika driver pengontrol SPB telah mengalokasikan permintaan I/O dan mengirimkannya ke driver yang lebih rendah berikutnya dalam rantai permintaan I/O untuk perangkat target, fungsi EvtSpbTargetDisconnect harus membatalkan permintaan ini sebelum kembali.

Rutinitas panggilan balik DispatchCleanup dan CreateProcessNotifyEx driver klien dapat dipanggil kapan saja setelah panggilan balik EvtSpbTargetDisconnect kembali. Ketika proses driver klien keluar, rutinitas CreateProcessNotifyEx dipanggil tepat sebelum utas terakhir untuk keluar dari proses dihancurkan.

Untuk mendaftarkan fungsi panggilan balik EvtSpbTargetDisconnect , panggil metode SpbDeviceInitialize .

Contoh

Untuk menentukan fungsi panggilan balik EvtSpbTargetDisconnect , 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 EvtSpbTargetDisconnect yang diberi nama MyEvtSpbTargetDisconnect, gunakan jenis fungsi EVT_SPB_TARGET_DISCONNECT, seperti yang ditunjukkan dalam contoh kode ini:

EVT_SPB_TARGET_DISCONNECT  MyEvtSpbTargetDisconnect;

Kemudian, terapkan fungsi panggilan balik Anda sebagai berikut:

_Use_decl_annotations_
VOID
  MyEvtSpbTargetDisconnect(
    WDFDEVICE Controller,
    SPBTARGET Target
    )
{ ... }

Jenis fungsi EVT_SPB_TARGET_DISCONNECT ditentukan dalam file header Spbcx.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_SPB_TARGET_DISCONNECT 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 spbcx.h
IRQL Dipanggil pada PASSIVE_LEVEL.

Lihat juga

EvtSpbTargetConnect

IRP_MJ_CLOSE

IRP_MJ_CREATE

SPBTARGET

SpbDeviceInitialize