MINIPORT_ALLOCATE_SHARED_MEM_COMPLETE fungsi panggilan balik (ndis.h)
NDIS memanggil fungsi MiniportSharedMemoryAllocateComplete driver miniport untuk menyelesaikan permintaan alokasi memori bersama yang dimulai driver miniport dengan memanggil Fungsi NdisMAllocateSharedMemoryAsyncEx .
Sintaks
MINIPORT_ALLOCATE_SHARED_MEM_COMPLETE MiniportAllocateSharedMemComplete;
void MiniportAllocateSharedMemComplete(
[in] NDIS_HANDLE MiniportAdapterContext,
[in] PVOID VirtualAddress,
[in] PNDIS_PHYSICAL_ADDRESS PhysicalAddress,
[in] ULONG Length,
[in] PVOID Context
)
{...}
Parameter
[in] MiniportAdapterContext
Handel ke area konteks yang dialokasikan oleh driver miniport tempat driver mempertahankan informasi status untuk NIC. Driver mengalokasikan area konteks ini di Fungsi MiniportInitializeEx .
[in] VirtualAddress
Alamat virtual dasar memori bersama yang dialokasikan driver miniport dengan memanggil NdisMAllocateSharedMemoryAsyncEx. VirtualAddress ADALAH NULL jika upaya alokasi gagal.
[in] PhysicalAddress
Alamat fisik dasar untuk digunakan NIC yang dipetakan ke alamat yang ditentukan parameter VirtualAddress .
[in] Length
Jumlah byte yang dialokasikan oleh NdisMAllocateSharedMemoryAsyncEx .
[in] Context
Pointer ke area konteks yang ditentukan driver miniport dalam panggilan sebelumnya ke NdisMAllocateSharedMemoryAsyncEx.
Mengembalikan nilai
Tidak ada
Keterangan
MiniportAllocateSharedMemoryComplete adalah fungsi opsional untuk driver miniport. Driver miniport mendaftarkan fungsi MiniportAllocateSharedMemoryComplete dalam struktur NDIS_SG_DMA_DESCRIPTION yang diteruskan driver ke Fungsi NdisMRegisterScatterGatherDma .
Panggilan driver miniport NdisMAllocateSharedMemoryAsyncEx untuk mengalokasikan memori bersama. Jika NdisMAllocateSharedMemoryAsyncEx mengembalikan NDIS_STATUS_PENDING, NDIS memanggil MiniportAllocateSharedMemoryComplete untuk meneruskan memori ke driver miniport.
NDIS memanggil MiniportSharedMemoryAllocateComplete di IRQL PASSIVE_LEVEL.
Contoh
Untuk menentukan fungsi MiniportSharedMemoryAllocateComplete , 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 MiniportSharedMemoryAllocateComplete yang diberi nama "MySharedMemoryAllocateComplete", gunakan jenis MINIPORT_ALLOCATE_SHARED_MEM_COMPLETE seperti yang ditunjukkan dalam contoh kode ini:
MINIPORT_ALLOCATE_SHARED_MEM_COMPLETE MySharedMemoryAllocateComplete;
Kemudian, terapkan fungsi Anda sebagai berikut:
_Use_decl_annotations_
VOID
MySharedMemoryAllocateComplete(
NDIS_HANDLE MiniportAdapterContext,
PVOID VirtualAddress,
PNDIS_PHYSICAL_ADDRESS PhysicalAddress,
ULONG Length,
PVOID Context
)
{...}
Jenis fungsi MINIPORT_ALLOCATE_SHARED_MEM_COMPLETE ditentukan 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_ALLOCATE_SHARED_MEM_COMPLETE 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 | PASSIVE_LEVEL |