BNX2X: spatch signed typedefs
[akaros.git] / kern / include / page_alloc.h
index 5a98312..ccaaa59 100644 (file)
@@ -24,14 +24,16 @@ struct page_map;            /* preprocessor games */
 struct page;
 typedef size_t ppn_t;
 typedef struct page page_t;
-typedef LIST_HEAD(PageList, page) page_list_t;
-typedef LIST_ENTRY(page) page_list_entry_t;
+typedef BSD_LIST_HEAD(PageList, page) page_list_t;
+typedef BSD_LIST_ENTRY(page) page_list_entry_t;
 
 /* Per-page flag bits related to their state in the page cache */
 #define PG_LOCKED              0x001   /* involved in an IO op */
 #define PG_UPTODATE            0x002   /* page map, filled with file data */
 #define PG_DIRTY               0x004   /* page map, data is dirty */
 #define PG_BUFFER              0x008   /* is a buffer page, has BHs */
+#define PG_PAGEMAP             0x010   /* belongs to a page map */
+#define PG_REMOVAL             0x020   /* Working flag for page map removal */
 
 /* TODO: this struct is not protected from concurrent operations in some
  * functions.  If you want to lock on it, use the spinlock in the semaphore.
@@ -39,13 +41,16 @@ typedef LIST_ENTRY(page) page_list_entry_t;
  * an issue, we can dynamically allocate some of these things when we're a
  * buffer page (in a page mapping) */
 struct page {
-       LIST_ENTRY(page)                        pg_link;        /* membership in various lists */
+       BSD_LIST_ENTRY(page)            pg_link;        /* membership in various lists */
        struct kref                                     pg_kref;
-       unsigned int                            pg_flags;
-       struct page_map                         *pg_mapping;
+       atomic_t                                        pg_flags;
+       struct page_map                         *pg_mapping; /* for debugging... */
        unsigned long                           pg_index;
+       void                                            **pg_tree_slot;
        void                                            *pg_private;    /* type depends on page usage */
        struct semaphore                        pg_sem;         /* for blocking on IO */
+       uint64_t                                gpa;            /* physical address in guest */
+                                                               /* pg_private is overloaded. */
 };
 
 /******** Externally visible global variables ************/
@@ -66,6 +71,8 @@ error_t upage_alloc_specific(struct proc* p, page_t *SAFE *page, size_t ppn);
 error_t kpage_alloc_specific(page_t *SAFE *page, size_t ppn);
 
 void *CT(1 << order) get_cont_pages(size_t order, int flags);
+void *CT(1 << order) get_cont_pages_node(int node, size_t order, int flags);
+void *get_cont_phys_pages_at(size_t order, physaddr_t at, int flags);
 void free_cont_pages(void *buf, size_t order);
 
 void page_incref(page_t *SAFE page);