Fungsi ExAllocatePool2 (wdm.h)
Rutinitas ExAllocatePool2 mengalokasikan memori kumpulan dari jenis yang ditentukan dan mengembalikan penunjuk ke blok yang dialokasikan.
Sintaks
DECLSPEC_RESTRICT PVOID ExAllocatePool2(
POOL_FLAGS Flags,
SIZE_T NumberOfBytes,
ULONG Tag
);
Parameter
Flags
Nilai jenis ULONG64 yang menentukan jenis memori kumpulan bersama dengan atribut yang diperlukan dan opsional. Beberapa nilai bendera dapat digabungkan menggunakan bit-wise OR. Lihat POOL_FLAGS untuk nilai yang mungkin.
NumberOfBytes
Menentukan jumlah byte bukan nol untuk dialokasikan.
Tag
Tag kumpulan yang digunakan untuk memori yang dialokasikan. Tentukan tag kumpulan sebagai literal karakter bukan nol dari satu hingga empat karakter yang dibatasi oleh tanda kutip tunggal (misalnya, Tag1
). String biasanya ditentukan dalam urutan terbalik (misalnya, 1gaT
). Setiap karakter ASCII dalam tag harus berupa nilai dalam rentang 0x20 (spasi) hingga 0x7E (tilde). Setiap jalur kode alokasi harus menggunakan tag kumpulan unik untuk membantu debugger dan verifier mengidentifikasi jalur kode.
Mengembalikan nilai
ExAllocatePool2 mengembalikan pointer ke memori yang dialokasikan.
Kondisi berikut menyebabkan fungsi mengembalikan NULL secara default. Jika POOL_FLAG_RAISE_ON_FAILURE ditentukan, fungsi akan menimbulkan pengecualian.
- Memori tidak mencukuum
- Tag diatur ke 0 atau POOL_FLAGS tidak valid ditentukan
Keterangan
Jika Anda membangun driver yang menargetkan versi Windows sebelum Windows 10, versi 2004, gunakan ExAllocatePoolZero, ExAllocatePoolUninitialized, ExAllocatePoolQuotaZero, atau ExAllocatePoolQuotaUninitialized.
Rutinitas ini memiliki perbedaan berikut dari rutinitas alokasi sebelumnya (ExAllocatePoolWithTag, ExAllocatePoolWithQuotaTag, ExAllocatePoolWithTagPriority):
Memori tidak diinisialisasi kecuali POOL_FLAG_UNINITIALIZED ditentukan.
Mengembalikan perilaku jika terjadi alokasi yang gagal. ExAllocatePoolWithQuotaTag menimbulkan pengecualian secara default.
Tag dengan nilai 0 tidak valid.
Saat mengganti ExAllocatePoolWithQuotaTag dengan ExAllocatePool2, Anda harus menentukan bendera POOL_FLAG_USE_QUOTA . Untuk informasi selengkapnya tentang bendera kumpulan, lihat POOL_FLAGS.
Jika NumberOfBytes atau PAGE_SIZE
lebih besar, buffer sejajar halaman dialokasikan. Alokasi PAGE_SIZE
memori atau kurang dialokasikan dalam halaman dan tidak melewati batas halaman. Alokasi memori kurang dari PAGE_SIZE
yang belum tentu selaras dengan halaman tetapi selaras dengan batas 8-byte dalam sistem 32-bit dan ke batas 16-byte dalam sistem 64-bit.
Driver hanya dapat menggunakan hingga NumberOfBytes yang telah dialokasikan secara eksplisit. Mengakses memori di luar rentang ini dapat merusak kumpulan dan menyebabkan sistem lumpuh.
Sistem mengaitkan tag kumpulan dengan memori yang dialokasikan. Alat pemrograman, seperti WinDbg, dapat menampilkan tag kumpulan yang terkait dengan setiap buffer yang dialokasikan. Gflags, alat yang disertakan dalam Alat Debugging untuk Windows, mengaktifkan fitur sistem yang meminta alokasi dari kumpulan khusus untuk tag kumpulan tertentu. Poolmon, yang disertakan dalam WDK, melacak memori menurut tag kumpulan.
Nilai Tag disimpan, dan terkadang ditampilkan, dalam urutan terbalik (little-endian). Misalnya, jika penelepon lolos Fred
sebagai Tag, pemanggil muncul seperti derF
di cadangan kumpulan dan di pelacakan penggunaan kumpulan di debugger, dan seperti 0x64657246
dalam registri dan di alat ditampilkan.
Buffer yang dialokasikan dapat dikosongkan dengan ExFreePool atau ExFreePoolWithTag.
Penelepon ExAllocatePool2 harus berjalan di IRQL <= DISPATCH_LEVEL. Penelepon yang dijalankan di DISPATCH_LEVEL harus menentukan POOL_FLAG_NON_PAGED atau POOL_FLAG_NON_PAGED_EXECUTABLE untuk Bendera. Penelepon yang mengeksekusi di IRQL <= APC_LEVEL dapat menentukan POOL_FLAG_PAGED, tetapi jika memori akan diakses dari kode yang berjalan pada DISPATCH_LEVEL, Anda masih harus mengalokasikan memori non-halaman.
Dalam arsitektur multiprosesor akses memori non-seragam (NUMA), ExAllocatePool2 mencoba mengalokasikan memori yang bersifat lokal untuk prosesor yang memanggil ExAllocatePool2. Jika tidak ada memori lokal yang tersedia, ExAllocatePool2 mengalokasikan memori terdekat yang tersedia.
Memori yang dialokasikan ExAllocatePool2 adalah nol yang diinisialisasi. Driver mode kernel tidak boleh menolak nol untuk alokasi yang akan disalin ke lokasi yang tidak tepercaya (mode pengguna, melalui jaringan, dll.) untuk menghindari pengungkapan informasi sensitif.
Persyaratan
Persyaratan | Nilai |
---|---|
Klien minimum yang didukung | Windows 10, version 2004 |
Target Platform | Universal |
Header | wdm.h (termasuk Wdm.h, Ntddk.h, Ntifs.h) |
Pustaka | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | IRQL <= DISPATCH_LEVEL (lihat bagian Keterangan) |
Aturan kepatuhan DDI | HwStorPortProhibitedDDIs, SpNoWait, StorPortStartIo |
Lihat juga
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