AVCSTRM_ABORT_STREAMING

Kode fungsi AVCSTRM_ABORT_STREAMING membatalkan semua permintaan data yang tertunda dan membebaskan sumber daya yang digunakan.

Blok Status I/O

Jika berhasil, avcstrm.sys mengatur Irp-IoStatus.Status> ke STATUS_SUCCESS.

Kemungkinan nilai pengembalian kesalahan meliputi:

Status Kesalahan Deskripsi
STATUS_DEVICE_REMOVED Perangkat yang sesuai dengan operasi AVCSTRM_READ tidak ada lagi.
STATUS_CANCELLED Permintaan tidak dapat diselesaikan.
STATUS_INVALID_PARAMETER Parameter yang ditentukan dalam IRP salah,
STATUS_INSUFFICIENT_RESOURCES Tidak ada sumber daya sistem yang memadai untuk menyelesaikan permintaan.
STATUS_PENDING Permintaan telah diterima tetapi memerlukan pemrosesan lebih lanjut. Rutinitas penyelesaian I/O akan menangani respons akhir.

AVC_STREAM_REQUEST_BLOCK Input

SizeOfThisBlock, Versi dan Fungsi
Gunakan makro INIT_AVCSTRM_HEADER untuk menginisialisasi anggota ini. Teruskan AVCSTRM_ABORT_STREAMING dalam argumen Permintaan makro.

AVCStreamContext
Menentukan konteks aliran (handel) yang dikembalikan oleh panggilan AVCSTRM_OPEN sebelumnya yang merupakan target untuk operasi penulisan data.

Driver subunit harus terlebih dahulu mengalokasikan IRP dan struktur AVC_STREAM_REQUEST_BLOCK .

Selanjutnya, ini harus menggunakan makro INIT_AVCSTRM_HEADER untuk menginisialisasi struktur AVC_STREAM_REQUEST_BLOCK, meneruskan AVCSTRM_READ sebagai argumen Permintaan ke makro.

Selanjutnya, driver subunit mengatur anggota AVCStreamContext ke konteks aliran (handel) aliran untuk membatalkan streaming.

Untuk mengirim permintaan ini, subunit mengirimkan IRP IRP_MJ_INTERNAL_DEVICE_CONTROL dengan anggota IoControlCode dari IRP yang diatur ke IOCTL_AVCSTRM_CLASS dan anggota Argumen1 dari IRP yang diatur ke struktur AVC_STREAM_REQUEST_BLOCK yang menjelaskan operasi streaming pembatalan berlangsung.

Kode fungsi ini harus dipanggil pada PASSIVE_LEVEL. Saat IRP data dibatalkan, IRP dapat dijalankan pada DISPATCH_LEVEL. Dalam hal ini, subunit harus memulai item kerja dan memanggil fungsi ini dalam rutinitas item kerjanya, yang dijalankan di PASSIVE_LEVEL.

Komentar

Perhatikan, fungsionalitas ini membatalkan semua runtime integrasi streaming. Untuk membatalkan IRP individual, gunakan IoCancelIrp.

Subunit harus memanggil ini saat perangkat targetnya dihapus atau IRP data asli dibatalkan untuk menghentikan operasi streaming.

Fungsi ini tidak menggunakan anggota apa pun dari serikat CommandData dalam struktur AVC_STREAM_REQUEST_BLOCK.

typedef struct _AVC_STREAM_REQUEST_BLOCK {
  ULONG  SizeOfThisBlock;
  ULONG  Version;
  AVCSTRM_FUNCTION  Function;
  .
  .
  PVOID AVCStreamContext;
  .
  .
} AVC_STREAM_REQUEST_BLOCK, *PAVC_STREAM_REQUEST_BLOCK;

Persyaratan

Header: Dinyatakan dalam avcstrm.h. Sertakan avcstrm.h.

Lihat juga

INIT_AVCSTRM_HEADER

IRP_MJ_INTERNAL_DEVICE_CONTROL

IOCTL_AVCSTRM_CLASS

AVCSTRM_FUNCTION