#define _PAGEMAP_H
#include <stdlib.h>
+#include <string.h>
#include "utils.h"
#include "list.h"
-#include "bintree.h"
+#include "rbtree.h"
#define PAGE_SHIFT 12
#define PAGE_SIZE (1 << PAGE_SHIFT)
#define BITRANGE(first, last) (((2ll << (last - first)) - 1) << first)
struct pageframe {
- struct bintree tree;
+ struct rb_node tree;
struct list_head ml; /* List of mappings which refer to this pfn */
unsigned long long pf; /* page frame entry from /proc/pid/pagemap */
int refcount;
};
-#define tree_to_pageframe(tree_struct) \
+struct pageframe *pf_insert(struct rb_root *root, struct pageframe *pf);
+struct pageframe *pf_search(struct rb_root *root, struct pageframe *pf);
+
+#define rb_to_pageframe(tree_struct) \
container_of((tree_struct), struct pageframe, tree)
static inline void clear_pageframe(struct pageframe *pf)