4 #include <linux/spinlock.h>
7 #define SWAP_FLAG_PREFER 0x8000 /* set if swap priority specified */
8 #define SWAP_FLAG_PRIO_MASK 0x7fff
9 #define SWAP_FLAG_PRIO_SHIFT 0
11 #define MAX_SWAPFILES 8
16 char reserved
[PAGE_SIZE
- 10];
21 char bootbits
[1024]; /* Space for disklabel etc. */
23 unsigned int last_page
;
24 unsigned int nr_badpages
;
25 unsigned int padding
[125];
26 unsigned int badpages
[1];
33 * Max bad pages in the new format..
35 #define __swapoffset(x) ((unsigned long)&((union swap_header *)0)->x)
36 #define MAX_SWAP_BADPAGES \
37 ((__swapoffset(magic.magic) - __swapoffset(info.badpages)) / sizeof(int))
39 #include <asm/atomic.h>
44 #define SWAP_CLUSTER_MAX 32
46 #define SWAP_MAP_MAX 0x7fff
47 #define SWAP_MAP_BAD 0x8000
49 struct swap_info_struct
{
53 struct dentry
* swap_file
;
54 unsigned short * swap_map
;
55 unsigned int lowest_bit
;
56 unsigned int highest_bit
;
57 unsigned int cluster_next
;
58 unsigned int cluster_nr
;
59 int prio
; /* swap priority */
62 int next
; /* next entry on swap list */
65 extern int nr_swap_pages
;
66 FASTCALL(unsigned int nr_free_pages(void));
67 FASTCALL(unsigned int nr_free_buffer_pages(void));
68 FASTCALL(unsigned int nr_free_highpages(void));
69 extern int nr_lru_pages
;
70 extern atomic_t nr_async_pages
;
71 extern struct address_space swapper_space
;
72 extern atomic_t page_cache_size
;
73 extern atomic_t buffermem_pages
;
75 /* Incomplete types for prototype declarations: */
77 struct vm_area_struct
;
82 extern int shm_swap (int, int, zone_t
*);
85 extern void swap_setup (void);
87 /* linux/mm/vmscan.c */
88 extern int try_to_free_pages(unsigned int gfp_mask
, zone_t
*zone
);
90 /* linux/mm/page_io.c */
91 extern void rw_swap_page(int, struct page
*, int);
92 extern void rw_swap_page_nolock(int, swp_entry_t
, char *, int);
94 /* linux/mm/page_alloc.c */
96 /* linux/mm/swap_state.c */
97 extern void show_swap_cache_info(void);
98 extern void add_to_swap_cache(struct page
*, swp_entry_t
);
99 extern int swap_check_entry(unsigned long);
100 extern struct page
* lookup_swap_cache(swp_entry_t
);
101 extern struct page
* read_swap_cache_async(swp_entry_t
, int);
102 #define read_swap_cache(entry) read_swap_cache_async(entry, 1);
105 * Make these inline later once they are working properly.
107 extern void __delete_from_swap_cache(struct page
*page
);
108 extern void delete_from_swap_cache(struct page
*page
);
109 extern void delete_from_swap_cache_nolock(struct page
*page
);
110 extern void free_page_and_swap_cache(struct page
*page
);
112 /* linux/mm/swapfile.c */
113 extern unsigned int nr_swapfiles
;
114 extern struct swap_info_struct swap_info
[];
115 extern int is_swap_partition(kdev_t
);
116 extern void si_swapinfo(struct sysinfo
*);
117 extern swp_entry_t
__get_swap_page(unsigned short);
118 extern void get_swaphandle_info(swp_entry_t
, unsigned long *, kdev_t
*,
120 extern int swap_duplicate(swp_entry_t
);
121 extern int swap_count(struct page
*);
122 extern swp_entry_t
acquire_swap_entry(struct page
*page
);
123 extern int valid_swaphandles(swp_entry_t
, unsigned long *);
124 #define get_swap_page() __get_swap_page(1)
125 extern void __swap_free(swp_entry_t
, unsigned short);
126 #define swap_free(entry) __swap_free((entry), 1)
128 int head
; /* head of priority-ordered swapfile list */
129 int next
; /* swapfile to be used next */
131 extern struct swap_list_t swap_list
;
132 asmlinkage
long sys_swapoff(const char *);
133 asmlinkage
long sys_swapon(const char *, int);
135 #define SWAP_CACHE_INFO
137 #ifdef SWAP_CACHE_INFO
138 extern unsigned long swap_cache_add_total
;
139 extern unsigned long swap_cache_del_total
;
140 extern unsigned long swap_cache_find_total
;
141 extern unsigned long swap_cache_find_success
;
145 * Work out if there are any other processes sharing this page, ignoring
146 * any page reference coming from the swap cache, or from outstanding
147 * swap IO on this page. (The page cache _does_ count as another valid
148 * reference to the page, however.)
150 static inline int is_page_shared(struct page
*page
)
153 if (PageReserved(page
))
155 count
= page_count(page
);
156 if (PageSwapCache(page
))
157 count
+= swap_count(page
) - 2;
161 extern spinlock_t pagemap_lru_lock
;
164 * Helper macros for lru_pages handling.
166 #define lru_cache_add(page) \
168 spin_lock(&pagemap_lru_lock); \
169 list_add(&(page)->lru, &page->zone->lru_cache); \
171 spin_unlock(&pagemap_lru_lock); \
174 #define lru_cache_del(page) \
176 spin_lock(&pagemap_lru_lock); \
177 list_del(&(page)->lru); \
179 spin_unlock(&pagemap_lru_lock); \
182 extern spinlock_t swaplock
;
184 #define swap_list_lock() spin_lock(&swaplock)
185 #define swap_list_unlock() spin_unlock(&swaplock)
186 #define swap_device_lock(p) spin_lock(&p->sdev_lock)
187 #define swap_device_unlock(p) spin_unlock(&p->sdev_lock)
189 #endif /* __KERNEL__*/
191 #endif /* _LINUX_SWAP_H */