summaryrefslogtreecommitdiffstats
path: root/sys/vm/vm.h
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2009-07-12 23:31:20 +0000
committeralc <alc@FreeBSD.org>2009-07-12 23:31:20 +0000
commitea60573817570658a0528f9e36f4b65d1dc10b05 (patch)
treea3d5747cacdafc73df95feaef86c79ecdf8fc918 /sys/vm/vm.h
parentc86a9c376273cc3a3010c0b5ad122b391a1b2ecd (diff)
downloadFreeBSD-src-ea60573817570658a0528f9e36f4b65d1dc10b05.zip
FreeBSD-src-ea60573817570658a0528f9e36f4b65d1dc10b05.tar.gz
Add support to the virtual memory system for configuring machine-
dependent memory attributes: Rename vm_cache_mode_t to vm_memattr_t. The new name reflects the fact that there are machine-dependent memory attributes that have nothing to do with controlling the cache's behavior. Introduce vm_object_set_memattr() for setting the default memory attributes that will be given to an object's pages. Introduce and use pmap_page_{get,set}_memattr() for getting and setting a page's machine-dependent memory attributes. Add full support for these functions on amd64 and i386 and stubs for them on the other architectures. The function pmap_page_set_memattr() is also responsible for any other machine-dependent aspects of changing a page's memory attributes, such as flushing the cache or updating the direct map. The uses include kmem_alloc_contig(), vm_page_alloc(), and the device pager: kmem_alloc_contig() can now be used to allocate kernel memory with non-default memory attributes on amd64 and i386. vm_page_alloc() and the device pager will set the memory attributes for the real or fictitious page according to the object's default memory attributes. Update the various pmap functions on amd64 and i386 that map pages to incorporate each page's memory attributes in the mapping. Notes: (1) Inherent to this design are safety features that prevent the specification of inconsistent memory attributes by different mappings on amd64 and i386. In addition, the device pager provides a warning when a device driver creates a fictitious page with memory attributes that are inconsistent with the real page that the fictitious page is an alias for. (2) Storing the machine-dependent memory attributes for amd64 and i386 as a dedicated "int" in "struct md_page" represents a compromise between space efficiency and the ease of MFCing these changes to RELENG_7. In collaboration with: jhb Approved by: re (kib)
Diffstat (limited to 'sys/vm/vm.h')
-rw-r--r--sys/vm/vm.h6
1 files changed, 3 insertions, 3 deletions
diff --git a/sys/vm/vm.h b/sys/vm/vm.h
index 832c335..9159e93 100644
--- a/sys/vm/vm.h
+++ b/sys/vm/vm.h
@@ -64,10 +64,10 @@
#include <machine/vm.h>
/*
- * The exact set of cache control codes is machine dependent. However, every
- * machine is required to define VM_CACHE_DEFAULT.
+ * The exact set of memory attributes is machine dependent. However, every
+ * machine is required to define VM_MEMATTR_DEFAULT.
*/
-typedef char vm_cache_mode_t; /* cache control codes */
+typedef char vm_memattr_t; /* memory attribute codes */
typedef char vm_inherit_t; /* inheritance codes */
OpenPOWER on IntegriCloud