Changeset View
Changeset View
Standalone View
Standalone View
sys/vm/device_pager.c
Show First 20 Lines • Show All 229 Lines • ▼ Show 20 Lines | |||||
void | void | ||||
cdev_pager_free_page(vm_object_t object, vm_page_t m) | cdev_pager_free_page(vm_object_t object, vm_page_t m) | ||||
{ | { | ||||
VM_OBJECT_ASSERT_WLOCKED(object); | VM_OBJECT_ASSERT_WLOCKED(object); | ||||
if (object->type == OBJT_MGTDEVICE) { | if (object->type == OBJT_MGTDEVICE) { | ||||
KASSERT((m->oflags & VPO_UNMANAGED) == 0, ("unmanaged %p", m)); | KASSERT((m->oflags & VPO_UNMANAGED) == 0, ("unmanaged %p", m)); | ||||
pmap_remove_all(m); | pmap_remove_all(m); | ||||
vm_page_lock(m); | |||||
(void)vm_page_remove(m); | (void)vm_page_remove(m); | ||||
vm_page_unlock(m); | |||||
} else if (object->type == OBJT_DEVICE) | } else if (object->type == OBJT_DEVICE) | ||||
dev_pager_free_page(object, m); | dev_pager_free_page(object, m); | ||||
} | } | ||||
static void | static void | ||||
dev_pager_free_page(vm_object_t object, vm_page_t m) | dev_pager_free_page(vm_object_t object, vm_page_t m) | ||||
{ | { | ||||
▲ Show 20 Lines • Show All 139 Lines • ▼ Show 20 Lines | old_dev_pager_fault(vm_object_t object, vm_ooffset_t offset, int prot, | ||||
} else { | } else { | ||||
/* | /* | ||||
* Replace the passed in reqpage page with our own fake page and | * Replace the passed in reqpage page with our own fake page and | ||||
* free up the all of the original pages. | * free up the all of the original pages. | ||||
*/ | */ | ||||
page = vm_page_getfake(paddr, memattr); | page = vm_page_getfake(paddr, memattr); | ||||
VM_OBJECT_WLOCK(object); | VM_OBJECT_WLOCK(object); | ||||
vm_page_replace_checked(page, object, (*mres)->pindex, *mres); | vm_page_replace_checked(page, object, (*mres)->pindex, *mres); | ||||
vm_page_lock(*mres); | |||||
vm_page_free(*mres); | vm_page_free(*mres); | ||||
vm_page_unlock(*mres); | |||||
*mres = page; | *mres = page; | ||||
} | } | ||||
page->valid = VM_PAGE_BITS_ALL; | page->valid = VM_PAGE_BITS_ALL; | ||||
return (VM_PAGER_OK); | return (VM_PAGER_OK); | ||||
} | } | ||||
static void | static void | ||||
dev_pager_putpages(vm_object_t object, vm_page_t *m, int count, int flags, | dev_pager_putpages(vm_object_t object, vm_page_t *m, int count, int flags, | ||||
▲ Show 20 Lines • Show All 65 Lines • Show Last 20 Lines |