alc
7db05daaf9
Modify vm_page_alloc() and vm_page_select_cache() to allow the page that
...
is returned by vm_page_select_cache() to belong to the object that is
already locked by the caller to vm_page_alloc().
2003-07-01 07:33:41 +00:00
alc
decdc946ef
Check the address provided to vm_map_stack() against the vm map's maximum,
...
returning an error if the address is too high.
2003-07-01 03:57:25 +00:00
alc
65c6a689bc
Introduce vm_map_pmap_enter(). Presently, this is a stub calling the MD
...
pmap_object_init_pt().
2003-06-29 23:32:55 +00:00
alc
44509f207f
- Export pmap_enter_quick() to the MI VM. This will permit the
...
implementation of a largely MI pmap_object_init_pt() for vnode-backed
objects. pmap_enter_quick() is implemented via pmap_enter() on sparc64
and powerpc.
- Correct a mismatch between pmap_object_init_pt()'s prototype and its
various implementations. (I plan to keep pmap_object_init_pt() as
the MD hook for device-backed objects on i386 and amd64.)
- Correct an error in ia64's pmap_enter_quick() and adjust its interface
to match the other versions. Discussed with: marcel
2003-06-29 21:20:04 +00:00
alc
0269d0e1b4
Add vm object locking to vm_pageout_map_deactivate_pages().
2003-06-29 19:51:24 +00:00
alc
9ab695deec
Remove GIANT_REQUIRED from kmem_malloc().
2003-06-28 22:04:52 +00:00
alc
df16822d69
- Add vm object locking to vm_pageout_clean().
2003-06-28 20:07:54 +00:00
alc
1eef33b705
- Use an int rather than a vm_pindex_t to represent the desired page
...
color in vm_page_alloc(). (This also has small performance benefits.)
- Eliminate vm_page_select_free(); vm_page_alloc() might as well
call vm_pageq_find() directly.
2003-06-28 07:58:10 +00:00
alc
0b4d9704b9
Simple read-modify-write operations on a vm object's flags, ref_count, and
...
shadow_count can now rely on its mutex for synchronization. Remove one use
of Giant from vm_map_insert().
2003-06-27 18:52:49 +00:00
alc
0e0026d70f
vm_page_select_cache() enforces a number of conditions on the returned
...
page. Add the ability to lock the containing object to those conditions.
2003-06-26 15:44:03 +00:00
alc
5cfe94b875
Modify vm_pageq_requeue() to handle a PQ_NONE page without dereferencing
...
a NULL pointer; remove some now unused code.
2003-06-26 03:14:40 +00:00
bmilekic
bf27dce79b
Move the pcpu lock out of the uma_cache and instead have a single set
...
of pcpu locks. This makes uma_zone somewhat smaller (by (LOCKNAME_LEN *
sizeof(char) + sizeof(struct mtx) * maxcpu) bytes, to be exact).
No Objections from jeff.
2003-06-25 20:49:48 +00:00
bmilekic
2763308887
Make sure that the zone destructor doesn't get called twice in
...
certain free paths.
2003-06-25 17:25:45 +00:00
alc
8ef02c4002
Remove a GIANT_REQUIRED on the kernel object that we no longer need.
2003-06-25 05:31:02 +00:00
alc
a4f8c4746a
Maintain the lock on a vm object when calling vm_page_grab().
2003-06-25 04:53:56 +00:00
alc
cbc68243ab
Assert that the vm object is locked on entry to dev_pager_getpages().
2003-06-24 19:48:34 +00:00
alc
b3592fe6d2
Assert that the vm object is locked on entry to vm_pager_get_pages().
2003-06-23 06:15:05 +00:00
alc
fa54a6610e
Maintain a lock on the vm object of interest throughout vm_fault(),
...
releasing the lock only if we are about to sleep (e.g., vm_pager_get_pages()
or vm_pager_has_pages()). If we sleep, we have marked the vm object with
the paging-in-progress flag.
2003-06-22 21:35:41 +00:00
phk
c81c59299b
Add a f_vnode field to struct file.
...
Several of the subtypes have an associated vnode which is used for
stuff like the f*() functions.
By giving the vnode a speparate field, a number of checks for the specific
subtype can be replaced simply with a check for f_vnode != NULL, and
we can later free f_data up to subtype specific use.
At this point in time, f_data still points to the vnode, so any code I
might have overlooked will still work.
2003-06-22 08:41:43 +00:00
alc
5d0aaa2a87
As vm_fault() descends the chain of backing objects, set paging-in-
...
progress on the next object before clearing it on the current object.
2003-06-22 05:36:53 +00:00
alc
17a3946774
Complete the vm object locking in vm_object_backing_scan(); specifically,
...
deal with the case where we need to sleep on a busy page with two vm object
locks held.
2003-06-22 02:35:06 +00:00
alc
752ed0a2b9
Make some style and white-space changes to the copy-on-write path through
...
vm_fault(); remove a pointless assignment statement from that path.
2003-06-22 00:00:11 +00:00
phk
42a4ac2ba1
Use a do {...} while (0); and a couple of breaks to reduce the level
...
of indentation a bit.
2003-06-21 08:27:06 +00:00
alc
ed79b4d625
Lock one of the vm objects involved in an optimized copy-on-write fault.
2003-06-21 06:31:42 +00:00
alc
ab509a1fdd
- Increase the scope of the vm object lock in vm_object_collapse().
...
- Assert that the vm object and its backing vm object are both locked in
vm_object_qcollapse().
2003-06-21 04:14:48 +00:00
alc
6106a85499
Make swap_pager_haspages() static; remove unused function prototypes.
2003-06-20 20:20:06 +00:00
phk
85ce27a435
Initialize b_saveaddr when we hand out pbufs
2003-06-20 08:35:28 +00:00
alc
893b54638f
The so-called "optimized copy-on-write fault" case should not require
...
the vm map lock. What's really needed is vm object locking, which
is (for the moment) provided Giant.
Reviewed by: tegge
2003-06-20 04:20:36 +00:00
alc
cb7655e83c
Assert that the vm object is locked in vm_page_try_to_free().
2003-06-19 01:50:14 +00:00
alc
29c6e6376c
Fix a vm object reference leak in the page-based copy-on-write mechanism
...
used by the zero-copy sockets implementation.
Reviewed by: gallatin
2003-06-19 01:40:44 +00:00
alc
cacc52e8aa
Lock the vm object when freeing a vm page.
2003-06-18 04:27:18 +00:00
phk
bd4fe20bfd
This file was ignored by CVS in my last commit for some reason:
...
Remove pointless initialization of b_spc field, which now no longer
exists.
2003-06-16 09:31:15 +00:00
phk
24cc9156fe
Add the same KASSERT to all VOP_STRATEGY and VOP_SPECSTRATEGY implementations
...
to check that the buffer points to the correct vnode.
2003-06-15 18:53:00 +00:00
alc
ff1c2851e3
Remove an unnecessary forward declaration.
2003-06-15 07:28:33 +00:00
alc
a7a826b5cb
Use #ifdef __alpha__, not __alpha.
2003-06-15 00:12:42 +00:00
alc
83f108b04d
Migrate the thread stack management functions from the machine-dependent
...
to the machine-independent parts of the VM. At the same time, this
introduces vm object locking for the non-i386 platforms.
Two details:
1. KSTACK_GUARD has been removed in favor of KSTACK_GUARD_PAGES. The
different machine-dependent implementations used various combinations
of KSTACK_GUARD and KSTACK_GUARD_PAGES. To disable guard page, set
KSTACK_GUARD_PAGES to 0.
2. Remove the (unnecessary) clearing of PG_ZERO in vm_thread_new. In
5.x, (but not 4.x,) PG_ZERO can only be set if VM_ALLOC_ZERO is passed
to vm_page_alloc() or vm_page_grab().
2003-06-14 23:23:55 +00:00
alc
d20c30720b
Move the *_new_altkstack() and *_dispose_altkstack() functions out of the
...
various pmap implementations into the machine-independent vm. They were
all identical.
2003-06-14 06:20:25 +00:00
alc
d2198cef89
Extend the scope of the vm object lock in swp_pager_async_iodone() to cover
...
a vm_page_free().
2003-06-13 06:17:42 +00:00
alc
d66a37a0f2
Add vm object locking to various pagers' "get pages" methods, i386 stack
...
management functions, and a u area management function.
2003-06-13 03:02:28 +00:00
obrien
b0678d7a44
Use __FBSDID().
2003-06-11 23:50:51 +00:00
peter
fda03b7cfc
GC unused cpu_wait() function
2003-06-11 05:20:33 +00:00
alc
cad0ed280c
- Finish vm object and page locking in vnode_pager_setsize().
...
- Make some small style changes to vnode_pager_setsize(); most notably,
move two comments to a more logical place.
2003-06-10 20:28:41 +00:00
phk
07cd5a08f3
Revert last commit, I have no idea what happened.
2003-06-09 22:51:36 +00:00
phk
5411462454
A white-space nit I noticed.
2003-06-09 19:40:34 +00:00
alc
f13256329b
Hold the vm object's lock when performing vm_page_lookup().
2003-06-09 07:01:05 +00:00
alc
fd950733b7
Don't use vm_object_set_flag() to initialize the vm object's flags.
2003-06-09 06:50:02 +00:00
alc
6a3f0ec4b1
- Properly handle the paging_in_progress case on two vm objects in
...
vm_object_deallocate().
- Remove vm_object_pip_sleep().
2003-06-08 23:01:24 +00:00
alc
3812b42f43
Lock the kernel object in kmem_alloc().
2003-06-07 23:24:10 +00:00
alc
e448f32b52
Teach vm_page_grab() how to handle the vm object's lock.
2003-06-07 23:22:04 +00:00
alc
c57f179395
Assert that the vm object is locked on entry to swap_pager_freespace().
2003-06-07 20:43:16 +00:00