MINIPORT_PROCESS_SG_LIST fungsi panggilan balik (ndis.h)
Driver miniport master bus menyediakan fungsi MiniportProcessSGList untuk memproses daftar sebar/kumpulkan untuk data jaringan.
Sintaks
MINIPORT_PROCESS_SG_LIST MiniportProcessSgList;
void MiniportProcessSgList(
[in] PDEVICE_OBJECT pDO,
[in] PVOID Reserved,
[in] PSCATTER_GATHER_LIST pSGL,
[in] PVOID Context
)
{...}
Parameter
[in] pDO
Driver Miniport harus mengabaikan parameter ini.
[in] Reserved
Driver Miniport harus mengabaikan parameter ini.
[in] pSGL
Penunjuk ke buffer daftar sebar/kumpulkan. Ini belum tentu buffer yang sama dengan yang ditentukan driver dalam panggilan ke Fungsi NdisMAllocateNetBufferSGList
[in] Context
Pointer ke area konteks yang dibuat driver miniport sebelum memanggil NdisMAllocateNetBufferSGList.
Nilai kembali
Tidak ada
Keterangan
Driver miniport memanggil Fungsi NdisMRegisterScatterGatherDma untuk mendaftarkan fungsi MiniportProcessSGList . Saat driver miniport memanggil NdisMAllocateNetBufferSGList untuk membuat daftar sebar/kumpulkan, NDIS memanggil HAL untuk membuat daftar.
NDIS memanggil fungsi MiniportProcessSGList driver miniport jika NdisMAllocateNetBufferSGList berhasil. Namun, pengembalian keberhasilan dari fungsi tersebut tidak menjamin panggilan balik sudah dipanggil; dapat dipanggil secara asinkron.
Ketika NDIS memanggil MiniportProcessSGList, driver dapat mengirim struktur NET_BUFFER ke perangkat keras. MiniportProcessSGList mengirimkan alamat fisik daftar sebar/kumpulkan ke DMA NIC dan mengeluarkan perintah kirim ke NIC.
HAL dapat memanggil MiniportProcessSGList sebelum atau sesudah NDIS kembali dari NdisMAllocateNetBufferSGList. Oleh karena itu, penulis driver tidak boleh berasumsi bahwa panggilan dilakukan dalam konteks NdisMAllocateNetBufferSGList.
NDIS memanggil MiniportProcessSGList di IRQL = DISPATCH_LEVEL.
Contoh
Untuk menentukan fungsi MiniportProcessSGList , Anda harus terlebih dahulu memberikan deklarasi fungsi yang mengidentifikasi jenis fungsi yang Anda tentukan. Windows menyediakan sekumpulan tipe fungsi untuk pengandar. Mendeklarasikan fungsi menggunakan jenis fungsi 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 MiniportProcessSGList yang diberi nama "MyProcessSGList", gunakan jenis MINIPORT_PROCESS_SG_LIST seperti yang ditunjukkan dalam contoh kode ini:
MINIPORT_PROCESS_SG_LIST MyProcessSGList;
Kemudian, terapkan fungsi Anda sebagai berikut:
_Use_decl_annotations_
VOID
MyProcessSGList(
PDEVICE_OBJECT pDO,
PVOID Reserved,
PSCATTER_GATHER_LIST pSGL,
PVOID Context
)
{...}
Jenis fungsi MINIPORT_PROCESS_SG_LIST didefinisikan dalam file header Ndis.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 MINIPORT_PROCESS_SG_LIST dalam file header digunakan. Untuk informasi selengkapnya tentang persyaratan untuk deklarasi fungsi, lihat Mendeklarasikan Fungsi dengan Menggunakan Jenis Peran Fungsi untuk Driver NDIS.
Untuk informasi tentang Use_decl_annotations, lihat Perilaku Fungsi Anotasi.
Persyaratan
Persyaratan | Nilai |
---|---|
Klien minimum yang didukung | Didukung di NDIS 6.0 dan yang lebih baru. |
Target Platform | Windows |
Header | ndis.h (termasuk Ndis.h) |
IRQL | DISPATCH_LEVEL |
Lihat juga
NdismRegisterScatterGatherDmaSaran 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