Index: vm/vm_pageout.c =================================================================== --- vm/vm_pageout.c (.../head/sys) (revision 248711) +++ vm/vm_pageout.c (.../user/attilio/vmobj-readlock/sys) (revision 248711) @@ -1015,9 +1015,9 @@ vm_pageout_scan(int pass) } else if ((m->aflags & PGA_REFERENCED) == 0 && (actcount = pmap_ts_referenced(m)) != 0) { vm_page_activate(m); + VM_OBJECT_WUNLOCK(object); + m->act_count += actcount + ACT_ADVANCE; vm_page_unlock(m); - m->act_count += actcount + ACT_ADVANCE; - VM_OBJECT_WUNLOCK(object); goto relock_queues; } @@ -1031,9 +1031,9 @@ vm_pageout_scan(int pass) vm_page_aflag_clear(m, PGA_REFERENCED); actcount = pmap_ts_referenced(m); vm_page_activate(m); + VM_OBJECT_WUNLOCK(object); + m->act_count += actcount + ACT_ADVANCE + 1; vm_page_unlock(m); - m->act_count += actcount + ACT_ADVANCE + 1; - VM_OBJECT_WUNLOCK(object); goto relock_queues; } Index: vm/vm_page.h =================================================================== --- vm/vm_page.h (.../head/sys) (revision 248711) +++ vm/vm_page.h (.../user/attilio/vmobj-readlock/sys) (revision 248711) @@ -143,7 +143,7 @@ struct vm_page { uint8_t aflags; /* access is atomic */ uint8_t oflags; /* page VPO_* flags (O) */ uint16_t flags; /* page PG_* flags (P) */ - u_char act_count; /* page usage count (O) */ + u_char act_count; /* page usage count (P) */ u_char busy; /* page busy count (O) */ /* NOTE that these must support one bit per DEV_BSIZE in a page!!! */ /* so, on normal X86 kernels, they must be at least 8 bits wide */