1
0
mirror of https://git.FreeBSD.org/src.git synced 2024-12-31 12:13:10 +00:00
freebsd/sys/vm
Alan Cox 19c244d064 Prevent a race between vm_object_collapse() and vm_object_split() from
causing a crash.

Suppose that we have two objects, obj and backing_obj, where
backing_obj is obj's backing object.  Further, suppose that
backing_obj has a reference count of two.  One being the reference
held by obj and the other by a map entry.  Now, suppose that the map
entry is deallocated and its reference removed by
vm_object_deallocate().  vm_object_deallocate() recognizes that the
only remaining reference is from a shadow object, obj, and calls
vm_object_collapse() on obj.  vm_object_collapse() executes

                if (backing_object->ref_count == 1) {
                        /*
                         * If there is exactly one reference to the backing
                         * object, we can collapse it into the parent.
                         */
                        vm_object_backing_scan(object, OBSC_COLLAPSE_WAIT);

vm_object_backing_scan(OBSC_COLLAPSE_WAIT) executes

        if (op & OBSC_COLLAPSE_WAIT) {
                vm_object_set_flag(backing_object, OBJ_DEAD);
        }

Finally, suppose that either vm_object_backing_scan() or
vm_object_collapse() sleeps releasing its locks.  At this instant,
another thread executes vm_object_split().  It crashes in
vm_object_reference_locked() on the assertion that the object is not
dead.  If, however, assertions are not enabled, it crashes much later,
after the object has been recycled, in vm_object_deallocate() because
the shadow count and shadow list are inconsistent.

Reviewed by: tegge
Reported by: jhb
MFC after: 1 week
2007-03-27 08:55:17 +00:00
..
default_pager.c
device_pager.c Replace PG_BUSY with VPO_BUSY. In other words, changes to the page's 2006-10-22 04:28:14 +00:00
memguard.c
memguard.h
phys_pager.c Change the way that unmanaged pages are created. Specifically, 2007-02-25 06:14:58 +00:00
pmap.h
redzone.c
redzone.h
swap_pager.c Use pause() rather than tsleep() on stack variables and function pointers. 2007-02-27 17:23:29 +00:00
swap_pager.h - Move 'struct swdevt' back into swap_pager.h and expose it to userland. 2007-02-07 17:43:11 +00:00
uma_core.c Add uma_set_align() interface, which will be called at most once during 2007-02-11 20:13:52 +00:00
uma_dbg.c
uma_dbg.h
uma_int.h
uma.h Add uma_set_align() interface, which will be called at most once during 2007-02-11 20:13:52 +00:00
vm_contig.c Change the free page queue lock from a spin mutex to a default (blocking) 2007-02-05 06:02:55 +00:00
vm_extern.h
vm_fault.c vm_page_busy() no longer requires the page queues lock to be held. Reduce 2007-03-23 06:11:25 +00:00
vm_glue.c - Remove setrunqueue and replace it with direct calls to sched_add(). 2007-01-23 08:46:51 +00:00
vm_init.c
vm_kern.c Change the way that unmanaged pages are created. Specifically, 2007-02-25 06:14:58 +00:00
vm_kern.h The clean_map has been made local to vm_init.c long ago. 2006-11-20 16:23:34 +00:00
vm_map.c Two small changes to vm_map_pmap_enter(): 2007-03-25 19:33:40 +00:00
vm_map.h
vm_meter.c Remove a redundant pointer-type variable. 2006-11-20 08:33:55 +00:00
vm_mmap.c Sweep kernel replacing suser(9) calls with priv(9) calls, assigning 2006-11-06 13:42:10 +00:00
vm_object.c Prevent a race between vm_object_collapse() and vm_object_split() from 2007-03-27 08:55:17 +00:00
vm_object.h
vm_page.c Change the way that unmanaged pages are created. Specifically, 2007-02-25 06:14:58 +00:00
vm_page.h Change the way that unmanaged pages are created. Specifically, 2007-02-25 06:14:58 +00:00
vm_pageout.c Change the pagedaemon, vm_wait(), and vm_waitpfault() to sleep on the 2007-02-07 06:37:30 +00:00
vm_pageout.h
vm_pageq.c Change the free page queue lock from a spin mutex to a default (blocking) 2007-02-05 06:02:55 +00:00
vm_pager.c
vm_pager.h
vm_param.h
vm_unix.c
vm_zeroidle.c Use the free page queue mutex instead of the page queue mutex to 2007-02-11 05:18:40 +00:00
vm.h
vnode_pager.c Long ago, revision 1.22 of vm/vm_pager.h introduced a bug. Specifically, 2006-10-14 23:21:48 +00:00
vnode_pager.h