pm: Add pm_writeback_pages()
[akaros.git] / kern / include / pagemap.h
index 56dd9c2..140ffbb 100644 (file)
@@ -7,32 +7,28 @@
  * with the VFS, block devices also use it (hence the separate header and c
  * file). */
 
-#ifndef ROS_KERN_PAGEMAP_H
-#define ROS_KERN_PAGEMAP_H
+#pragma once
 
 #include <radix.h>
 #include <atomic.h>
+#include <mm.h>
 
 /* Need to be careful, due to some ghetto circular references */
 struct page;
-struct inode;
-struct block_device;
+struct chan;
 struct page_map_operations;
 
-/* Every object that has pages, like an inode or the swap (or even direct block
- * devices) has a page_map, tracking which of its pages are currently in memory.
- * It is a map, per object, from index to physical page frame. */
+/* Every object that has pages has a page_map, tracking which of its pages are
+ * currently in memory.  It is a map, per object, from index to physical page
+ * frame. */
 struct page_map {
-       union {
-               struct inode                            *pm_host;       /* inode of the owner, if any */
-               struct block_device                     *pm_bdev;       /* bdev of the owner, if any */
-       };
+       qlock_t                                         pm_qlock;               /* for the radix tree nr_pgs */
+       struct fs_file                          *pm_file;
        struct radix_tree                       pm_tree;                /* tracks present pages */
-       spinlock_t                                      pm_tree_lock;   /* spinlock => we can't block */
        unsigned long                           pm_num_pages;   /* how many pages are present */
        struct page_map_operations      *pm_op;
-       unsigned int                            pm_flags;
-       /*... and private lists, backing block dev info, other mappings, etc. */
+       spinlock_t                                      pm_lock;                /* for the VMR list */
+       struct vmr_tailq                        pm_vmrs;
 };
 
 /* Operations performed on a page_map.  These are usually FS specific, which
@@ -40,6 +36,7 @@ struct page_map {
  * Will fill these in as they are created/needed/used. */
 struct page_map_operations {
        int (*readpage) (struct page_map *, struct page *);
+       int (*writepage) (struct page_map *, struct page *);
 /*     readpages: read a list of pages
        writepage: write from a page to its backing store
        writepages: write a list of pages
@@ -49,14 +46,23 @@ struct page_map_operations {
        commit_write: complete a write (disk backed pages)
        bmap: get a logical block number from a file block index
        invalidate page: invalidate, part of truncating
-       release page: prepare to release 
+       release page: prepare to release
        direct_io: bypass the page cache */
 };
 
 /* Page cache functions */
 void pm_init(struct page_map *pm, struct page_map_operations *op, void *host);
-struct page *pm_find_page(struct page_map *pm, unsigned long index);
-int pm_insert_page(struct page_map *pm, unsigned long index, struct page *page);
-int pm_remove_page(struct page_map *pm, struct page *page);
-
-#endif /* ROS_KERN_PAGEMAP_H */
+int pm_load_page(struct page_map *pm, unsigned long index, struct page **pp);
+int pm_load_page_nowait(struct page_map *pm, unsigned long index,
+                        struct page **pp);
+void pm_put_page(struct page *page);
+void pm_add_vmr(struct page_map *pm, struct vm_region *vmr);
+void pm_remove_vmr(struct page_map *pm, struct vm_region *vmr);
+int pm_remove_contig(struct page_map *pm, unsigned long index,
+                     unsigned long nr_pgs);
+void pm_remove_or_zero_pages(struct page_map *pm, unsigned long start_idx,
+                             unsigned long nr_pgs);
+void pm_writeback_pages(struct page_map *pm);
+void pm_destroy(struct page_map *pm);
+void pm_page_asserter(struct page *page, char *str);
+void print_page_map_info(struct page_map *pm);