mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-15 15:06:42 +00:00
Assert that page allocations during an interrupt specify
VM_ALLOC_INTERRUPT. Assert that pages removed from the cache queue are not busy.
This commit is contained in:
parent
90c4b74cbe
commit
0869d38ba6
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=139495
@ -706,9 +706,10 @@ vm_page_select_cache(int color)
|
||||
|
||||
mtx_assert(&vm_page_queue_mtx, MA_OWNED);
|
||||
while ((m = vm_pageq_find(PQ_CACHE, color, FALSE)) != NULL) {
|
||||
if ((m->flags & PG_BUSY) == 0 && m->busy == 0 &&
|
||||
m->hold_count == 0 && (VM_OBJECT_TRYLOCK(m->object) ||
|
||||
if (m->hold_count == 0 && (VM_OBJECT_TRYLOCK(m->object) ||
|
||||
VM_OBJECT_LOCKED(m->object))) {
|
||||
KASSERT((m->flags & PG_BUSY) == 0 && m->busy == 0,
|
||||
("Found busy cache page %p", m));
|
||||
KASSERT(m->dirty == 0,
|
||||
("Found dirty cache page %p", m));
|
||||
KASSERT(!pmap_page_is_mapped(m),
|
||||
@ -750,6 +751,9 @@ vm_page_alloc(vm_object_t object, vm_pindex_t pindex, int req)
|
||||
int color, flags, page_req;
|
||||
|
||||
page_req = req & VM_ALLOC_CLASS_MASK;
|
||||
KASSERT(curthread->td_intr_nesting_level == 0 ||
|
||||
page_req == VM_ALLOC_INTERRUPT,
|
||||
("vm_page_alloc(NORMAL|SYSTEM) in interrupt context"));
|
||||
|
||||
if ((req & VM_ALLOC_NOOBJ) == 0) {
|
||||
KASSERT(object != NULL,
|
||||
|
Loading…
Reference in New Issue
Block a user