Fungsi ExInterlockedInsertHeadList (wdm.h)
Rutinitas ExInterlockedInsertHeadList secara atomik menyisipkan entri di awal daftar struktur LIST_ENTRY yang ditautkan ganda.
Sintaks
PLIST_ENTRY ExInterlockedInsertHeadList(
[in, out] PLIST_ENTRY ListHead,
[in, out] __drv_aliasesMem PLIST_ENTRY ListEntry,
[in, out] PKSPIN_LOCK Lock
);
Parameter
[in, out] ListHead
Penunjuk ke struktur LIST_ENTRY yang berfungsi sebagai header daftar.
[in, out] ListEntry
Penunjuk ke struktur LIST_ENTRY yang mewakili entri yang akan dimasukkan ke dalam daftar.
[in, out] Lock
Penunjuk ke struktur KSPIN_LOCK yang berfungsi sebagai kunci putar yang digunakan untuk menyinkronkan akses ke daftar. Penyimpanan untuk kunci putaran harus residen dan harus diinisialisasi dengan memanggil KeInitializeSpinLock. Anda harus menggunakan kunci putar ini hanya dengan rutinitas DaftarXxxExInterlocked .
Nilai kembali
ExInterlockedInsertHeadList mengembalikan penunjuk ke entri pertama daftar sebelum entri baru dimasukkan. Jika daftar kosong, rutinitas mengembalikan NULL.
Keterangan
ExInterlockedInsertHeadList melakukan operasi yang sama dengan InsertHeadList, tetapi secara atomik. Jangan mencampur panggilan atomik dan non-atomik pada daftar yang sama.
Untuk informasi selengkapnya tentang menggunakan rutinitas ini untuk mengimplementasikan daftar yang ditautkan dua kali lipat, lihat Lists Tertaut Singly dan Doubly.
Rutinitas ExInterlockedInsertHeadList dapat dipanggil di IRQL apa pun. Penyimpanan untuk parameter ListHead dan entri daftar harus residen di semua IRQL.
Persyaratan
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