1Variables 2static void *page_cache_table 3 4static spinlock_t page_cache_table_lock 5 6static int page_compare_func(void *_p, const void *_key) 7 Compares a vm_page's cache_ref and offset to those of key. Returns 0 on match, -1 otherwise. 8 9static unsigned int page_hash_func(void *_p, const void *_key, unsigned int range) 10 If p is not null, use it otherwise use key; computes a hash value for offset and reference. 11 12int vm_cache_init(kernel_args *ka) 13 Calls hash_init, sets page_cache_table_lock to unlocked and returns 0. 14 15vm_cache *vm_cache_create(vm_store *store) 16 Allocates a vm_cache structure and populates with 0's and NULLs (except for store). 17 18vm_cache_ref *vm_cache_ref_create(vm_cache *cache) 19 Allocates a vm_cache_ref, setting it to point to the passed in cache. It initalizes the references lock and returns. 20 21void vm_cache_acquire_ref(vm_cache_ref *cache_ref, bool acquire_store_ref) 22 If the cache_ref is null, panic. Otherwise, if we are to aquire a reference and there is an aquire reference function for this cache's store, call that function. Finally, increment this cache references' count. 23 24void vm_cache_release_ref(vm_cache_ref *cache_ref) 25 If this cache_ref is the last reference to its cache, we call destroy on the store, remove all of its pages from the page_cache_table and set the state of them to free, increase max_commit by the size of the now freed storage, remove the reference to the original cache, destroy the reference's mutex and its space. 26 Otherwise, we call the store's release ref and return. 27 28vm_page *vm_cache_lookup_page(vm_cache_ref *cache_ref, off_t offset) 29 Lock the page_cache_table_lock and lookup the offset and cache_ref in the page_cache_table, then unlock. 30 31void vm_cache_insert_page(vm_cache_ref *cache_ref, vm_page *page, off_t offset) 32 Add this page to the page_cache_table. 33 34void vm_cache_remove_page(vm_cache_ref *cache_ref, vm_page *page) 35 Find this page and remove it from the hash list. Clean up the linked lists. 36 37int vm_cache_insert_region(vm_cache_ref *cache_ref, vm_region *region) 38 Add this region to the cache_ref's region list. 39 40int vm_cache_remove_region(vm_cache_ref *cache_ref, vm_region *region) 41 Remove this region from the cache_ref's region list.