blob: c32e9b23d64279ab6a3b8a3ab9765afaf6b6be3b [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/mm/swapfile.c
3 *
4 * Copyright (C) 1991, 1992, 1993, 1994 Linus Torvalds
5 * Swap reorganised 29.12.95, Stephen Tweedie
6 */
7
Linus Torvalds1da177e2005-04-16 15:20:36 -07008#include <linux/mm.h>
Ingo Molnar6e84f312017-02-08 18:51:29 +01009#include <linux/sched/mm.h>
Ingo Molnar29930022017-02-08 18:51:36 +010010#include <linux/sched/task.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070011#include <linux/hugetlb.h>
12#include <linux/mman.h>
13#include <linux/slab.h>
14#include <linux/kernel_stat.h>
15#include <linux/swap.h>
16#include <linux/vmalloc.h>
17#include <linux/pagemap.h>
18#include <linux/namei.h>
Hugh Dickins072441e2011-06-27 16:18:02 -070019#include <linux/shmem_fs.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#include <linux/blkdev.h>
Hugh Dickins20137a42009-01-06 14:39:54 -080021#include <linux/random.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070022#include <linux/writeback.h>
23#include <linux/proc_fs.h>
24#include <linux/seq_file.h>
25#include <linux/init.h>
Hugh Dickins5ad64682009-12-14 17:59:24 -080026#include <linux/ksm.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070027#include <linux/rmap.h>
28#include <linux/security.h>
29#include <linux/backing-dev.h>
Ingo Molnarfc0abb12006-01-18 17:42:33 -080030#include <linux/mutex.h>
Randy.Dunlapc59ede72006-01-11 12:17:46 -080031#include <linux/capability.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070032#include <linux/syscalls.h>
Balbir Singh8a9f3cc2008-02-07 00:13:53 -080033#include <linux/memcontrol.h>
Kay Sievers66d7dd52010-10-26 14:22:06 -070034#include <linux/poll.h>
David Rientjes72788c32011-05-24 17:11:40 -070035#include <linux/oom.h>
Dan Magenheimer38b5faf2012-04-09 17:08:06 -060036#include <linux/frontswap.h>
37#include <linux/swapfile.h>
Mel Gormanf981c592012-07-31 16:44:47 -070038#include <linux/export.h>
Tim Chen67afa382017-02-22 15:45:39 -080039#include <linux/swap_slots.h>
Huang Ying155b5f82017-07-06 15:40:31 -070040#include <linux/sort.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070041
42#include <asm/pgtable.h>
43#include <asm/tlbflush.h>
44#include <linux/swapops.h>
Johannes Weiner5d1ea482014-12-10 15:44:55 -080045#include <linux/swap_cgroup.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070046
Hugh Dickins570a335b2009-12-14 17:58:46 -080047static bool swap_count_continued(struct swap_info_struct *, pgoff_t,
48 unsigned char);
49static void free_swap_count_continuations(struct swap_info_struct *);
Lee Schermerhornd4906e12009-12-14 17:58:49 -080050static sector_t map_swap_entry(swp_entry_t, struct block_device**);
Hugh Dickins570a335b2009-12-14 17:58:46 -080051
Dan Magenheimer38b5faf2012-04-09 17:08:06 -060052DEFINE_SPINLOCK(swap_lock);
Adrian Bunk7c363b82008-07-25 19:46:24 -070053static unsigned int nr_swapfiles;
Shaohua Liec8acf22013-02-22 16:34:38 -080054atomic_long_t nr_swap_pages;
Chris Wilsonfb0fec52015-12-04 15:58:53 +000055/*
56 * Some modules use swappable objects and may try to swap them out under
57 * memory pressure (via the shrinker). Before doing so, they may wish to
58 * check to see if any swap space is available.
59 */
60EXPORT_SYMBOL_GPL(nr_swap_pages);
Shaohua Liec8acf22013-02-22 16:34:38 -080061/* protected with swap_lock. reading in vm_swap_full() doesn't need lock */
Linus Torvalds1da177e2005-04-16 15:20:36 -070062long total_swap_pages;
Hugh Dickins78ecba02008-07-23 21:28:23 -070063static int least_priority;
Linus Torvalds1da177e2005-04-16 15:20:36 -070064
Linus Torvalds1da177e2005-04-16 15:20:36 -070065static const char Bad_file[] = "Bad swap file entry ";
66static const char Unused_file[] = "Unused swap file entry ";
67static const char Bad_offset[] = "Bad swap offset entry ";
68static const char Unused_offset[] = "Unused swap offset entry ";
69
Dan Streetmanadfab832014-06-04 16:09:53 -070070/*
71 * all active swap_info_structs
72 * protected with swap_lock, and ordered by priority.
73 */
Dan Streetman18ab4d42014-06-04 16:09:59 -070074PLIST_HEAD(swap_active_head);
75
76/*
77 * all available (active, not full) swap_info_structs
78 * protected with swap_avail_lock, ordered by priority.
79 * This is used by get_swap_page() instead of swap_active_head
80 * because swap_active_head includes all swap_info_structs,
81 * but get_swap_page() doesn't need to look at full ones.
82 * This uses its own lock instead of swap_lock because when a
83 * swap_info_struct changes between not-full/full, it needs to
84 * add/remove itself to/from this list, but the swap_info_struct->lock
85 * is held and the locking order requires swap_lock to be taken
86 * before any swap_info_struct->lock.
87 */
88static PLIST_HEAD(swap_avail_head);
89static DEFINE_SPINLOCK(swap_avail_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -070090
Dan Magenheimer38b5faf2012-04-09 17:08:06 -060091struct swap_info_struct *swap_info[MAX_SWAPFILES];
Linus Torvalds1da177e2005-04-16 15:20:36 -070092
Ingo Molnarfc0abb12006-01-18 17:42:33 -080093static DEFINE_MUTEX(swapon_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -070094
Kay Sievers66d7dd52010-10-26 14:22:06 -070095static DECLARE_WAIT_QUEUE_HEAD(proc_poll_wait);
96/* Activity counter to indicate that a swapon or swapoff has occurred */
97static atomic_t proc_poll_event = ATOMIC_INIT(0);
98
Hugh Dickins8d69aae2009-12-14 17:58:45 -080099static inline unsigned char swap_count(unsigned char ent)
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -0700100{
Hugh Dickins570a335b2009-12-14 17:58:46 -0800101 return ent & ~SWAP_HAS_CACHE; /* may include SWAP_HAS_CONT flag */
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -0700102}
103
Hugh Dickinsefa90a92009-12-14 17:58:41 -0800104/* returns 1 if swap entry is freed */
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700105static int
106__try_to_reclaim_swap(struct swap_info_struct *si, unsigned long offset)
107{
Hugh Dickinsefa90a92009-12-14 17:58:41 -0800108 swp_entry_t entry = swp_entry(si->type, offset);
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700109 struct page *page;
110 int ret = 0;
111
Huang Yingf6ab1f72016-10-07 17:00:21 -0700112 page = find_get_page(swap_address_space(entry), swp_offset(entry));
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700113 if (!page)
114 return 0;
115 /*
116 * This function is called from scan_swap_map() and it's called
117 * by vmscan.c at reclaiming pages. So, we hold a lock on a page, here.
118 * We have to use trylock for avoiding deadlock. This is a special
119 * case and you should use try_to_free_swap() with explicit lock_page()
120 * in usual operations.
121 */
122 if (trylock_page(page)) {
123 ret = try_to_free_swap(page);
124 unlock_page(page);
125 }
Kirill A. Shutemov09cbfea2016-04-01 15:29:47 +0300126 put_page(page);
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700127 return ret;
128}
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -0700129
Linus Torvalds1da177e2005-04-16 15:20:36 -0700130/*
Hugh Dickins6a6ba832009-01-06 14:39:51 -0800131 * swapon tell device that all the old swap contents can be discarded,
132 * to allow the swap device to optimize its wear-levelling.
133 */
134static int discard_swap(struct swap_info_struct *si)
135{
136 struct swap_extent *se;
Hugh Dickins9625a5f2009-12-14 17:58:42 -0800137 sector_t start_block;
138 sector_t nr_blocks;
Hugh Dickins6a6ba832009-01-06 14:39:51 -0800139 int err = 0;
140
Hugh Dickins9625a5f2009-12-14 17:58:42 -0800141 /* Do not discard the swap header page! */
142 se = &si->first_swap_extent;
143 start_block = (se->start_block + 1) << (PAGE_SHIFT - 9);
144 nr_blocks = ((sector_t)se->nr_pages - 1) << (PAGE_SHIFT - 9);
145 if (nr_blocks) {
146 err = blkdev_issue_discard(si->bdev, start_block,
Christoph Hellwigdd3932e2010-09-16 20:51:46 +0200147 nr_blocks, GFP_KERNEL, 0);
Hugh Dickins9625a5f2009-12-14 17:58:42 -0800148 if (err)
149 return err;
150 cond_resched();
151 }
Hugh Dickins6a6ba832009-01-06 14:39:51 -0800152
Hugh Dickins9625a5f2009-12-14 17:58:42 -0800153 list_for_each_entry(se, &si->first_swap_extent.list, list) {
154 start_block = se->start_block << (PAGE_SHIFT - 9);
155 nr_blocks = (sector_t)se->nr_pages << (PAGE_SHIFT - 9);
Hugh Dickins6a6ba832009-01-06 14:39:51 -0800156
157 err = blkdev_issue_discard(si->bdev, start_block,
Christoph Hellwigdd3932e2010-09-16 20:51:46 +0200158 nr_blocks, GFP_KERNEL, 0);
Hugh Dickins6a6ba832009-01-06 14:39:51 -0800159 if (err)
160 break;
161
162 cond_resched();
163 }
164 return err; /* That will often be -EOPNOTSUPP */
165}
166
Hugh Dickins7992fde2009-01-06 14:39:53 -0800167/*
168 * swap allocation tell device that a cluster of swap can now be discarded,
169 * to allow the swap device to optimize its wear-levelling.
170 */
171static void discard_swap_cluster(struct swap_info_struct *si,
172 pgoff_t start_page, pgoff_t nr_pages)
173{
174 struct swap_extent *se = si->curr_swap_extent;
175 int found_extent = 0;
176
177 while (nr_pages) {
Hugh Dickins7992fde2009-01-06 14:39:53 -0800178 if (se->start_page <= start_page &&
179 start_page < se->start_page + se->nr_pages) {
180 pgoff_t offset = start_page - se->start_page;
181 sector_t start_block = se->start_block + offset;
Hugh Dickins858a29902009-01-06 14:39:56 -0800182 sector_t nr_blocks = se->nr_pages - offset;
Hugh Dickins7992fde2009-01-06 14:39:53 -0800183
184 if (nr_blocks > nr_pages)
185 nr_blocks = nr_pages;
186 start_page += nr_blocks;
187 nr_pages -= nr_blocks;
188
189 if (!found_extent++)
190 si->curr_swap_extent = se;
191
192 start_block <<= PAGE_SHIFT - 9;
193 nr_blocks <<= PAGE_SHIFT - 9;
194 if (blkdev_issue_discard(si->bdev, start_block,
Christoph Hellwigdd3932e2010-09-16 20:51:46 +0200195 nr_blocks, GFP_NOIO, 0))
Hugh Dickins7992fde2009-01-06 14:39:53 -0800196 break;
197 }
198
Geliang Tanga8ae4992016-01-14 15:20:45 -0800199 se = list_next_entry(se, list);
Hugh Dickins7992fde2009-01-06 14:39:53 -0800200 }
201}
202
Huang Ying38d8b4e2017-07-06 15:37:18 -0700203#ifdef CONFIG_THP_SWAP
204#define SWAPFILE_CLUSTER HPAGE_PMD_NR
205#else
Hugh Dickins048c27f2005-09-03 15:54:40 -0700206#define SWAPFILE_CLUSTER 256
Huang Ying38d8b4e2017-07-06 15:37:18 -0700207#endif
Hugh Dickins048c27f2005-09-03 15:54:40 -0700208#define LATENCY_LIMIT 256
209
Shaohua Li2a8f9442013-09-11 14:20:28 -0700210static inline void cluster_set_flag(struct swap_cluster_info *info,
211 unsigned int flag)
212{
213 info->flags = flag;
214}
215
216static inline unsigned int cluster_count(struct swap_cluster_info *info)
217{
218 return info->data;
219}
220
221static inline void cluster_set_count(struct swap_cluster_info *info,
222 unsigned int c)
223{
224 info->data = c;
225}
226
227static inline void cluster_set_count_flag(struct swap_cluster_info *info,
228 unsigned int c, unsigned int f)
229{
230 info->flags = f;
231 info->data = c;
232}
233
234static inline unsigned int cluster_next(struct swap_cluster_info *info)
235{
236 return info->data;
237}
238
239static inline void cluster_set_next(struct swap_cluster_info *info,
240 unsigned int n)
241{
242 info->data = n;
243}
244
245static inline void cluster_set_next_flag(struct swap_cluster_info *info,
246 unsigned int n, unsigned int f)
247{
248 info->flags = f;
249 info->data = n;
250}
251
252static inline bool cluster_is_free(struct swap_cluster_info *info)
253{
254 return info->flags & CLUSTER_FLAG_FREE;
255}
256
257static inline bool cluster_is_null(struct swap_cluster_info *info)
258{
259 return info->flags & CLUSTER_FLAG_NEXT_NULL;
260}
261
262static inline void cluster_set_null(struct swap_cluster_info *info)
263{
264 info->flags = CLUSTER_FLAG_NEXT_NULL;
265 info->data = 0;
266}
267
Huang, Ying235b6212017-02-22 15:45:22 -0800268static inline struct swap_cluster_info *lock_cluster(struct swap_info_struct *si,
269 unsigned long offset)
270{
271 struct swap_cluster_info *ci;
272
273 ci = si->cluster_info;
274 if (ci) {
275 ci += offset / SWAPFILE_CLUSTER;
276 spin_lock(&ci->lock);
277 }
278 return ci;
279}
280
281static inline void unlock_cluster(struct swap_cluster_info *ci)
282{
283 if (ci)
284 spin_unlock(&ci->lock);
285}
286
287static inline struct swap_cluster_info *lock_cluster_or_swap_info(
288 struct swap_info_struct *si,
289 unsigned long offset)
290{
291 struct swap_cluster_info *ci;
292
293 ci = lock_cluster(si, offset);
294 if (!ci)
295 spin_lock(&si->lock);
296
297 return ci;
298}
299
300static inline void unlock_cluster_or_swap_info(struct swap_info_struct *si,
301 struct swap_cluster_info *ci)
302{
303 if (ci)
304 unlock_cluster(ci);
305 else
306 spin_unlock(&si->lock);
307}
308
Huang Ying6b534912016-10-07 16:58:42 -0700309static inline bool cluster_list_empty(struct swap_cluster_list *list)
310{
311 return cluster_is_null(&list->head);
312}
313
314static inline unsigned int cluster_list_first(struct swap_cluster_list *list)
315{
316 return cluster_next(&list->head);
317}
318
319static void cluster_list_init(struct swap_cluster_list *list)
320{
321 cluster_set_null(&list->head);
322 cluster_set_null(&list->tail);
323}
324
325static void cluster_list_add_tail(struct swap_cluster_list *list,
326 struct swap_cluster_info *ci,
327 unsigned int idx)
328{
329 if (cluster_list_empty(list)) {
330 cluster_set_next_flag(&list->head, idx, 0);
331 cluster_set_next_flag(&list->tail, idx, 0);
332 } else {
Huang, Ying235b6212017-02-22 15:45:22 -0800333 struct swap_cluster_info *ci_tail;
Huang Ying6b534912016-10-07 16:58:42 -0700334 unsigned int tail = cluster_next(&list->tail);
335
Huang, Ying235b6212017-02-22 15:45:22 -0800336 /*
337 * Nested cluster lock, but both cluster locks are
338 * only acquired when we held swap_info_struct->lock
339 */
340 ci_tail = ci + tail;
341 spin_lock_nested(&ci_tail->lock, SINGLE_DEPTH_NESTING);
342 cluster_set_next(ci_tail, idx);
Huang Ying0ef017d2017-05-03 14:54:36 -0700343 spin_unlock(&ci_tail->lock);
Huang Ying6b534912016-10-07 16:58:42 -0700344 cluster_set_next_flag(&list->tail, idx, 0);
345 }
346}
347
348static unsigned int cluster_list_del_first(struct swap_cluster_list *list,
349 struct swap_cluster_info *ci)
350{
351 unsigned int idx;
352
353 idx = cluster_next(&list->head);
354 if (cluster_next(&list->tail) == idx) {
355 cluster_set_null(&list->head);
356 cluster_set_null(&list->tail);
357 } else
358 cluster_set_next_flag(&list->head,
359 cluster_next(&ci[idx]), 0);
360
361 return idx;
362}
363
Shaohua Li815c2c52013-09-11 14:20:30 -0700364/* Add a cluster to discard list and schedule it to do discard */
365static void swap_cluster_schedule_discard(struct swap_info_struct *si,
366 unsigned int idx)
367{
368 /*
369 * If scan_swap_map() can't find a free cluster, it will check
370 * si->swap_map directly. To make sure the discarding cluster isn't
371 * taken by scan_swap_map(), mark the swap entries bad (occupied). It
372 * will be cleared after discard
373 */
374 memset(si->swap_map + idx * SWAPFILE_CLUSTER,
375 SWAP_MAP_BAD, SWAPFILE_CLUSTER);
376
Huang Ying6b534912016-10-07 16:58:42 -0700377 cluster_list_add_tail(&si->discard_clusters, si->cluster_info, idx);
Shaohua Li815c2c52013-09-11 14:20:30 -0700378
379 schedule_work(&si->discard_work);
380}
381
Huang Ying38d8b4e2017-07-06 15:37:18 -0700382static void __free_cluster(struct swap_info_struct *si, unsigned long idx)
383{
384 struct swap_cluster_info *ci = si->cluster_info;
385
386 cluster_set_flag(ci + idx, CLUSTER_FLAG_FREE);
387 cluster_list_add_tail(&si->free_clusters, ci, idx);
388}
389
Shaohua Li815c2c52013-09-11 14:20:30 -0700390/*
391 * Doing discard actually. After a cluster discard is finished, the cluster
392 * will be added to free cluster list. caller should hold si->lock.
393*/
394static void swap_do_scheduled_discard(struct swap_info_struct *si)
395{
Huang, Ying235b6212017-02-22 15:45:22 -0800396 struct swap_cluster_info *info, *ci;
Shaohua Li815c2c52013-09-11 14:20:30 -0700397 unsigned int idx;
398
399 info = si->cluster_info;
400
Huang Ying6b534912016-10-07 16:58:42 -0700401 while (!cluster_list_empty(&si->discard_clusters)) {
402 idx = cluster_list_del_first(&si->discard_clusters, info);
Shaohua Li815c2c52013-09-11 14:20:30 -0700403 spin_unlock(&si->lock);
404
405 discard_swap_cluster(si, idx * SWAPFILE_CLUSTER,
406 SWAPFILE_CLUSTER);
407
408 spin_lock(&si->lock);
Huang, Ying235b6212017-02-22 15:45:22 -0800409 ci = lock_cluster(si, idx * SWAPFILE_CLUSTER);
Huang Ying38d8b4e2017-07-06 15:37:18 -0700410 __free_cluster(si, idx);
Shaohua Li815c2c52013-09-11 14:20:30 -0700411 memset(si->swap_map + idx * SWAPFILE_CLUSTER,
412 0, SWAPFILE_CLUSTER);
Huang, Ying235b6212017-02-22 15:45:22 -0800413 unlock_cluster(ci);
Shaohua Li815c2c52013-09-11 14:20:30 -0700414 }
415}
416
417static void swap_discard_work(struct work_struct *work)
418{
419 struct swap_info_struct *si;
420
421 si = container_of(work, struct swap_info_struct, discard_work);
422
423 spin_lock(&si->lock);
424 swap_do_scheduled_discard(si);
425 spin_unlock(&si->lock);
426}
427
Huang Ying38d8b4e2017-07-06 15:37:18 -0700428static void alloc_cluster(struct swap_info_struct *si, unsigned long idx)
429{
430 struct swap_cluster_info *ci = si->cluster_info;
431
432 VM_BUG_ON(cluster_list_first(&si->free_clusters) != idx);
433 cluster_list_del_first(&si->free_clusters, ci);
434 cluster_set_count_flag(ci + idx, 0, 0);
435}
436
437static void free_cluster(struct swap_info_struct *si, unsigned long idx)
438{
439 struct swap_cluster_info *ci = si->cluster_info + idx;
440
441 VM_BUG_ON(cluster_count(ci) != 0);
442 /*
443 * If the swap is discardable, prepare discard the cluster
444 * instead of free it immediately. The cluster will be freed
445 * after discard.
446 */
447 if ((si->flags & (SWP_WRITEOK | SWP_PAGE_DISCARD)) ==
448 (SWP_WRITEOK | SWP_PAGE_DISCARD)) {
449 swap_cluster_schedule_discard(si, idx);
450 return;
451 }
452
453 __free_cluster(si, idx);
454}
455
Shaohua Li2a8f9442013-09-11 14:20:28 -0700456/*
457 * The cluster corresponding to page_nr will be used. The cluster will be
458 * removed from free cluster list and its usage counter will be increased.
459 */
460static void inc_cluster_info_page(struct swap_info_struct *p,
461 struct swap_cluster_info *cluster_info, unsigned long page_nr)
462{
463 unsigned long idx = page_nr / SWAPFILE_CLUSTER;
464
465 if (!cluster_info)
466 return;
Huang Ying38d8b4e2017-07-06 15:37:18 -0700467 if (cluster_is_free(&cluster_info[idx]))
468 alloc_cluster(p, idx);
Shaohua Li2a8f9442013-09-11 14:20:28 -0700469
470 VM_BUG_ON(cluster_count(&cluster_info[idx]) >= SWAPFILE_CLUSTER);
471 cluster_set_count(&cluster_info[idx],
472 cluster_count(&cluster_info[idx]) + 1);
473}
474
475/*
476 * The cluster corresponding to page_nr decreases one usage. If the usage
477 * counter becomes 0, which means no page in the cluster is in using, we can
478 * optionally discard the cluster and add it to free cluster list.
479 */
480static void dec_cluster_info_page(struct swap_info_struct *p,
481 struct swap_cluster_info *cluster_info, unsigned long page_nr)
482{
483 unsigned long idx = page_nr / SWAPFILE_CLUSTER;
484
485 if (!cluster_info)
486 return;
487
488 VM_BUG_ON(cluster_count(&cluster_info[idx]) == 0);
489 cluster_set_count(&cluster_info[idx],
490 cluster_count(&cluster_info[idx]) - 1);
491
Huang Ying38d8b4e2017-07-06 15:37:18 -0700492 if (cluster_count(&cluster_info[idx]) == 0)
493 free_cluster(p, idx);
Shaohua Li2a8f9442013-09-11 14:20:28 -0700494}
495
496/*
497 * It's possible scan_swap_map() uses a free cluster in the middle of free
498 * cluster list. Avoiding such abuse to avoid list corruption.
499 */
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700500static bool
501scan_swap_map_ssd_cluster_conflict(struct swap_info_struct *si,
Shaohua Li2a8f9442013-09-11 14:20:28 -0700502 unsigned long offset)
503{
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700504 struct percpu_cluster *percpu_cluster;
505 bool conflict;
506
Shaohua Li2a8f9442013-09-11 14:20:28 -0700507 offset /= SWAPFILE_CLUSTER;
Huang Ying6b534912016-10-07 16:58:42 -0700508 conflict = !cluster_list_empty(&si->free_clusters) &&
509 offset != cluster_list_first(&si->free_clusters) &&
Shaohua Li2a8f9442013-09-11 14:20:28 -0700510 cluster_is_free(&si->cluster_info[offset]);
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700511
512 if (!conflict)
513 return false;
514
515 percpu_cluster = this_cpu_ptr(si->percpu_cluster);
516 cluster_set_null(&percpu_cluster->index);
517 return true;
518}
519
520/*
521 * Try to get a swap entry from current cpu's swap entry pool (a cluster). This
522 * might involve allocating a new cluster for current CPU too.
523 */
Tim Chen36005ba2017-02-22 15:45:33 -0800524static bool scan_swap_map_try_ssd_cluster(struct swap_info_struct *si,
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700525 unsigned long *offset, unsigned long *scan_base)
526{
527 struct percpu_cluster *cluster;
Huang, Ying235b6212017-02-22 15:45:22 -0800528 struct swap_cluster_info *ci;
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700529 bool found_free;
Huang, Ying235b6212017-02-22 15:45:22 -0800530 unsigned long tmp, max;
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700531
532new_cluster:
533 cluster = this_cpu_ptr(si->percpu_cluster);
534 if (cluster_is_null(&cluster->index)) {
Huang Ying6b534912016-10-07 16:58:42 -0700535 if (!cluster_list_empty(&si->free_clusters)) {
536 cluster->index = si->free_clusters.head;
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700537 cluster->next = cluster_next(&cluster->index) *
538 SWAPFILE_CLUSTER;
Huang Ying6b534912016-10-07 16:58:42 -0700539 } else if (!cluster_list_empty(&si->discard_clusters)) {
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700540 /*
541 * we don't have free cluster but have some clusters in
542 * discarding, do discard now and reclaim them
543 */
544 swap_do_scheduled_discard(si);
545 *scan_base = *offset = si->cluster_next;
546 goto new_cluster;
547 } else
Tim Chen36005ba2017-02-22 15:45:33 -0800548 return false;
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700549 }
550
551 found_free = false;
552
553 /*
554 * Other CPUs can use our cluster if they can't find a free cluster,
555 * check if there is still free entry in the cluster
556 */
557 tmp = cluster->next;
Huang, Ying235b6212017-02-22 15:45:22 -0800558 max = min_t(unsigned long, si->max,
559 (cluster_next(&cluster->index) + 1) * SWAPFILE_CLUSTER);
560 if (tmp >= max) {
561 cluster_set_null(&cluster->index);
562 goto new_cluster;
563 }
564 ci = lock_cluster(si, tmp);
565 while (tmp < max) {
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700566 if (!si->swap_map[tmp]) {
567 found_free = true;
568 break;
569 }
570 tmp++;
571 }
Huang, Ying235b6212017-02-22 15:45:22 -0800572 unlock_cluster(ci);
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700573 if (!found_free) {
574 cluster_set_null(&cluster->index);
575 goto new_cluster;
576 }
577 cluster->next = tmp + 1;
578 *offset = tmp;
579 *scan_base = tmp;
Tim Chen36005ba2017-02-22 15:45:33 -0800580 return found_free;
Shaohua Li2a8f9442013-09-11 14:20:28 -0700581}
582
Huang Ying38d8b4e2017-07-06 15:37:18 -0700583static void swap_range_alloc(struct swap_info_struct *si, unsigned long offset,
584 unsigned int nr_entries)
585{
586 unsigned int end = offset + nr_entries - 1;
587
588 if (offset == si->lowest_bit)
589 si->lowest_bit += nr_entries;
590 if (end == si->highest_bit)
591 si->highest_bit -= nr_entries;
592 si->inuse_pages += nr_entries;
593 if (si->inuse_pages == si->pages) {
594 si->lowest_bit = si->max;
595 si->highest_bit = 0;
596 spin_lock(&swap_avail_lock);
597 plist_del(&si->avail_list, &swap_avail_head);
598 spin_unlock(&swap_avail_lock);
599 }
600}
601
602static void swap_range_free(struct swap_info_struct *si, unsigned long offset,
603 unsigned int nr_entries)
604{
605 unsigned long end = offset + nr_entries - 1;
606 void (*swap_slot_free_notify)(struct block_device *, unsigned long);
607
608 if (offset < si->lowest_bit)
609 si->lowest_bit = offset;
610 if (end > si->highest_bit) {
611 bool was_full = !si->highest_bit;
612
613 si->highest_bit = end;
614 if (was_full && (si->flags & SWP_WRITEOK)) {
615 spin_lock(&swap_avail_lock);
616 WARN_ON(!plist_node_empty(&si->avail_list));
617 if (plist_node_empty(&si->avail_list))
618 plist_add(&si->avail_list, &swap_avail_head);
619 spin_unlock(&swap_avail_lock);
620 }
621 }
622 atomic_long_add(nr_entries, &nr_swap_pages);
623 si->inuse_pages -= nr_entries;
624 if (si->flags & SWP_BLKDEV)
625 swap_slot_free_notify =
626 si->bdev->bd_disk->fops->swap_slot_free_notify;
627 else
628 swap_slot_free_notify = NULL;
629 while (offset <= end) {
630 frontswap_invalidate_page(si->type, offset);
631 if (swap_slot_free_notify)
632 swap_slot_free_notify(si->bdev, offset);
633 offset++;
634 }
635}
636
Tim Chen36005ba2017-02-22 15:45:33 -0800637static int scan_swap_map_slots(struct swap_info_struct *si,
638 unsigned char usage, int nr,
639 swp_entry_t slots[])
Linus Torvalds1da177e2005-04-16 15:20:36 -0700640{
Huang, Ying235b6212017-02-22 15:45:22 -0800641 struct swap_cluster_info *ci;
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800642 unsigned long offset;
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800643 unsigned long scan_base;
Hugh Dickins7992fde2009-01-06 14:39:53 -0800644 unsigned long last_in_cluster = 0;
Hugh Dickins048c27f2005-09-03 15:54:40 -0700645 int latency_ration = LATENCY_LIMIT;
Tim Chen36005ba2017-02-22 15:45:33 -0800646 int n_ret = 0;
647
648 if (nr > SWAP_BATCH)
649 nr = SWAP_BATCH;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700650
Hugh Dickins886bb7e2009-01-06 14:39:48 -0800651 /*
Hugh Dickins7dfad412005-09-03 15:54:38 -0700652 * We try to cluster swap pages by allocating them sequentially
653 * in swap. Once we've allocated SWAPFILE_CLUSTER pages this
654 * way, however, we resort to first-free allocation, starting
655 * a new cluster. This prevents us from scattering swap pages
656 * all over the entire swap partition, so that we reduce
657 * overall disk seek times between swap pages. -- sct
658 * But we do now try to find an empty cluster. -Andrea
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800659 * And we let swap pages go all over an SSD partition. Hugh
Hugh Dickins7dfad412005-09-03 15:54:38 -0700660 */
661
Hugh Dickins52b7efdb2005-09-03 15:54:39 -0700662 si->flags += SWP_SCANNING;
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800663 scan_base = offset = si->cluster_next;
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800664
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700665 /* SSD algorithm */
666 if (si->cluster_info) {
Tim Chen36005ba2017-02-22 15:45:33 -0800667 if (scan_swap_map_try_ssd_cluster(si, &offset, &scan_base))
668 goto checks;
669 else
670 goto scan;
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700671 }
672
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800673 if (unlikely(!si->cluster_nr--)) {
674 if (si->pages - si->inuse_pages < SWAPFILE_CLUSTER) {
675 si->cluster_nr = SWAPFILE_CLUSTER - 1;
676 goto checks;
677 }
Shaohua Li2a8f9442013-09-11 14:20:28 -0700678
Shaohua Liec8acf22013-02-22 16:34:38 -0800679 spin_unlock(&si->lock);
Hugh Dickins7dfad412005-09-03 15:54:38 -0700680
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800681 /*
682 * If seek is expensive, start searching for new cluster from
683 * start of partition, to minimize the span of allocated swap.
Chen Yucong50088c42014-06-04 16:10:57 -0700684 * If seek is cheap, that is the SWP_SOLIDSTATE si->cluster_info
685 * case, just handled by scan_swap_map_try_ssd_cluster() above.
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800686 */
Chen Yucong50088c42014-06-04 16:10:57 -0700687 scan_base = offset = si->lowest_bit;
Hugh Dickins7dfad412005-09-03 15:54:38 -0700688 last_in_cluster = offset + SWAPFILE_CLUSTER - 1;
689
690 /* Locate the first empty (unaligned) cluster */
691 for (; last_in_cluster <= si->highest_bit; offset++) {
692 if (si->swap_map[offset])
693 last_in_cluster = offset + SWAPFILE_CLUSTER;
694 else if (offset == last_in_cluster) {
Shaohua Liec8acf22013-02-22 16:34:38 -0800695 spin_lock(&si->lock);
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800696 offset -= SWAPFILE_CLUSTER - 1;
697 si->cluster_next = offset;
698 si->cluster_nr = SWAPFILE_CLUSTER - 1;
699 goto checks;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700700 }
Hugh Dickins048c27f2005-09-03 15:54:40 -0700701 if (unlikely(--latency_ration < 0)) {
702 cond_resched();
703 latency_ration = LATENCY_LIMIT;
704 }
Hugh Dickins7dfad412005-09-03 15:54:38 -0700705 }
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800706
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800707 offset = scan_base;
Shaohua Liec8acf22013-02-22 16:34:38 -0800708 spin_lock(&si->lock);
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800709 si->cluster_nr = SWAPFILE_CLUSTER - 1;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700710 }
Hugh Dickins7dfad412005-09-03 15:54:38 -0700711
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800712checks:
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700713 if (si->cluster_info) {
Tim Chen36005ba2017-02-22 15:45:33 -0800714 while (scan_swap_map_ssd_cluster_conflict(si, offset)) {
715 /* take a break if we already got some slots */
716 if (n_ret)
717 goto done;
718 if (!scan_swap_map_try_ssd_cluster(si, &offset,
719 &scan_base))
720 goto scan;
721 }
Shaohua Liebc2a1a2013-09-11 14:20:32 -0700722 }
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800723 if (!(si->flags & SWP_WRITEOK))
Hugh Dickins52b7efdb2005-09-03 15:54:39 -0700724 goto no_page;
Hugh Dickins7dfad412005-09-03 15:54:38 -0700725 if (!si->highest_bit)
726 goto no_page;
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800727 if (offset > si->highest_bit)
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800728 scan_base = offset = si->lowest_bit;
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700729
Huang, Ying235b6212017-02-22 15:45:22 -0800730 ci = lock_cluster(si, offset);
Hugh Dickinsb73d7fc2010-09-09 16:38:09 -0700731 /* reuse swap entry of cache-only swap if not busy. */
732 if (vm_swap_full() && si->swap_map[offset] == SWAP_HAS_CACHE) {
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700733 int swap_was_freed;
Huang, Ying235b6212017-02-22 15:45:22 -0800734 unlock_cluster(ci);
Shaohua Liec8acf22013-02-22 16:34:38 -0800735 spin_unlock(&si->lock);
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700736 swap_was_freed = __try_to_reclaim_swap(si, offset);
Shaohua Liec8acf22013-02-22 16:34:38 -0800737 spin_lock(&si->lock);
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700738 /* entry was freed successfully, try to use this again */
739 if (swap_was_freed)
740 goto checks;
741 goto scan; /* check next one */
742 }
743
Huang, Ying235b6212017-02-22 15:45:22 -0800744 if (si->swap_map[offset]) {
745 unlock_cluster(ci);
Tim Chen36005ba2017-02-22 15:45:33 -0800746 if (!n_ret)
747 goto scan;
748 else
749 goto done;
Huang, Ying235b6212017-02-22 15:45:22 -0800750 }
Huang Ying2872bb22017-05-03 14:54:39 -0700751 si->swap_map[offset] = usage;
752 inc_cluster_info_page(si, si->cluster_info, offset);
753 unlock_cluster(ci);
Hugh Dickins7dfad412005-09-03 15:54:38 -0700754
Huang Ying38d8b4e2017-07-06 15:37:18 -0700755 swap_range_alloc(si, offset, 1);
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800756 si->cluster_next = offset + 1;
Tim Chen36005ba2017-02-22 15:45:33 -0800757 slots[n_ret++] = swp_entry(si->type, offset);
Hugh Dickins7992fde2009-01-06 14:39:53 -0800758
Tim Chen36005ba2017-02-22 15:45:33 -0800759 /* got enough slots or reach max slots? */
760 if ((n_ret == nr) || (offset >= si->highest_bit))
761 goto done;
762
763 /* search for next available slot */
764
765 /* time to take a break? */
766 if (unlikely(--latency_ration < 0)) {
767 if (n_ret)
768 goto done;
769 spin_unlock(&si->lock);
770 cond_resched();
771 spin_lock(&si->lock);
772 latency_ration = LATENCY_LIMIT;
773 }
774
775 /* try to get more slots in cluster */
776 if (si->cluster_info) {
777 if (scan_swap_map_try_ssd_cluster(si, &offset, &scan_base))
778 goto checks;
779 else
780 goto done;
781 }
782 /* non-ssd case */
783 ++offset;
784
785 /* non-ssd case, still more slots in cluster? */
786 if (si->cluster_nr && !si->swap_map[offset]) {
787 --si->cluster_nr;
788 goto checks;
789 }
790
791done:
792 si->flags -= SWP_SCANNING;
793 return n_ret;
Hugh Dickinsebebbbe2009-01-06 14:39:50 -0800794
795scan:
Shaohua Liec8acf22013-02-22 16:34:38 -0800796 spin_unlock(&si->lock);
Hugh Dickins7dfad412005-09-03 15:54:38 -0700797 while (++offset <= si->highest_bit) {
Hugh Dickins52b7efdb2005-09-03 15:54:39 -0700798 if (!si->swap_map[offset]) {
Shaohua Liec8acf22013-02-22 16:34:38 -0800799 spin_lock(&si->lock);
Hugh Dickins52b7efdb2005-09-03 15:54:39 -0700800 goto checks;
801 }
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700802 if (vm_swap_full() && si->swap_map[offset] == SWAP_HAS_CACHE) {
Shaohua Liec8acf22013-02-22 16:34:38 -0800803 spin_lock(&si->lock);
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700804 goto checks;
805 }
Hugh Dickins048c27f2005-09-03 15:54:40 -0700806 if (unlikely(--latency_ration < 0)) {
807 cond_resched();
808 latency_ration = LATENCY_LIMIT;
809 }
Hugh Dickins7dfad412005-09-03 15:54:38 -0700810 }
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800811 offset = si->lowest_bit;
Jamie Liua5998062014-01-23 15:53:40 -0800812 while (offset < scan_base) {
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800813 if (!si->swap_map[offset]) {
Shaohua Liec8acf22013-02-22 16:34:38 -0800814 spin_lock(&si->lock);
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800815 goto checks;
816 }
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700817 if (vm_swap_full() && si->swap_map[offset] == SWAP_HAS_CACHE) {
Shaohua Liec8acf22013-02-22 16:34:38 -0800818 spin_lock(&si->lock);
KAMEZAWA Hiroyukic9e44412009-06-16 15:32:54 -0700819 goto checks;
820 }
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800821 if (unlikely(--latency_ration < 0)) {
822 cond_resched();
823 latency_ration = LATENCY_LIMIT;
824 }
Jamie Liua5998062014-01-23 15:53:40 -0800825 offset++;
Hugh Dickinsc60aa172009-01-06 14:39:55 -0800826 }
Shaohua Liec8acf22013-02-22 16:34:38 -0800827 spin_lock(&si->lock);
Hugh Dickins7dfad412005-09-03 15:54:38 -0700828
829no_page:
Hugh Dickins52b7efdb2005-09-03 15:54:39 -0700830 si->flags -= SWP_SCANNING;
Tim Chen36005ba2017-02-22 15:45:33 -0800831 return n_ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700832}
833
Huang Ying38d8b4e2017-07-06 15:37:18 -0700834#ifdef CONFIG_THP_SWAP
835static int swap_alloc_cluster(struct swap_info_struct *si, swp_entry_t *slot)
836{
837 unsigned long idx;
838 struct swap_cluster_info *ci;
839 unsigned long offset, i;
840 unsigned char *map;
841
842 if (cluster_list_empty(&si->free_clusters))
843 return 0;
844
845 idx = cluster_list_first(&si->free_clusters);
846 offset = idx * SWAPFILE_CLUSTER;
847 ci = lock_cluster(si, offset);
848 alloc_cluster(si, idx);
849 cluster_set_count_flag(ci, SWAPFILE_CLUSTER, 0);
850
851 map = si->swap_map + offset;
852 for (i = 0; i < SWAPFILE_CLUSTER; i++)
853 map[i] = SWAP_HAS_CACHE;
854 unlock_cluster(ci);
855 swap_range_alloc(si, offset, SWAPFILE_CLUSTER);
856 *slot = swp_entry(si->type, offset);
857
858 return 1;
859}
860
861static void swap_free_cluster(struct swap_info_struct *si, unsigned long idx)
862{
863 unsigned long offset = idx * SWAPFILE_CLUSTER;
864 struct swap_cluster_info *ci;
865
866 ci = lock_cluster(si, offset);
867 cluster_set_count_flag(ci, 0, 0);
868 free_cluster(si, idx);
869 unlock_cluster(ci);
870 swap_range_free(si, offset, SWAPFILE_CLUSTER);
871}
872#else
873static int swap_alloc_cluster(struct swap_info_struct *si, swp_entry_t *slot)
874{
875 VM_WARN_ON_ONCE(1);
876 return 0;
877}
878#endif /* CONFIG_THP_SWAP */
879
Tim Chen36005ba2017-02-22 15:45:33 -0800880static unsigned long scan_swap_map(struct swap_info_struct *si,
881 unsigned char usage)
882{
883 swp_entry_t entry;
884 int n_ret;
885
886 n_ret = scan_swap_map_slots(si, usage, 1, &entry);
887
888 if (n_ret)
889 return swp_offset(entry);
890 else
891 return 0;
892
893}
894
Huang Ying38d8b4e2017-07-06 15:37:18 -0700895int get_swap_pages(int n_goal, bool cluster, swp_entry_t swp_entries[])
Linus Torvalds1da177e2005-04-16 15:20:36 -0700896{
Huang Ying38d8b4e2017-07-06 15:37:18 -0700897 unsigned long nr_pages = cluster ? SWAPFILE_CLUSTER : 1;
Dan Streetmanadfab832014-06-04 16:09:53 -0700898 struct swap_info_struct *si, *next;
Tim Chen36005ba2017-02-22 15:45:33 -0800899 long avail_pgs;
900 int n_ret = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700901
Huang Ying38d8b4e2017-07-06 15:37:18 -0700902 /* Only single cluster request supported */
903 WARN_ON_ONCE(n_goal > 1 && cluster);
904
905 avail_pgs = atomic_long_read(&nr_swap_pages) / nr_pages;
Tim Chen36005ba2017-02-22 15:45:33 -0800906 if (avail_pgs <= 0)
Hugh Dickinsfb4f88d2005-09-03 15:54:37 -0700907 goto noswap;
Tim Chen36005ba2017-02-22 15:45:33 -0800908
909 if (n_goal > SWAP_BATCH)
910 n_goal = SWAP_BATCH;
911
912 if (n_goal > avail_pgs)
913 n_goal = avail_pgs;
914
Huang Ying38d8b4e2017-07-06 15:37:18 -0700915 atomic_long_sub(n_goal * nr_pages, &nr_swap_pages);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700916
Dan Streetman18ab4d42014-06-04 16:09:59 -0700917 spin_lock(&swap_avail_lock);
918
919start_over:
920 plist_for_each_entry_safe(si, next, &swap_avail_head, avail_list) {
921 /* requeue si to after same-priority siblings */
922 plist_requeue(&si->avail_list, &swap_avail_head);
923 spin_unlock(&swap_avail_lock);
Shaohua Liec8acf22013-02-22 16:34:38 -0800924 spin_lock(&si->lock);
Dan Streetmanadfab832014-06-04 16:09:53 -0700925 if (!si->highest_bit || !(si->flags & SWP_WRITEOK)) {
Dan Streetman18ab4d42014-06-04 16:09:59 -0700926 spin_lock(&swap_avail_lock);
927 if (plist_node_empty(&si->avail_list)) {
928 spin_unlock(&si->lock);
929 goto nextsi;
930 }
931 WARN(!si->highest_bit,
932 "swap_info %d in list but !highest_bit\n",
933 si->type);
934 WARN(!(si->flags & SWP_WRITEOK),
935 "swap_info %d in list but !SWP_WRITEOK\n",
936 si->type);
937 plist_del(&si->avail_list, &swap_avail_head);
Shaohua Liec8acf22013-02-22 16:34:38 -0800938 spin_unlock(&si->lock);
Dan Streetman18ab4d42014-06-04 16:09:59 -0700939 goto nextsi;
Shaohua Liec8acf22013-02-22 16:34:38 -0800940 }
Huang Ying38d8b4e2017-07-06 15:37:18 -0700941 if (cluster)
942 n_ret = swap_alloc_cluster(si, swp_entries);
943 else
944 n_ret = scan_swap_map_slots(si, SWAP_HAS_CACHE,
945 n_goal, swp_entries);
Shaohua Liec8acf22013-02-22 16:34:38 -0800946 spin_unlock(&si->lock);
Huang Ying38d8b4e2017-07-06 15:37:18 -0700947 if (n_ret || cluster)
Tim Chen36005ba2017-02-22 15:45:33 -0800948 goto check_out;
Dan Streetman18ab4d42014-06-04 16:09:59 -0700949 pr_debug("scan_swap_map of si %d failed to find offset\n",
Tim Chen36005ba2017-02-22 15:45:33 -0800950 si->type);
951
Dan Streetman18ab4d42014-06-04 16:09:59 -0700952 spin_lock(&swap_avail_lock);
953nextsi:
Dan Streetmanadfab832014-06-04 16:09:53 -0700954 /*
955 * if we got here, it's likely that si was almost full before,
956 * and since scan_swap_map() can drop the si->lock, multiple
957 * callers probably all tried to get a page from the same si
Dan Streetman18ab4d42014-06-04 16:09:59 -0700958 * and it filled up before we could get one; or, the si filled
959 * up between us dropping swap_avail_lock and taking si->lock.
960 * Since we dropped the swap_avail_lock, the swap_avail_head
961 * list may have been modified; so if next is still in the
Tim Chen36005ba2017-02-22 15:45:33 -0800962 * swap_avail_head list then try it, otherwise start over
963 * if we have not gotten any slots.
Dan Streetmanadfab832014-06-04 16:09:53 -0700964 */
Dan Streetman18ab4d42014-06-04 16:09:59 -0700965 if (plist_node_empty(&next->avail_list))
966 goto start_over;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700967 }
Hugh Dickinsfb4f88d2005-09-03 15:54:37 -0700968
Dan Streetman18ab4d42014-06-04 16:09:59 -0700969 spin_unlock(&swap_avail_lock);
970
Tim Chen36005ba2017-02-22 15:45:33 -0800971check_out:
972 if (n_ret < n_goal)
Huang Ying38d8b4e2017-07-06 15:37:18 -0700973 atomic_long_add((long)(n_goal - n_ret) * nr_pages,
974 &nr_swap_pages);
Hugh Dickinsfb4f88d2005-09-03 15:54:37 -0700975noswap:
Tim Chen36005ba2017-02-22 15:45:33 -0800976 return n_ret;
977}
978
Seth Jennings2de1a7e2013-11-12 15:07:46 -0800979/* The only caller of this function is now suspend routine */
Hugh Dickins910321e2010-09-09 16:38:07 -0700980swp_entry_t get_swap_page_of_type(int type)
981{
982 struct swap_info_struct *si;
983 pgoff_t offset;
984
Hugh Dickins910321e2010-09-09 16:38:07 -0700985 si = swap_info[type];
Shaohua Liec8acf22013-02-22 16:34:38 -0800986 spin_lock(&si->lock);
Hugh Dickins910321e2010-09-09 16:38:07 -0700987 if (si && (si->flags & SWP_WRITEOK)) {
Shaohua Liec8acf22013-02-22 16:34:38 -0800988 atomic_long_dec(&nr_swap_pages);
Hugh Dickins910321e2010-09-09 16:38:07 -0700989 /* This is called for allocating swap entry, not cache */
990 offset = scan_swap_map(si, 1);
991 if (offset) {
Shaohua Liec8acf22013-02-22 16:34:38 -0800992 spin_unlock(&si->lock);
Hugh Dickins910321e2010-09-09 16:38:07 -0700993 return swp_entry(type, offset);
994 }
Shaohua Liec8acf22013-02-22 16:34:38 -0800995 atomic_long_inc(&nr_swap_pages);
Hugh Dickins910321e2010-09-09 16:38:07 -0700996 }
Shaohua Liec8acf22013-02-22 16:34:38 -0800997 spin_unlock(&si->lock);
Hugh Dickins910321e2010-09-09 16:38:07 -0700998 return (swp_entry_t) {0};
999}
1000
Tim Chene8c26ab2017-02-22 15:45:29 -08001001static struct swap_info_struct *__swap_info_get(swp_entry_t entry)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001002{
Hugh Dickins73c34b62009-12-14 17:58:43 -08001003 struct swap_info_struct *p;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001004 unsigned long offset, type;
1005
1006 if (!entry.val)
1007 goto out;
1008 type = swp_type(entry);
1009 if (type >= nr_swapfiles)
1010 goto bad_nofile;
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001011 p = swap_info[type];
Linus Torvalds1da177e2005-04-16 15:20:36 -07001012 if (!(p->flags & SWP_USED))
1013 goto bad_device;
1014 offset = swp_offset(entry);
1015 if (offset >= p->max)
1016 goto bad_offset;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001017 return p;
1018
Linus Torvalds1da177e2005-04-16 15:20:36 -07001019bad_offset:
Huang, Ying6a991fc2017-02-22 15:45:19 -08001020 pr_err("swap_info_get: %s%08lx\n", Bad_offset, entry.val);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001021 goto out;
1022bad_device:
Huang, Ying6a991fc2017-02-22 15:45:19 -08001023 pr_err("swap_info_get: %s%08lx\n", Unused_file, entry.val);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001024 goto out;
1025bad_nofile:
Huang, Ying6a991fc2017-02-22 15:45:19 -08001026 pr_err("swap_info_get: %s%08lx\n", Bad_file, entry.val);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001027out:
1028 return NULL;
Hugh Dickins886bb7e2009-01-06 14:39:48 -08001029}
Linus Torvalds1da177e2005-04-16 15:20:36 -07001030
Tim Chene8c26ab2017-02-22 15:45:29 -08001031static struct swap_info_struct *_swap_info_get(swp_entry_t entry)
1032{
1033 struct swap_info_struct *p;
1034
1035 p = __swap_info_get(entry);
1036 if (!p)
1037 goto out;
1038 if (!p->swap_map[swp_offset(entry)])
1039 goto bad_free;
1040 return p;
1041
1042bad_free:
1043 pr_err("swap_info_get: %s%08lx\n", Unused_offset, entry.val);
1044 goto out;
1045out:
1046 return NULL;
1047}
1048
Huang, Ying235b6212017-02-22 15:45:22 -08001049static struct swap_info_struct *swap_info_get(swp_entry_t entry)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001050{
Huang, Ying235b6212017-02-22 15:45:22 -08001051 struct swap_info_struct *p;
1052
1053 p = _swap_info_get(entry);
1054 if (p)
1055 spin_lock(&p->lock);
1056 return p;
1057}
1058
Tim Chen7c00baf2017-02-22 15:45:36 -08001059static struct swap_info_struct *swap_info_get_cont(swp_entry_t entry,
1060 struct swap_info_struct *q)
1061{
1062 struct swap_info_struct *p;
1063
1064 p = _swap_info_get(entry);
1065
1066 if (p != q) {
1067 if (q != NULL)
1068 spin_unlock(&q->lock);
1069 if (p != NULL)
1070 spin_lock(&p->lock);
1071 }
1072 return p;
1073}
1074
1075static unsigned char __swap_entry_free(struct swap_info_struct *p,
1076 swp_entry_t entry, unsigned char usage)
Huang, Ying235b6212017-02-22 15:45:22 -08001077{
1078 struct swap_cluster_info *ci;
Hugh Dickins253d5532009-12-14 17:58:44 -08001079 unsigned long offset = swp_offset(entry);
Hugh Dickins8d69aae2009-12-14 17:58:45 -08001080 unsigned char count;
1081 unsigned char has_cache;
Huang, Ying235b6212017-02-22 15:45:22 -08001082
Tim Chen7c00baf2017-02-22 15:45:36 -08001083 ci = lock_cluster_or_swap_info(p, offset);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001084
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07001085 count = p->swap_map[offset];
Huang, Ying235b6212017-02-22 15:45:22 -08001086
Hugh Dickins253d5532009-12-14 17:58:44 -08001087 has_cache = count & SWAP_HAS_CACHE;
1088 count &= ~SWAP_HAS_CACHE;
1089
1090 if (usage == SWAP_HAS_CACHE) {
1091 VM_BUG_ON(!has_cache);
1092 has_cache = 0;
Hugh Dickinsaaa46862009-12-14 17:58:47 -08001093 } else if (count == SWAP_MAP_SHMEM) {
1094 /*
1095 * Or we could insist on shmem.c using a special
1096 * swap_shmem_free() and free_shmem_swap_and_cache()...
1097 */
1098 count = 0;
Hugh Dickins570a335b2009-12-14 17:58:46 -08001099 } else if ((count & ~COUNT_CONTINUED) <= SWAP_MAP_MAX) {
1100 if (count == COUNT_CONTINUED) {
1101 if (swap_count_continued(p, offset, count))
1102 count = SWAP_MAP_MAX | COUNT_CONTINUED;
1103 else
1104 count = SWAP_MAP_MAX;
1105 } else
1106 count--;
1107 }
Hugh Dickins253d5532009-12-14 17:58:44 -08001108
Hugh Dickins253d5532009-12-14 17:58:44 -08001109 usage = count | has_cache;
Tim Chen7c00baf2017-02-22 15:45:36 -08001110 p->swap_map[offset] = usage ? : SWAP_HAS_CACHE;
Hugh Dickins253d5532009-12-14 17:58:44 -08001111
Tim Chen7c00baf2017-02-22 15:45:36 -08001112 unlock_cluster_or_swap_info(p, ci);
Huang, Ying235b6212017-02-22 15:45:22 -08001113
Hugh Dickins253d5532009-12-14 17:58:44 -08001114 return usage;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001115}
1116
Tim Chen7c00baf2017-02-22 15:45:36 -08001117static void swap_entry_free(struct swap_info_struct *p, swp_entry_t entry)
1118{
1119 struct swap_cluster_info *ci;
1120 unsigned long offset = swp_offset(entry);
1121 unsigned char count;
1122
1123 ci = lock_cluster(p, offset);
1124 count = p->swap_map[offset];
1125 VM_BUG_ON(count != SWAP_HAS_CACHE);
1126 p->swap_map[offset] = 0;
1127 dec_cluster_info_page(p, p->cluster_info, offset);
1128 unlock_cluster(ci);
1129
Huang Ying38d8b4e2017-07-06 15:37:18 -07001130 mem_cgroup_uncharge_swap(entry, 1);
1131 swap_range_free(p, offset, 1);
Tim Chen7c00baf2017-02-22 15:45:36 -08001132}
1133
Linus Torvalds1da177e2005-04-16 15:20:36 -07001134/*
Seth Jennings2de1a7e2013-11-12 15:07:46 -08001135 * Caller has made sure that the swap device corresponding to entry
Linus Torvalds1da177e2005-04-16 15:20:36 -07001136 * is still around or has not been recycled.
1137 */
1138void swap_free(swp_entry_t entry)
1139{
Hugh Dickins73c34b62009-12-14 17:58:43 -08001140 struct swap_info_struct *p;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001141
Huang, Ying235b6212017-02-22 15:45:22 -08001142 p = _swap_info_get(entry);
Tim Chen7c00baf2017-02-22 15:45:36 -08001143 if (p) {
1144 if (!__swap_entry_free(p, entry, 1))
Tim Chen67afa382017-02-22 15:45:39 -08001145 free_swap_slot(entry);
Tim Chen7c00baf2017-02-22 15:45:36 -08001146 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001147}
1148
1149/*
KAMEZAWA Hiroyukicb4b86b2009-06-16 15:32:52 -07001150 * Called after dropping swapcache to decrease refcnt to swap entries.
1151 */
Minchan Kim75f6d6d2017-07-06 15:37:21 -07001152static void swapcache_free(swp_entry_t entry)
KAMEZAWA Hiroyukicb4b86b2009-06-16 15:32:52 -07001153{
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07001154 struct swap_info_struct *p;
1155
Huang, Ying235b6212017-02-22 15:45:22 -08001156 p = _swap_info_get(entry);
Tim Chen7c00baf2017-02-22 15:45:36 -08001157 if (p) {
1158 if (!__swap_entry_free(p, entry, SWAP_HAS_CACHE))
Tim Chen67afa382017-02-22 15:45:39 -08001159 free_swap_slot(entry);
Tim Chen7c00baf2017-02-22 15:45:36 -08001160 }
1161}
1162
Huang Ying38d8b4e2017-07-06 15:37:18 -07001163#ifdef CONFIG_THP_SWAP
Minchan Kim75f6d6d2017-07-06 15:37:21 -07001164static void swapcache_free_cluster(swp_entry_t entry)
Huang Ying38d8b4e2017-07-06 15:37:18 -07001165{
1166 unsigned long offset = swp_offset(entry);
1167 unsigned long idx = offset / SWAPFILE_CLUSTER;
1168 struct swap_cluster_info *ci;
1169 struct swap_info_struct *si;
1170 unsigned char *map;
Huang Yinga3aea832017-09-06 16:22:12 -07001171 unsigned int i, free_entries = 0;
1172 unsigned char val;
Huang Ying38d8b4e2017-07-06 15:37:18 -07001173
Huang Yinga3aea832017-09-06 16:22:12 -07001174 si = _swap_info_get(entry);
Huang Ying38d8b4e2017-07-06 15:37:18 -07001175 if (!si)
1176 return;
1177
1178 ci = lock_cluster(si, offset);
1179 map = si->swap_map + offset;
1180 for (i = 0; i < SWAPFILE_CLUSTER; i++) {
Huang Yinga3aea832017-09-06 16:22:12 -07001181 val = map[i];
1182 VM_BUG_ON(!(val & SWAP_HAS_CACHE));
1183 if (val == SWAP_HAS_CACHE)
1184 free_entries++;
1185 }
1186 if (!free_entries) {
1187 for (i = 0; i < SWAPFILE_CLUSTER; i++)
1188 map[i] &= ~SWAP_HAS_CACHE;
Huang Ying38d8b4e2017-07-06 15:37:18 -07001189 }
1190 unlock_cluster(ci);
Huang Yinga3aea832017-09-06 16:22:12 -07001191 if (free_entries == SWAPFILE_CLUSTER) {
1192 spin_lock(&si->lock);
1193 ci = lock_cluster(si, offset);
1194 memset(map, 0, SWAPFILE_CLUSTER);
1195 unlock_cluster(ci);
1196 mem_cgroup_uncharge_swap(entry, SWAPFILE_CLUSTER);
1197 swap_free_cluster(si, idx);
1198 spin_unlock(&si->lock);
1199 } else if (free_entries) {
1200 for (i = 0; i < SWAPFILE_CLUSTER; i++, entry.val++) {
1201 if (!__swap_entry_free(si, entry, SWAP_HAS_CACHE))
1202 free_swap_slot(entry);
1203 }
1204 }
Huang Ying38d8b4e2017-07-06 15:37:18 -07001205}
Minchan Kim75f6d6d2017-07-06 15:37:21 -07001206#else
1207static inline void swapcache_free_cluster(swp_entry_t entry)
1208{
1209}
Huang Ying38d8b4e2017-07-06 15:37:18 -07001210#endif /* CONFIG_THP_SWAP */
1211
Minchan Kim75f6d6d2017-07-06 15:37:21 -07001212void put_swap_page(struct page *page, swp_entry_t entry)
1213{
1214 if (!PageTransHuge(page))
1215 swapcache_free(entry);
1216 else
1217 swapcache_free_cluster(entry);
1218}
1219
Huang Ying155b5f82017-07-06 15:40:31 -07001220static int swp_entry_cmp(const void *ent1, const void *ent2)
1221{
1222 const swp_entry_t *e1 = ent1, *e2 = ent2;
1223
1224 return (int)swp_type(*e1) - (int)swp_type(*e2);
1225}
1226
Tim Chen7c00baf2017-02-22 15:45:36 -08001227void swapcache_free_entries(swp_entry_t *entries, int n)
1228{
1229 struct swap_info_struct *p, *prev;
1230 int i;
1231
1232 if (n <= 0)
1233 return;
1234
1235 prev = NULL;
1236 p = NULL;
Huang Ying155b5f82017-07-06 15:40:31 -07001237
1238 /*
1239 * Sort swap entries by swap device, so each lock is only taken once.
1240 * nr_swapfiles isn't absolutely correct, but the overhead of sort() is
1241 * so low that it isn't necessary to optimize further.
1242 */
1243 if (nr_swapfiles > 1)
1244 sort(entries, n, sizeof(entries[0]), swp_entry_cmp, NULL);
Tim Chen7c00baf2017-02-22 15:45:36 -08001245 for (i = 0; i < n; ++i) {
1246 p = swap_info_get_cont(entries[i], prev);
1247 if (p)
1248 swap_entry_free(p, entries[i]);
Tim Chen7c00baf2017-02-22 15:45:36 -08001249 prev = p;
1250 }
Huang, Ying235b6212017-02-22 15:45:22 -08001251 if (p)
Tim Chen7c00baf2017-02-22 15:45:36 -08001252 spin_unlock(&p->lock);
KAMEZAWA Hiroyukicb4b86b2009-06-16 15:32:52 -07001253}
1254
1255/*
Hugh Dickinsc475a8a2005-06-21 17:15:12 -07001256 * How many references to page are currently swapped out?
Hugh Dickins570a335b2009-12-14 17:58:46 -08001257 * This does not give an exact answer when swap count is continued,
1258 * but does include the high COUNT_CONTINUED flag to allow for that.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001259 */
Hugh Dickinsbde05d12012-05-29 15:06:38 -07001260int page_swapcount(struct page *page)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001261{
Hugh Dickinsc475a8a2005-06-21 17:15:12 -07001262 int count = 0;
1263 struct swap_info_struct *p;
Huang, Ying235b6212017-02-22 15:45:22 -08001264 struct swap_cluster_info *ci;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001265 swp_entry_t entry;
Huang, Ying235b6212017-02-22 15:45:22 -08001266 unsigned long offset;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001267
Hugh Dickins4c21e2f2005-10-29 18:16:40 -07001268 entry.val = page_private(page);
Huang, Ying235b6212017-02-22 15:45:22 -08001269 p = _swap_info_get(entry);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001270 if (p) {
Huang, Ying235b6212017-02-22 15:45:22 -08001271 offset = swp_offset(entry);
1272 ci = lock_cluster_or_swap_info(p, offset);
1273 count = swap_count(p->swap_map[offset]);
1274 unlock_cluster_or_swap_info(p, ci);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001275 }
Hugh Dickinsc475a8a2005-06-21 17:15:12 -07001276 return count;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001277}
1278
Huang Ying322b8afe2017-05-03 14:52:49 -07001279static int swap_swapcount(struct swap_info_struct *si, swp_entry_t entry)
1280{
1281 int count = 0;
1282 pgoff_t offset = swp_offset(entry);
1283 struct swap_cluster_info *ci;
1284
1285 ci = lock_cluster_or_swap_info(si, offset);
1286 count = swap_count(si->swap_map[offset]);
1287 unlock_cluster_or_swap_info(si, ci);
1288 return count;
1289}
1290
Linus Torvalds1da177e2005-04-16 15:20:36 -07001291/*
Minchan Kim8334b962015-09-08 15:00:24 -07001292 * How many references to @entry are currently swapped out?
Tim Chene8c26ab2017-02-22 15:45:29 -08001293 * This does not give an exact answer when swap count is continued,
1294 * but does include the high COUNT_CONTINUED flag to allow for that.
1295 */
1296int __swp_swapcount(swp_entry_t entry)
1297{
1298 int count = 0;
Tim Chene8c26ab2017-02-22 15:45:29 -08001299 struct swap_info_struct *si;
Tim Chene8c26ab2017-02-22 15:45:29 -08001300
1301 si = __swap_info_get(entry);
Huang Ying322b8afe2017-05-03 14:52:49 -07001302 if (si)
1303 count = swap_swapcount(si, entry);
Tim Chene8c26ab2017-02-22 15:45:29 -08001304 return count;
1305}
1306
1307/*
1308 * How many references to @entry are currently swapped out?
Minchan Kim8334b962015-09-08 15:00:24 -07001309 * This considers COUNT_CONTINUED so it returns exact answer.
1310 */
1311int swp_swapcount(swp_entry_t entry)
1312{
1313 int count, tmp_count, n;
1314 struct swap_info_struct *p;
Huang, Ying235b6212017-02-22 15:45:22 -08001315 struct swap_cluster_info *ci;
Minchan Kim8334b962015-09-08 15:00:24 -07001316 struct page *page;
1317 pgoff_t offset;
1318 unsigned char *map;
1319
Huang, Ying235b6212017-02-22 15:45:22 -08001320 p = _swap_info_get(entry);
Minchan Kim8334b962015-09-08 15:00:24 -07001321 if (!p)
1322 return 0;
1323
Huang, Ying235b6212017-02-22 15:45:22 -08001324 offset = swp_offset(entry);
1325
1326 ci = lock_cluster_or_swap_info(p, offset);
1327
1328 count = swap_count(p->swap_map[offset]);
Minchan Kim8334b962015-09-08 15:00:24 -07001329 if (!(count & COUNT_CONTINUED))
1330 goto out;
1331
1332 count &= ~COUNT_CONTINUED;
1333 n = SWAP_MAP_MAX + 1;
1334
Minchan Kim8334b962015-09-08 15:00:24 -07001335 page = vmalloc_to_page(p->swap_map + offset);
1336 offset &= ~PAGE_MASK;
1337 VM_BUG_ON(page_private(page) != SWP_CONTINUED);
1338
1339 do {
Geliang Tanga8ae4992016-01-14 15:20:45 -08001340 page = list_next_entry(page, lru);
Minchan Kim8334b962015-09-08 15:00:24 -07001341 map = kmap_atomic(page);
1342 tmp_count = map[offset];
1343 kunmap_atomic(map);
1344
1345 count += (tmp_count & ~COUNT_CONTINUED) * n;
1346 n *= (SWAP_CONT_MAX + 1);
1347 } while (tmp_count & COUNT_CONTINUED);
1348out:
Huang, Ying235b6212017-02-22 15:45:22 -08001349 unlock_cluster_or_swap_info(p, ci);
Minchan Kim8334b962015-09-08 15:00:24 -07001350 return count;
1351}
1352
1353/*
Hugh Dickins7b1fe592009-01-06 14:39:34 -08001354 * We can write to an anon page without COW if there are no other references
1355 * to it. And as a side-effect, free up its swap: because the old content
1356 * on disk will never be read, and seeking back there to write new content
1357 * later would only waste time away from clustering.
Andrea Arcangeli6d0a07e2016-05-12 15:42:25 -07001358 *
1359 * NOTE: total_mapcount should not be relied upon by the caller if
1360 * reuse_swap_page() returns false, but it may be always overwritten
1361 * (see the other implementation for CONFIG_SWAP=n).
Linus Torvalds1da177e2005-04-16 15:20:36 -07001362 */
Andrea Arcangeli6d0a07e2016-05-12 15:42:25 -07001363bool reuse_swap_page(struct page *page, int *total_mapcount)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001364{
Hugh Dickinsc475a8a2005-06-21 17:15:12 -07001365 int count;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001366
Sasha Levin309381fea2014-01-23 15:52:54 -08001367 VM_BUG_ON_PAGE(!PageLocked(page), page);
Hugh Dickins5ad64682009-12-14 17:59:24 -08001368 if (unlikely(PageKsm(page)))
Andrea Arcangeli6d0a07e2016-05-12 15:42:25 -07001369 return false;
1370 count = page_trans_huge_mapcount(page, total_mapcount);
Hugh Dickins7b1fe592009-01-06 14:39:34 -08001371 if (count <= 1 && PageSwapCache(page)) {
Hugh Dickinsc475a8a2005-06-21 17:15:12 -07001372 count += page_swapcount(page);
Minchan Kimf0571422017-01-10 16:58:15 -08001373 if (count != 1)
1374 goto out;
1375 if (!PageWriteback(page)) {
Hugh Dickins7b1fe592009-01-06 14:39:34 -08001376 delete_from_swap_cache(page);
1377 SetPageDirty(page);
Minchan Kimf0571422017-01-10 16:58:15 -08001378 } else {
1379 swp_entry_t entry;
1380 struct swap_info_struct *p;
1381
1382 entry.val = page_private(page);
1383 p = swap_info_get(entry);
1384 if (p->flags & SWP_STABLE_WRITES) {
1385 spin_unlock(&p->lock);
1386 return false;
1387 }
1388 spin_unlock(&p->lock);
Hugh Dickins7b1fe592009-01-06 14:39:34 -08001389 }
1390 }
Minchan Kimf0571422017-01-10 16:58:15 -08001391out:
Hugh Dickins5ad64682009-12-14 17:59:24 -08001392 return count <= 1;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001393}
1394
1395/*
Hugh Dickinsa2c43ee2009-01-06 14:39:36 -08001396 * If swap is getting full, or if there are no more mappings of this page,
1397 * then try_to_free_swap is called to free its swap space.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001398 */
Hugh Dickinsa2c43ee2009-01-06 14:39:36 -08001399int try_to_free_swap(struct page *page)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001400{
Sasha Levin309381fea2014-01-23 15:52:54 -08001401 VM_BUG_ON_PAGE(!PageLocked(page), page);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001402
1403 if (!PageSwapCache(page))
1404 return 0;
1405 if (PageWriteback(page))
1406 return 0;
Hugh Dickinsa2c43ee2009-01-06 14:39:36 -08001407 if (page_swapcount(page))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001408 return 0;
1409
Hugh Dickinsb73d7fc2010-09-09 16:38:09 -07001410 /*
1411 * Once hibernation has begun to create its image of memory,
1412 * there's a danger that one of the calls to try_to_free_swap()
1413 * - most probably a call from __try_to_reclaim_swap() while
1414 * hibernation is allocating its own swap pages for the image,
1415 * but conceivably even a call from memory reclaim - will free
1416 * the swap from a page which has already been recorded in the
1417 * image as a clean swapcache page, and then reuse its swap for
1418 * another page of the image. On waking from hibernation, the
1419 * original page might be freed under memory pressure, then
1420 * later read back in from swap, now with the wrong data.
1421 *
Seth Jennings2de1a7e2013-11-12 15:07:46 -08001422 * Hibernation suspends storage while it is writing the image
Mel Gormanf90ac392012-01-10 15:07:15 -08001423 * to disk so check that here.
Hugh Dickinsb73d7fc2010-09-09 16:38:09 -07001424 */
Mel Gormanf90ac392012-01-10 15:07:15 -08001425 if (pm_suspended_storage())
Hugh Dickinsb73d7fc2010-09-09 16:38:09 -07001426 return 0;
1427
Hugh Dickinsa2c43ee2009-01-06 14:39:36 -08001428 delete_from_swap_cache(page);
1429 SetPageDirty(page);
1430 return 1;
Rik van Riel68a223942008-10-18 20:26:23 -07001431}
1432
1433/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07001434 * Free the swap entry like above, but also try to
1435 * free the page cache entry if it is the last user.
1436 */
Hugh Dickins2509ef22009-01-06 14:40:10 -08001437int free_swap_and_cache(swp_entry_t entry)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001438{
Hugh Dickins2509ef22009-01-06 14:40:10 -08001439 struct swap_info_struct *p;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001440 struct page *page = NULL;
Tim Chen7c00baf2017-02-22 15:45:36 -08001441 unsigned char count;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001442
Andi Kleena7420aa2009-09-16 11:50:05 +02001443 if (non_swap_entry(entry))
Hugh Dickins2509ef22009-01-06 14:40:10 -08001444 return 1;
Christoph Lameter06972122006-06-23 02:03:35 -07001445
Tim Chen7c00baf2017-02-22 15:45:36 -08001446 p = _swap_info_get(entry);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001447 if (p) {
Tim Chen7c00baf2017-02-22 15:45:36 -08001448 count = __swap_entry_free(p, entry, 1);
1449 if (count == SWAP_HAS_CACHE) {
Shaohua Li33806f02013-02-22 16:34:37 -08001450 page = find_get_page(swap_address_space(entry),
Huang Yingf6ab1f72016-10-07 17:00:21 -07001451 swp_offset(entry));
Nick Piggin8413ac92008-10-18 20:26:59 -07001452 if (page && !trylock_page(page)) {
Kirill A. Shutemov09cbfea2016-04-01 15:29:47 +03001453 put_page(page);
Nick Piggin93fac702006-03-31 02:29:56 -08001454 page = NULL;
1455 }
Tim Chen7c00baf2017-02-22 15:45:36 -08001456 } else if (!count)
Tim Chen67afa382017-02-22 15:45:39 -08001457 free_swap_slot(entry);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001458 }
1459 if (page) {
Hugh Dickinsa2c43ee2009-01-06 14:39:36 -08001460 /*
1461 * Not mapped elsewhere, or swap space full? Free it!
1462 * Also recheck PageSwapCache now page is locked (above).
1463 */
Nick Piggin93fac702006-03-31 02:29:56 -08001464 if (PageSwapCache(page) && !PageWriteback(page) &&
Huang Ying322b8afe2017-05-03 14:52:49 -07001465 (!page_mapped(page) || mem_cgroup_swap_full(page)) &&
1466 !swap_swapcount(p, entry)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001467 delete_from_swap_cache(page);
1468 SetPageDirty(page);
1469 }
1470 unlock_page(page);
Kirill A. Shutemov09cbfea2016-04-01 15:29:47 +03001471 put_page(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001472 }
Hugh Dickins2509ef22009-01-06 14:40:10 -08001473 return p != NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001474}
1475
Rafael J. Wysockib0cb1a12007-07-29 23:24:36 +02001476#ifdef CONFIG_HIBERNATION
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001477/*
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001478 * Find the swap type that corresponds to given device (if any).
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001479 *
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001480 * @offset - number of the PAGE_SIZE-sized block of the device, starting
1481 * from 0, in which the swap header is expected to be located.
1482 *
1483 * This is needed for the suspend to disk (aka swsusp).
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001484 */
Rafael J. Wysocki7bf23682007-01-05 16:36:28 -08001485int swap_type_of(dev_t device, sector_t offset, struct block_device **bdev_p)
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001486{
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001487 struct block_device *bdev = NULL;
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001488 int type;
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001489
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001490 if (device)
1491 bdev = bdget(device);
1492
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001493 spin_lock(&swap_lock);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001494 for (type = 0; type < nr_swapfiles; type++) {
1495 struct swap_info_struct *sis = swap_info[type];
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001496
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001497 if (!(sis->flags & SWP_WRITEOK))
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001498 continue;
Rafael J. Wysockib6b5bce2006-08-27 01:23:25 -07001499
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001500 if (!bdev) {
Rafael J. Wysocki7bf23682007-01-05 16:36:28 -08001501 if (bdev_p)
Alan Jenkinsdddac6a2009-07-29 21:07:55 +02001502 *bdev_p = bdgrab(sis->bdev);
Rafael J. Wysocki7bf23682007-01-05 16:36:28 -08001503
Rafael J. Wysocki6e1819d2006-03-23 03:00:03 -08001504 spin_unlock(&swap_lock);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001505 return type;
Rafael J. Wysocki6e1819d2006-03-23 03:00:03 -08001506 }
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001507 if (bdev == sis->bdev) {
Hugh Dickins9625a5f2009-12-14 17:58:42 -08001508 struct swap_extent *se = &sis->first_swap_extent;
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001509
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001510 if (se->start_block == offset) {
Rafael J. Wysocki7bf23682007-01-05 16:36:28 -08001511 if (bdev_p)
Alan Jenkinsdddac6a2009-07-29 21:07:55 +02001512 *bdev_p = bdgrab(sis->bdev);
Rafael J. Wysocki7bf23682007-01-05 16:36:28 -08001513
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001514 spin_unlock(&swap_lock);
1515 bdput(bdev);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001516 return type;
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001517 }
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001518 }
1519 }
1520 spin_unlock(&swap_lock);
Rafael J. Wysocki915bae92006-12-06 20:34:07 -08001521 if (bdev)
1522 bdput(bdev);
1523
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001524 return -ENODEV;
1525}
1526
1527/*
Hugh Dickins73c34b62009-12-14 17:58:43 -08001528 * Get the (PAGE_SIZE) block corresponding to given offset on the swapdev
1529 * corresponding to given index in swap_info (swap type).
1530 */
1531sector_t swapdev_block(int type, pgoff_t offset)
1532{
1533 struct block_device *bdev;
1534
1535 if ((unsigned int)type >= nr_swapfiles)
1536 return 0;
1537 if (!(swap_info[type]->flags & SWP_WRITEOK))
1538 return 0;
Lee Schermerhornd4906e12009-12-14 17:58:49 -08001539 return map_swap_entry(swp_entry(type, offset), &bdev);
Hugh Dickins73c34b62009-12-14 17:58:43 -08001540}
1541
1542/*
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001543 * Return either the total number of swap pages of given type, or the number
1544 * of free pages of that type (depending on @free)
1545 *
1546 * This is needed for software suspend
1547 */
1548unsigned int count_swap_pages(int type, int free)
1549{
1550 unsigned int n = 0;
1551
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001552 spin_lock(&swap_lock);
1553 if ((unsigned int)type < nr_swapfiles) {
1554 struct swap_info_struct *sis = swap_info[type];
1555
Shaohua Liec8acf22013-02-22 16:34:38 -08001556 spin_lock(&sis->lock);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001557 if (sis->flags & SWP_WRITEOK) {
1558 n = sis->pages;
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001559 if (free)
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001560 n -= sis->inuse_pages;
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001561 }
Shaohua Liec8acf22013-02-22 16:34:38 -08001562 spin_unlock(&sis->lock);
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001563 }
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001564 spin_unlock(&swap_lock);
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001565 return n;
1566}
Hugh Dickins73c34b62009-12-14 17:58:43 -08001567#endif /* CONFIG_HIBERNATION */
Rafael J. Wysockif577eb32006-03-23 02:59:59 -08001568
Hugh Dickins9f8bdb32016-01-15 16:57:34 -08001569static inline int pte_same_as_swp(pte_t pte, pte_t swp_pte)
Cyrill Gorcunov179ef712013-08-13 16:00:49 -07001570{
Hugh Dickins9f8bdb32016-01-15 16:57:34 -08001571 return pte_same(pte_swp_clear_soft_dirty(pte), swp_pte);
Cyrill Gorcunov179ef712013-08-13 16:00:49 -07001572}
1573
Linus Torvalds1da177e2005-04-16 15:20:36 -07001574/*
Hugh Dickins72866f62005-10-29 18:15:55 -07001575 * No need to decide whether this PTE shares the swap entry with others,
1576 * just let do_wp_page work it out if a write is requested later - to
1577 * force COW, vm_page_prot omits write permission from any private vma.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001578 */
Hugh Dickins044d66c2008-02-07 00:14:04 -08001579static int unuse_pte(struct vm_area_struct *vma, pmd_t *pmd,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001580 unsigned long addr, swp_entry_t entry, struct page *page)
1581{
Hugh Dickins9e16b7f2013-02-22 16:36:09 -08001582 struct page *swapcache;
Johannes Weiner72835c82012-01-12 17:18:32 -08001583 struct mem_cgroup *memcg;
Hugh Dickins044d66c2008-02-07 00:14:04 -08001584 spinlock_t *ptl;
1585 pte_t *pte;
1586 int ret = 1;
1587
Hugh Dickins9e16b7f2013-02-22 16:36:09 -08001588 swapcache = page;
1589 page = ksm_might_need_to_copy(page, vma, addr);
1590 if (unlikely(!page))
1591 return -ENOMEM;
1592
Kirill A. Shutemovf627c2f2016-01-15 16:52:20 -08001593 if (mem_cgroup_try_charge(page, vma->vm_mm, GFP_KERNEL,
1594 &memcg, false)) {
Hugh Dickins044d66c2008-02-07 00:14:04 -08001595 ret = -ENOMEM;
KAMEZAWA Hiroyuki85d9fc82009-01-29 14:25:13 -08001596 goto out_nolock;
1597 }
Hugh Dickins044d66c2008-02-07 00:14:04 -08001598
1599 pte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);
Hugh Dickins9f8bdb32016-01-15 16:57:34 -08001600 if (unlikely(!pte_same_as_swp(*pte, swp_entry_to_pte(entry)))) {
Kirill A. Shutemovf627c2f2016-01-15 16:52:20 -08001601 mem_cgroup_cancel_charge(page, memcg, false);
Hugh Dickins044d66c2008-02-07 00:14:04 -08001602 ret = 0;
1603 goto out;
1604 }
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001605
KAMEZAWA Hiroyukib084d432010-03-05 13:41:42 -08001606 dec_mm_counter(vma->vm_mm, MM_SWAPENTS);
KAMEZAWA Hiroyukid559db02010-03-05 13:41:39 -08001607 inc_mm_counter(vma->vm_mm, MM_ANONPAGES);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001608 get_page(page);
1609 set_pte_at(vma->vm_mm, addr, pte,
1610 pte_mkold(mk_pte(page, vma->vm_page_prot)));
Johannes Weiner00501b52014-08-08 14:19:20 -07001611 if (page == swapcache) {
Kirill A. Shutemovd281ee62016-01-15 16:52:16 -08001612 page_add_anon_rmap(page, vma, addr, false);
Kirill A. Shutemovf627c2f2016-01-15 16:52:20 -08001613 mem_cgroup_commit_charge(page, memcg, true, false);
Johannes Weiner00501b52014-08-08 14:19:20 -07001614 } else { /* ksm created a completely new copy */
Kirill A. Shutemovd281ee62016-01-15 16:52:16 -08001615 page_add_new_anon_rmap(page, vma, addr, false);
Kirill A. Shutemovf627c2f2016-01-15 16:52:20 -08001616 mem_cgroup_commit_charge(page, memcg, false, false);
Johannes Weiner00501b52014-08-08 14:19:20 -07001617 lru_cache_add_active_or_unevictable(page, vma);
1618 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001619 swap_free(entry);
1620 /*
1621 * Move the page to the active list so it is not
1622 * immediately swapped out again after swapon.
1623 */
1624 activate_page(page);
Hugh Dickins044d66c2008-02-07 00:14:04 -08001625out:
1626 pte_unmap_unlock(pte, ptl);
KAMEZAWA Hiroyuki85d9fc82009-01-29 14:25:13 -08001627out_nolock:
Hugh Dickins9e16b7f2013-02-22 16:36:09 -08001628 if (page != swapcache) {
1629 unlock_page(page);
1630 put_page(page);
1631 }
Hugh Dickins044d66c2008-02-07 00:14:04 -08001632 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001633}
1634
1635static int unuse_pte_range(struct vm_area_struct *vma, pmd_t *pmd,
1636 unsigned long addr, unsigned long end,
1637 swp_entry_t entry, struct page *page)
1638{
Linus Torvalds1da177e2005-04-16 15:20:36 -07001639 pte_t swp_pte = swp_entry_to_pte(entry);
Hugh Dickins705e87c2005-10-29 18:16:27 -07001640 pte_t *pte;
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001641 int ret = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001642
Hugh Dickins044d66c2008-02-07 00:14:04 -08001643 /*
1644 * We don't actually need pte lock while scanning for swp_pte: since
1645 * we hold page lock and mmap_sem, swp_pte cannot be inserted into the
1646 * page table while we're scanning; though it could get zapped, and on
1647 * some architectures (e.g. x86_32 with PAE) we might catch a glimpse
1648 * of unmatched parts which look like swp_pte, so unuse_pte must
1649 * recheck under pte lock. Scanning without pte lock lets it be
Seth Jennings2de1a7e2013-11-12 15:07:46 -08001650 * preemptable whenever CONFIG_PREEMPT but not CONFIG_HIGHPTE.
Hugh Dickins044d66c2008-02-07 00:14:04 -08001651 */
1652 pte = pte_offset_map(pmd, addr);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001653 do {
1654 /*
1655 * swapoff spends a _lot_ of time in this loop!
1656 * Test inline before going to call unuse_pte.
1657 */
Hugh Dickins9f8bdb32016-01-15 16:57:34 -08001658 if (unlikely(pte_same_as_swp(*pte, swp_pte))) {
Hugh Dickins044d66c2008-02-07 00:14:04 -08001659 pte_unmap(pte);
1660 ret = unuse_pte(vma, pmd, addr, entry, page);
1661 if (ret)
1662 goto out;
1663 pte = pte_offset_map(pmd, addr);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001664 }
1665 } while (pte++, addr += PAGE_SIZE, addr != end);
Hugh Dickins044d66c2008-02-07 00:14:04 -08001666 pte_unmap(pte - 1);
1667out:
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001668 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001669}
1670
1671static inline int unuse_pmd_range(struct vm_area_struct *vma, pud_t *pud,
1672 unsigned long addr, unsigned long end,
1673 swp_entry_t entry, struct page *page)
1674{
1675 pmd_t *pmd;
1676 unsigned long next;
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001677 int ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001678
1679 pmd = pmd_offset(pud, addr);
1680 do {
Hugh Dickinsdc644a02016-12-12 16:44:44 -08001681 cond_resched();
Linus Torvalds1da177e2005-04-16 15:20:36 -07001682 next = pmd_addr_end(addr, end);
Andrea Arcangeli1a5a9902012-03-21 16:33:42 -07001683 if (pmd_none_or_trans_huge_or_clear_bad(pmd))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001684 continue;
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001685 ret = unuse_pte_range(vma, pmd, addr, next, entry, page);
1686 if (ret)
1687 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001688 } while (pmd++, addr = next, addr != end);
1689 return 0;
1690}
1691
Kirill A. Shutemovc2febaf2017-03-09 17:24:07 +03001692static inline int unuse_pud_range(struct vm_area_struct *vma, p4d_t *p4d,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001693 unsigned long addr, unsigned long end,
1694 swp_entry_t entry, struct page *page)
1695{
1696 pud_t *pud;
1697 unsigned long next;
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001698 int ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001699
Kirill A. Shutemovc2febaf2017-03-09 17:24:07 +03001700 pud = pud_offset(p4d, addr);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001701 do {
1702 next = pud_addr_end(addr, end);
1703 if (pud_none_or_clear_bad(pud))
1704 continue;
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001705 ret = unuse_pmd_range(vma, pud, addr, next, entry, page);
1706 if (ret)
1707 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001708 } while (pud++, addr = next, addr != end);
1709 return 0;
1710}
1711
Kirill A. Shutemovc2febaf2017-03-09 17:24:07 +03001712static inline int unuse_p4d_range(struct vm_area_struct *vma, pgd_t *pgd,
1713 unsigned long addr, unsigned long end,
1714 swp_entry_t entry, struct page *page)
1715{
1716 p4d_t *p4d;
1717 unsigned long next;
1718 int ret;
1719
1720 p4d = p4d_offset(pgd, addr);
1721 do {
1722 next = p4d_addr_end(addr, end);
1723 if (p4d_none_or_clear_bad(p4d))
1724 continue;
1725 ret = unuse_pud_range(vma, p4d, addr, next, entry, page);
1726 if (ret)
1727 return ret;
1728 } while (p4d++, addr = next, addr != end);
1729 return 0;
1730}
1731
Linus Torvalds1da177e2005-04-16 15:20:36 -07001732static int unuse_vma(struct vm_area_struct *vma,
1733 swp_entry_t entry, struct page *page)
1734{
1735 pgd_t *pgd;
1736 unsigned long addr, end, next;
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001737 int ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001738
Hugh Dickins3ca7b3c2009-12-14 17:58:57 -08001739 if (page_anon_vma(page)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001740 addr = page_address_in_vma(page, vma);
1741 if (addr == -EFAULT)
1742 return 0;
1743 else
1744 end = addr + PAGE_SIZE;
1745 } else {
1746 addr = vma->vm_start;
1747 end = vma->vm_end;
1748 }
1749
1750 pgd = pgd_offset(vma->vm_mm, addr);
1751 do {
1752 next = pgd_addr_end(addr, end);
1753 if (pgd_none_or_clear_bad(pgd))
1754 continue;
Kirill A. Shutemovc2febaf2017-03-09 17:24:07 +03001755 ret = unuse_p4d_range(vma, pgd, addr, next, entry, page);
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001756 if (ret)
1757 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001758 } while (pgd++, addr = next, addr != end);
1759 return 0;
1760}
1761
1762static int unuse_mm(struct mm_struct *mm,
1763 swp_entry_t entry, struct page *page)
1764{
1765 struct vm_area_struct *vma;
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001766 int ret = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001767
1768 if (!down_read_trylock(&mm->mmap_sem)) {
1769 /*
Fernando Luis Vazquez Cao7d034312008-07-29 22:33:41 -07001770 * Activate page so shrink_inactive_list is unlikely to unmap
1771 * its ptes while lock is dropped, so swapoff can make progress.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001772 */
Hugh Dickinsc475a8a2005-06-21 17:15:12 -07001773 activate_page(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001774 unlock_page(page);
1775 down_read(&mm->mmap_sem);
1776 lock_page(page);
1777 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001778 for (vma = mm->mmap; vma; vma = vma->vm_next) {
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001779 if (vma->anon_vma && (ret = unuse_vma(vma, entry, page)))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001780 break;
Hugh Dickinsdc644a02016-12-12 16:44:44 -08001781 cond_resched();
Linus Torvalds1da177e2005-04-16 15:20:36 -07001782 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07001783 up_read(&mm->mmap_sem);
Balbir Singh8a9f3cc2008-02-07 00:13:53 -08001784 return (ret < 0)? ret: 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001785}
1786
1787/*
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06001788 * Scan swap_map (or frontswap_map if frontswap parameter is true)
1789 * from current position to next entry still in use.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001790 * Recycle to start on reaching the end, returning 0 when empty.
1791 */
Hugh Dickins6eb396d2005-09-03 15:54:35 -07001792static unsigned int find_next_to_unuse(struct swap_info_struct *si,
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06001793 unsigned int prev, bool frontswap)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001794{
Hugh Dickins6eb396d2005-09-03 15:54:35 -07001795 unsigned int max = si->max;
1796 unsigned int i = prev;
Hugh Dickins8d69aae2009-12-14 17:58:45 -08001797 unsigned char count;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001798
1799 /*
Hugh Dickins5d337b92005-09-03 15:54:41 -07001800 * No need for swap_lock here: we're just looking
Linus Torvalds1da177e2005-04-16 15:20:36 -07001801 * for whether an entry is in use, not modifying it; false
1802 * hits are okay, and sys_swapoff() has already prevented new
Hugh Dickins5d337b92005-09-03 15:54:41 -07001803 * allocations from this area (while holding swap_lock).
Linus Torvalds1da177e2005-04-16 15:20:36 -07001804 */
1805 for (;;) {
1806 if (++i >= max) {
1807 if (!prev) {
1808 i = 0;
1809 break;
1810 }
1811 /*
1812 * No entries in use at top of swap_map,
1813 * loop back to start and recheck there.
1814 */
1815 max = prev + 1;
1816 prev = 0;
1817 i = 1;
1818 }
Jason Low4db0c3c2015-04-15 16:14:08 -07001819 count = READ_ONCE(si->swap_map[i]);
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07001820 if (count && swap_count(count) != SWAP_MAP_BAD)
Hugh Dickinsdc644a02016-12-12 16:44:44 -08001821 if (!frontswap || frontswap_test(si, i))
1822 break;
1823 if ((i % LATENCY_LIMIT) == 0)
1824 cond_resched();
Linus Torvalds1da177e2005-04-16 15:20:36 -07001825 }
1826 return i;
1827}
1828
1829/*
1830 * We completely avoid races by reading each swap page in advance,
1831 * and then search for the process using it. All the necessary
1832 * page table adjustments can then be made atomically.
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06001833 *
1834 * if the boolean frontswap is true, only unuse pages_to_unuse pages;
1835 * pages_to_unuse==0 means all pages; ignored if frontswap is false
Linus Torvalds1da177e2005-04-16 15:20:36 -07001836 */
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06001837int try_to_unuse(unsigned int type, bool frontswap,
1838 unsigned long pages_to_unuse)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001839{
Hugh Dickinsefa90a92009-12-14 17:58:41 -08001840 struct swap_info_struct *si = swap_info[type];
Linus Torvalds1da177e2005-04-16 15:20:36 -07001841 struct mm_struct *start_mm;
Shaohua Liedfe23d2013-09-11 14:20:31 -07001842 volatile unsigned char *swap_map; /* swap_map is accessed without
1843 * locking. Mark it as volatile
1844 * to prevent compiler doing
1845 * something odd.
1846 */
Hugh Dickins8d69aae2009-12-14 17:58:45 -08001847 unsigned char swcount;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001848 struct page *page;
1849 swp_entry_t entry;
Hugh Dickins6eb396d2005-09-03 15:54:35 -07001850 unsigned int i = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001851 int retval = 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001852
1853 /*
1854 * When searching mms for an entry, a good strategy is to
1855 * start at the first mm we freed the previous entry from
1856 * (though actually we don't notice whether we or coincidence
1857 * freed the entry). Initialize this start_mm with a hold.
1858 *
1859 * A simpler strategy would be to start at the last mm we
1860 * freed the previous entry from; but that would take less
1861 * advantage of mmlist ordering, which clusters forked mms
1862 * together, child after parent. If we race with dup_mmap(), we
1863 * prefer to resolve parent before child, lest we miss entries
1864 * duplicated after we scanned child: using last mm would invert
Hugh Dickins570a335b2009-12-14 17:58:46 -08001865 * that.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001866 */
1867 start_mm = &init_mm;
Vegard Nossum3fce3712017-02-27 14:30:10 -08001868 mmget(&init_mm);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001869
1870 /*
1871 * Keep on scanning until all entries have gone. Usually,
1872 * one pass through swap_map is enough, but not necessarily:
1873 * there are races when an instance of an entry might be missed.
1874 */
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06001875 while ((i = find_next_to_unuse(si, i, frontswap)) != 0) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001876 if (signal_pending(current)) {
1877 retval = -EINTR;
1878 break;
1879 }
1880
Hugh Dickins886bb7e2009-01-06 14:39:48 -08001881 /*
Linus Torvalds1da177e2005-04-16 15:20:36 -07001882 * Get a page for the entry, using the existing swap
1883 * cache page if there is one. Otherwise, get a clean
Hugh Dickins886bb7e2009-01-06 14:39:48 -08001884 * page and read the swap into it.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001885 */
1886 swap_map = &si->swap_map[i];
1887 entry = swp_entry(type, i);
Hugh Dickins02098fe2008-02-04 22:28:42 -08001888 page = read_swap_cache_async(entry,
Shaohua Li23955622017-07-10 15:47:11 -07001889 GFP_HIGHUSER_MOVABLE, NULL, 0, false);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001890 if (!page) {
1891 /*
1892 * Either swap_duplicate() failed because entry
1893 * has been freed independently, and will not be
1894 * reused since sys_swapoff() already disabled
1895 * allocation from here, or alloc_page() failed.
1896 */
Shaohua Liedfe23d2013-09-11 14:20:31 -07001897 swcount = *swap_map;
1898 /*
1899 * We don't hold lock here, so the swap entry could be
1900 * SWAP_MAP_BAD (when the cluster is discarding).
1901 * Instead of fail out, We can just skip the swap
1902 * entry because swapoff will wait for discarding
1903 * finish anyway.
1904 */
1905 if (!swcount || swcount == SWAP_MAP_BAD)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001906 continue;
1907 retval = -ENOMEM;
1908 break;
1909 }
1910
1911 /*
1912 * Don't hold on to start_mm if it looks like exiting.
1913 */
1914 if (atomic_read(&start_mm->mm_users) == 1) {
1915 mmput(start_mm);
1916 start_mm = &init_mm;
Vegard Nossum3fce3712017-02-27 14:30:10 -08001917 mmget(&init_mm);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001918 }
1919
1920 /*
1921 * Wait for and lock page. When do_swap_page races with
1922 * try_to_unuse, do_swap_page can handle the fault much
1923 * faster than try_to_unuse can locate the entry. This
1924 * apparently redundant "wait_on_page_locked" lets try_to_unuse
1925 * defer to do_swap_page in such a case - in some tests,
1926 * do_swap_page and try_to_unuse repeatedly compete.
1927 */
1928 wait_on_page_locked(page);
1929 wait_on_page_writeback(page);
1930 lock_page(page);
1931 wait_on_page_writeback(page);
1932
1933 /*
1934 * Remove all references to entry.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001935 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001936 swcount = *swap_map;
Hugh Dickinsaaa46862009-12-14 17:58:47 -08001937 if (swap_count(swcount) == SWAP_MAP_SHMEM) {
1938 retval = shmem_unuse(entry, page);
1939 /* page has already been unlocked and released */
1940 if (retval < 0)
1941 break;
1942 continue;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001943 }
Hugh Dickinsaaa46862009-12-14 17:58:47 -08001944 if (swap_count(swcount) && start_mm != &init_mm)
1945 retval = unuse_mm(start_mm, entry, page);
1946
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07001947 if (swap_count(*swap_map)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001948 int set_start_mm = (*swap_map >= swcount);
1949 struct list_head *p = &start_mm->mmlist;
1950 struct mm_struct *new_start_mm = start_mm;
1951 struct mm_struct *prev_mm = start_mm;
1952 struct mm_struct *mm;
1953
Vegard Nossum3fce3712017-02-27 14:30:10 -08001954 mmget(new_start_mm);
1955 mmget(prev_mm);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001956 spin_lock(&mmlist_lock);
Hugh Dickinsaaa46862009-12-14 17:58:47 -08001957 while (swap_count(*swap_map) && !retval &&
Linus Torvalds1da177e2005-04-16 15:20:36 -07001958 (p = p->next) != &start_mm->mmlist) {
1959 mm = list_entry(p, struct mm_struct, mmlist);
Vegard Nossum388f7932017-02-27 14:30:13 -08001960 if (!mmget_not_zero(mm))
Linus Torvalds1da177e2005-04-16 15:20:36 -07001961 continue;
Linus Torvalds1da177e2005-04-16 15:20:36 -07001962 spin_unlock(&mmlist_lock);
1963 mmput(prev_mm);
1964 prev_mm = mm;
1965
1966 cond_resched();
1967
1968 swcount = *swap_map;
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07001969 if (!swap_count(swcount)) /* any usage ? */
Linus Torvalds1da177e2005-04-16 15:20:36 -07001970 ;
Hugh Dickinsaaa46862009-12-14 17:58:47 -08001971 else if (mm == &init_mm)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001972 set_start_mm = 1;
Hugh Dickinsaaa46862009-12-14 17:58:47 -08001973 else
Linus Torvalds1da177e2005-04-16 15:20:36 -07001974 retval = unuse_mm(mm, entry, page);
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07001975
Bo Liu32c5fc12009-11-02 16:50:33 +00001976 if (set_start_mm && *swap_map < swcount) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07001977 mmput(new_start_mm);
Vegard Nossum3fce3712017-02-27 14:30:10 -08001978 mmget(mm);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001979 new_start_mm = mm;
1980 set_start_mm = 0;
1981 }
1982 spin_lock(&mmlist_lock);
1983 }
1984 spin_unlock(&mmlist_lock);
1985 mmput(prev_mm);
1986 mmput(start_mm);
1987 start_mm = new_start_mm;
1988 }
1989 if (retval) {
1990 unlock_page(page);
Kirill A. Shutemov09cbfea2016-04-01 15:29:47 +03001991 put_page(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -07001992 break;
1993 }
1994
1995 /*
Linus Torvalds1da177e2005-04-16 15:20:36 -07001996 * If a reference remains (rare), we would like to leave
1997 * the page in the swap cache; but try_to_unmap could
1998 * then re-duplicate the entry once we drop page lock,
1999 * so we might loop indefinitely; also, that page could
2000 * not be swapped out to other storage meanwhile. So:
2001 * delete from cache even if there's another reference,
2002 * after ensuring that the data has been saved to disk -
2003 * since if the reference remains (rarer), it will be
2004 * read from disk into another page. Splitting into two
2005 * pages would be incorrect if swap supported "shared
2006 * private" pages, but they are handled by tmpfs files.
Hugh Dickins5ad64682009-12-14 17:59:24 -08002007 *
2008 * Given how unuse_vma() targets one particular offset
2009 * in an anon_vma, once the anon_vma has been determined,
2010 * this splitting happens to be just what is needed to
2011 * handle where KSM pages have been swapped out: re-reading
2012 * is unnecessarily slow, but we can fix that later on.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002013 */
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07002014 if (swap_count(*swap_map) &&
2015 PageDirty(page) && PageSwapCache(page)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002016 struct writeback_control wbc = {
2017 .sync_mode = WB_SYNC_NONE,
2018 };
2019
2020 swap_writepage(page, &wbc);
2021 lock_page(page);
2022 wait_on_page_writeback(page);
2023 }
Hugh Dickins68bdc8d2009-01-06 14:39:37 -08002024
2025 /*
2026 * It is conceivable that a racing task removed this page from
2027 * swap cache just before we acquired the page lock at the top,
2028 * or while we dropped it in unuse_mm(). The page might even
2029 * be back in swap cache on another swap area: that we must not
2030 * delete, since it may not have been written out to swap yet.
2031 */
2032 if (PageSwapCache(page) &&
2033 likely(page_private(page) == entry.val))
Hugh Dickins2e0e26c2008-02-04 22:28:53 -08002034 delete_from_swap_cache(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002035
2036 /*
2037 * So we could skip searching mms once swap count went
2038 * to 1, we did not mark any present ptes as dirty: must
Anderson Briglia2706a1b2007-07-15 23:38:09 -07002039 * mark page dirty so shrink_page_list will preserve it.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002040 */
2041 SetPageDirty(page);
2042 unlock_page(page);
Kirill A. Shutemov09cbfea2016-04-01 15:29:47 +03002043 put_page(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002044
2045 /*
2046 * Make sure that we aren't completely killing
2047 * interactive performance.
2048 */
2049 cond_resched();
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06002050 if (frontswap && pages_to_unuse > 0) {
2051 if (!--pages_to_unuse)
2052 break;
2053 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002054 }
2055
2056 mmput(start_mm);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002057 return retval;
2058}
2059
2060/*
Hugh Dickins5d337b92005-09-03 15:54:41 -07002061 * After a successful try_to_unuse, if no swap is now in use, we know
2062 * we can empty the mmlist. swap_lock must be held on entry and exit.
2063 * Note that mmlist_lock nests inside swap_lock, and an mm must be
Linus Torvalds1da177e2005-04-16 15:20:36 -07002064 * added to the mmlist just after page_duplicate - before would be racy.
2065 */
2066static void drain_mmlist(void)
2067{
2068 struct list_head *p, *next;
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002069 unsigned int type;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002070
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002071 for (type = 0; type < nr_swapfiles; type++)
2072 if (swap_info[type]->inuse_pages)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002073 return;
2074 spin_lock(&mmlist_lock);
2075 list_for_each_safe(p, next, &init_mm.mmlist)
2076 list_del_init(p);
2077 spin_unlock(&mmlist_lock);
2078}
2079
2080/*
2081 * Use this swapdev's extent info to locate the (PAGE_SIZE) block which
Lee Schermerhornd4906e12009-12-14 17:58:49 -08002082 * corresponds to page offset for the specified swap entry.
2083 * Note that the type of this function is sector_t, but it returns page offset
2084 * into the bdev, not sector offset.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002085 */
Lee Schermerhornd4906e12009-12-14 17:58:49 -08002086static sector_t map_swap_entry(swp_entry_t entry, struct block_device **bdev)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002087{
Hugh Dickinsf29ad6a2009-12-14 17:58:40 -08002088 struct swap_info_struct *sis;
2089 struct swap_extent *start_se;
2090 struct swap_extent *se;
2091 pgoff_t offset;
2092
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002093 sis = swap_info[swp_type(entry)];
Hugh Dickinsf29ad6a2009-12-14 17:58:40 -08002094 *bdev = sis->bdev;
2095
2096 offset = swp_offset(entry);
2097 start_se = sis->curr_swap_extent;
2098 se = start_se;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002099
2100 for ( ; ; ) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002101 if (se->start_page <= offset &&
2102 offset < (se->start_page + se->nr_pages)) {
2103 return se->start_block + (offset - se->start_page);
2104 }
Geliang Tanga8ae4992016-01-14 15:20:45 -08002105 se = list_next_entry(se, list);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002106 sis->curr_swap_extent = se;
2107 BUG_ON(se == start_se); /* It *must* be present */
2108 }
2109}
2110
2111/*
Lee Schermerhornd4906e12009-12-14 17:58:49 -08002112 * Returns the page offset into bdev for the specified page's swap entry.
2113 */
2114sector_t map_swap_page(struct page *page, struct block_device **bdev)
2115{
2116 swp_entry_t entry;
2117 entry.val = page_private(page);
2118 return map_swap_entry(entry, bdev);
2119}
2120
2121/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07002122 * Free all of a swapdev's extent information
2123 */
2124static void destroy_swap_extents(struct swap_info_struct *sis)
2125{
Hugh Dickins9625a5f2009-12-14 17:58:42 -08002126 while (!list_empty(&sis->first_swap_extent.list)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002127 struct swap_extent *se;
2128
Geliang Tanga8ae4992016-01-14 15:20:45 -08002129 se = list_first_entry(&sis->first_swap_extent.list,
Linus Torvalds1da177e2005-04-16 15:20:36 -07002130 struct swap_extent, list);
2131 list_del(&se->list);
2132 kfree(se);
2133 }
Mel Gorman62c230b2012-07-31 16:44:55 -07002134
2135 if (sis->flags & SWP_FILE) {
2136 struct file *swap_file = sis->swap_file;
2137 struct address_space *mapping = swap_file->f_mapping;
2138
2139 sis->flags &= ~SWP_FILE;
2140 mapping->a_ops->swap_deactivate(swap_file);
2141 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002142}
2143
2144/*
2145 * Add a block range (and the corresponding page range) into this swapdev's
Hugh Dickins11d31882005-09-03 15:54:34 -07002146 * extent list. The extent list is kept sorted in page order.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002147 *
Hugh Dickins11d31882005-09-03 15:54:34 -07002148 * This function rather assumes that it is called in ascending page order.
Linus Torvalds1da177e2005-04-16 15:20:36 -07002149 */
Mel Gormana509bc12012-07-31 16:44:57 -07002150int
Linus Torvalds1da177e2005-04-16 15:20:36 -07002151add_swap_extent(struct swap_info_struct *sis, unsigned long start_page,
2152 unsigned long nr_pages, sector_t start_block)
2153{
2154 struct swap_extent *se;
2155 struct swap_extent *new_se;
2156 struct list_head *lh;
2157
Hugh Dickins9625a5f2009-12-14 17:58:42 -08002158 if (start_page == 0) {
2159 se = &sis->first_swap_extent;
2160 sis->curr_swap_extent = se;
2161 se->start_page = 0;
2162 se->nr_pages = nr_pages;
2163 se->start_block = start_block;
2164 return 1;
2165 } else {
2166 lh = sis->first_swap_extent.list.prev; /* Highest extent */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002167 se = list_entry(lh, struct swap_extent, list);
Hugh Dickins11d31882005-09-03 15:54:34 -07002168 BUG_ON(se->start_page + se->nr_pages != start_page);
2169 if (se->start_block + se->nr_pages == start_block) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002170 /* Merge it */
2171 se->nr_pages += nr_pages;
2172 return 0;
2173 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002174 }
2175
2176 /*
2177 * No merge. Insert a new extent, preserving ordering.
2178 */
2179 new_se = kmalloc(sizeof(*se), GFP_KERNEL);
2180 if (new_se == NULL)
2181 return -ENOMEM;
2182 new_se->start_page = start_page;
2183 new_se->nr_pages = nr_pages;
2184 new_se->start_block = start_block;
2185
Hugh Dickins9625a5f2009-12-14 17:58:42 -08002186 list_add_tail(&new_se->list, &sis->first_swap_extent.list);
Hugh Dickins53092a72005-09-03 15:54:34 -07002187 return 1;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002188}
2189
2190/*
2191 * A `swap extent' is a simple thing which maps a contiguous range of pages
2192 * onto a contiguous range of disk blocks. An ordered list of swap extents
2193 * is built at swapon time and is then used at swap_writepage/swap_readpage
2194 * time for locating where on disk a page belongs.
2195 *
2196 * If the swapfile is an S_ISBLK block device, a single extent is installed.
2197 * This is done so that the main operating code can treat S_ISBLK and S_ISREG
2198 * swap files identically.
2199 *
2200 * Whether the swapdev is an S_ISREG file or an S_ISBLK blockdev, the swap
2201 * extent list operates in PAGE_SIZE disk blocks. Both S_ISREG and S_ISBLK
2202 * swapfiles are handled *identically* after swapon time.
2203 *
2204 * For S_ISREG swapfiles, setup_swap_extents() will walk all the file's blocks
2205 * and will parse them into an ordered extent list, in PAGE_SIZE chunks. If
2206 * some stray blocks are found which do not fall within the PAGE_SIZE alignment
2207 * requirements, they are simply tossed out - we will never use those blocks
2208 * for swapping.
2209 *
Hugh Dickinsb0d9bcd2005-09-03 15:54:31 -07002210 * For S_ISREG swapfiles we set S_SWAPFILE across the life of the swapon. This
Linus Torvalds1da177e2005-04-16 15:20:36 -07002211 * prevents root from shooting her foot off by ftruncating an in-use swapfile,
2212 * which will scribble on the fs.
2213 *
2214 * The amount of disk space which a single swap extent represents varies.
2215 * Typically it is in the 1-4 megabyte range. So we can have hundreds of
2216 * extents in the list. To avoid much list walking, we cache the previous
2217 * search location in `curr_swap_extent', and start new searches from there.
2218 * This is extremely effective. The average number of iterations in
2219 * map_swap_page() has been measured at about 0.3 per page. - akpm.
2220 */
Hugh Dickins53092a72005-09-03 15:54:34 -07002221static int setup_swap_extents(struct swap_info_struct *sis, sector_t *span)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002222{
Mel Gorman62c230b2012-07-31 16:44:55 -07002223 struct file *swap_file = sis->swap_file;
2224 struct address_space *mapping = swap_file->f_mapping;
2225 struct inode *inode = mapping->host;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002226 int ret;
2227
Linus Torvalds1da177e2005-04-16 15:20:36 -07002228 if (S_ISBLK(inode->i_mode)) {
2229 ret = add_swap_extent(sis, 0, sis->max, 0);
Hugh Dickins53092a72005-09-03 15:54:34 -07002230 *span = sis->pages;
Mel Gormana509bc12012-07-31 16:44:57 -07002231 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002232 }
2233
Mel Gorman62c230b2012-07-31 16:44:55 -07002234 if (mapping->a_ops->swap_activate) {
Mel Gormana509bc12012-07-31 16:44:57 -07002235 ret = mapping->a_ops->swap_activate(sis, swap_file, span);
Mel Gorman62c230b2012-07-31 16:44:55 -07002236 if (!ret) {
2237 sis->flags |= SWP_FILE;
2238 ret = add_swap_extent(sis, 0, sis->max, 0);
2239 *span = sis->pages;
2240 }
Mel Gormana509bc12012-07-31 16:44:57 -07002241 return ret;
Mel Gorman62c230b2012-07-31 16:44:55 -07002242 }
2243
Mel Gormana509bc12012-07-31 16:44:57 -07002244 return generic_swapfile_activate(sis, swap_file, span);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002245}
2246
Cesar Eduardo Barroscf0cac02012-12-11 16:01:13 -08002247static void _enable_swap_info(struct swap_info_struct *p, int prio,
Shaohua Li2a8f9442013-09-11 14:20:28 -07002248 unsigned char *swap_map,
2249 struct swap_cluster_info *cluster_info)
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07002250{
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07002251 if (prio >= 0)
2252 p->prio = prio;
2253 else
2254 p->prio = --least_priority;
Dan Streetman18ab4d42014-06-04 16:09:59 -07002255 /*
2256 * the plist prio is negated because plist ordering is
2257 * low-to-high, while swap ordering is high-to-low
2258 */
2259 p->list.prio = -p->prio;
2260 p->avail_list.prio = -p->prio;
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07002261 p->swap_map = swap_map;
Shaohua Li2a8f9442013-09-11 14:20:28 -07002262 p->cluster_info = cluster_info;
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07002263 p->flags |= SWP_WRITEOK;
Shaohua Liec8acf22013-02-22 16:34:38 -08002264 atomic_long_add(p->pages, &nr_swap_pages);
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07002265 total_swap_pages += p->pages;
2266
Dan Streetmanadfab832014-06-04 16:09:53 -07002267 assert_spin_locked(&swap_lock);
Dan Streetmanadfab832014-06-04 16:09:53 -07002268 /*
Dan Streetman18ab4d42014-06-04 16:09:59 -07002269 * both lists are plists, and thus priority ordered.
2270 * swap_active_head needs to be priority ordered for swapoff(),
2271 * which on removal of any swap_info_struct with an auto-assigned
2272 * (i.e. negative) priority increments the auto-assigned priority
2273 * of any lower-priority swap_info_structs.
2274 * swap_avail_head needs to be priority ordered for get_swap_page(),
2275 * which allocates swap pages from the highest available priority
2276 * swap_info_struct.
Dan Streetmanadfab832014-06-04 16:09:53 -07002277 */
Dan Streetman18ab4d42014-06-04 16:09:59 -07002278 plist_add(&p->list, &swap_active_head);
2279 spin_lock(&swap_avail_lock);
2280 plist_add(&p->avail_list, &swap_avail_head);
2281 spin_unlock(&swap_avail_lock);
Cesar Eduardo Barroscf0cac02012-12-11 16:01:13 -08002282}
2283
2284static void enable_swap_info(struct swap_info_struct *p, int prio,
2285 unsigned char *swap_map,
Shaohua Li2a8f9442013-09-11 14:20:28 -07002286 struct swap_cluster_info *cluster_info,
Cesar Eduardo Barroscf0cac02012-12-11 16:01:13 -08002287 unsigned long *frontswap_map)
2288{
Minchan Kim4f898492013-04-30 15:26:54 -07002289 frontswap_init(p->type, frontswap_map);
Cesar Eduardo Barroscf0cac02012-12-11 16:01:13 -08002290 spin_lock(&swap_lock);
Shaohua Liec8acf22013-02-22 16:34:38 -08002291 spin_lock(&p->lock);
Shaohua Li2a8f9442013-09-11 14:20:28 -07002292 _enable_swap_info(p, prio, swap_map, cluster_info);
Shaohua Liec8acf22013-02-22 16:34:38 -08002293 spin_unlock(&p->lock);
Cesar Eduardo Barroscf0cac02012-12-11 16:01:13 -08002294 spin_unlock(&swap_lock);
2295}
2296
2297static void reinsert_swap_info(struct swap_info_struct *p)
2298{
2299 spin_lock(&swap_lock);
Shaohua Liec8acf22013-02-22 16:34:38 -08002300 spin_lock(&p->lock);
Shaohua Li2a8f9442013-09-11 14:20:28 -07002301 _enable_swap_info(p, p->prio, p->swap_map, p->cluster_info);
Shaohua Liec8acf22013-02-22 16:34:38 -08002302 spin_unlock(&p->lock);
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07002303 spin_unlock(&swap_lock);
2304}
2305
Tim Chen67afa382017-02-22 15:45:39 -08002306bool has_usable_swap(void)
2307{
2308 bool ret = true;
2309
2310 spin_lock(&swap_lock);
2311 if (plist_head_empty(&swap_active_head))
2312 ret = false;
2313 spin_unlock(&swap_lock);
2314 return ret;
2315}
2316
Heiko Carstensc4ea37c2009-01-14 14:14:28 +01002317SYSCALL_DEFINE1(swapoff, const char __user *, specialfile)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002318{
Hugh Dickins73c34b62009-12-14 17:58:43 -08002319 struct swap_info_struct *p = NULL;
Hugh Dickins8d69aae2009-12-14 17:58:45 -08002320 unsigned char *swap_map;
Shaohua Li2a8f9442013-09-11 14:20:28 -07002321 struct swap_cluster_info *cluster_info;
Minchan Kim4f898492013-04-30 15:26:54 -07002322 unsigned long *frontswap_map;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002323 struct file *swap_file, *victim;
2324 struct address_space *mapping;
2325 struct inode *inode;
Jeff Layton91a27b22012-10-10 15:25:28 -04002326 struct filename *pathname;
Dan Streetmanadfab832014-06-04 16:09:53 -07002327 int err, found = 0;
Krzysztof Kozlowski5b808a22013-10-16 13:47:06 -07002328 unsigned int old_block_size;
Hugh Dickins886bb7e2009-01-06 14:39:48 -08002329
Linus Torvalds1da177e2005-04-16 15:20:36 -07002330 if (!capable(CAP_SYS_ADMIN))
2331 return -EPERM;
2332
Al Viro191c5422012-02-13 03:58:52 +00002333 BUG_ON(!current->mm);
2334
Linus Torvalds1da177e2005-04-16 15:20:36 -07002335 pathname = getname(specialfile);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002336 if (IS_ERR(pathname))
Xiaotian Fengf58b59c2012-11-16 14:14:55 -08002337 return PTR_ERR(pathname);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002338
Jeff Layton669abf42012-10-10 16:43:10 -04002339 victim = file_open_name(pathname, O_RDWR|O_LARGEFILE, 0);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002340 err = PTR_ERR(victim);
2341 if (IS_ERR(victim))
2342 goto out;
2343
2344 mapping = victim->f_mapping;
Hugh Dickins5d337b92005-09-03 15:54:41 -07002345 spin_lock(&swap_lock);
Dan Streetman18ab4d42014-06-04 16:09:59 -07002346 plist_for_each_entry(p, &swap_active_head, list) {
Hugh Dickins22c6f8f2009-01-06 14:39:48 -08002347 if (p->flags & SWP_WRITEOK) {
Dan Streetmanadfab832014-06-04 16:09:53 -07002348 if (p->swap_file->f_mapping == mapping) {
2349 found = 1;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002350 break;
Dan Streetmanadfab832014-06-04 16:09:53 -07002351 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002352 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002353 }
Dan Streetmanadfab832014-06-04 16:09:53 -07002354 if (!found) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002355 err = -EINVAL;
Hugh Dickins5d337b92005-09-03 15:54:41 -07002356 spin_unlock(&swap_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002357 goto out_dput;
2358 }
Al Viro191c5422012-02-13 03:58:52 +00002359 if (!security_vm_enough_memory_mm(current->mm, p->pages))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002360 vm_unacct_memory(p->pages);
2361 else {
2362 err = -ENOMEM;
Hugh Dickins5d337b92005-09-03 15:54:41 -07002363 spin_unlock(&swap_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002364 goto out_dput;
2365 }
Dan Streetman18ab4d42014-06-04 16:09:59 -07002366 spin_lock(&swap_avail_lock);
2367 plist_del(&p->avail_list, &swap_avail_head);
2368 spin_unlock(&swap_avail_lock);
Shaohua Liec8acf22013-02-22 16:34:38 -08002369 spin_lock(&p->lock);
Hugh Dickins78ecba02008-07-23 21:28:23 -07002370 if (p->prio < 0) {
Dan Streetmanadfab832014-06-04 16:09:53 -07002371 struct swap_info_struct *si = p;
2372
Dan Streetman18ab4d42014-06-04 16:09:59 -07002373 plist_for_each_entry_continue(si, &swap_active_head, list) {
Dan Streetmanadfab832014-06-04 16:09:53 -07002374 si->prio++;
Dan Streetman18ab4d42014-06-04 16:09:59 -07002375 si->list.prio--;
2376 si->avail_list.prio--;
Dan Streetmanadfab832014-06-04 16:09:53 -07002377 }
Hugh Dickins78ecba02008-07-23 21:28:23 -07002378 least_priority++;
2379 }
Dan Streetman18ab4d42014-06-04 16:09:59 -07002380 plist_del(&p->list, &swap_active_head);
Shaohua Liec8acf22013-02-22 16:34:38 -08002381 atomic_long_sub(p->pages, &nr_swap_pages);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002382 total_swap_pages -= p->pages;
2383 p->flags &= ~SWP_WRITEOK;
Shaohua Liec8acf22013-02-22 16:34:38 -08002384 spin_unlock(&p->lock);
Hugh Dickins5d337b92005-09-03 15:54:41 -07002385 spin_unlock(&swap_lock);
Hugh Dickinsfb4f88d2005-09-03 15:54:37 -07002386
Tim Chen039939a2017-02-22 15:45:43 -08002387 disable_swap_slots_cache_lock();
2388
David Rientjese1e12d22012-12-11 16:02:56 -08002389 set_current_oom_origin();
Dan Streetmanadfab832014-06-04 16:09:53 -07002390 err = try_to_unuse(p->type, false, 0); /* force unuse all pages */
David Rientjese1e12d22012-12-11 16:02:56 -08002391 clear_current_oom_origin();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002392
Linus Torvalds1da177e2005-04-16 15:20:36 -07002393 if (err) {
2394 /* re-insert swap space back into swap_list */
Cesar Eduardo Barroscf0cac02012-12-11 16:01:13 -08002395 reinsert_swap_info(p);
Tim Chen039939a2017-02-22 15:45:43 -08002396 reenable_swap_slots_cache_unlock();
Linus Torvalds1da177e2005-04-16 15:20:36 -07002397 goto out_dput;
2398 }
Hugh Dickins52b7efdb2005-09-03 15:54:39 -07002399
Tim Chen039939a2017-02-22 15:45:43 -08002400 reenable_swap_slots_cache_unlock();
2401
Shaohua Li815c2c52013-09-11 14:20:30 -07002402 flush_work(&p->discard_work);
2403
Hugh Dickins4cd3bb12005-09-03 15:54:33 -07002404 destroy_swap_extents(p);
Hugh Dickins570a335b2009-12-14 17:58:46 -08002405 if (p->flags & SWP_CONTINUED)
2406 free_swap_count_continuations(p);
2407
Ingo Molnarfc0abb12006-01-18 17:42:33 -08002408 mutex_lock(&swapon_mutex);
Hugh Dickins5d337b92005-09-03 15:54:41 -07002409 spin_lock(&swap_lock);
Shaohua Liec8acf22013-02-22 16:34:38 -08002410 spin_lock(&p->lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002411 drain_mmlist();
Hugh Dickins5d337b92005-09-03 15:54:41 -07002412
2413 /* wait for anyone still in scan_swap_map */
2414 p->highest_bit = 0; /* cuts scans short */
2415 while (p->flags >= SWP_SCANNING) {
Shaohua Liec8acf22013-02-22 16:34:38 -08002416 spin_unlock(&p->lock);
Hugh Dickins5d337b92005-09-03 15:54:41 -07002417 spin_unlock(&swap_lock);
Nishanth Aravamudan13e4b572005-09-10 00:27:25 -07002418 schedule_timeout_uninterruptible(1);
Hugh Dickins5d337b92005-09-03 15:54:41 -07002419 spin_lock(&swap_lock);
Shaohua Liec8acf22013-02-22 16:34:38 -08002420 spin_lock(&p->lock);
Hugh Dickins5d337b92005-09-03 15:54:41 -07002421 }
2422
Linus Torvalds1da177e2005-04-16 15:20:36 -07002423 swap_file = p->swap_file;
Krzysztof Kozlowski5b808a22013-10-16 13:47:06 -07002424 old_block_size = p->old_block_size;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002425 p->swap_file = NULL;
2426 p->max = 0;
2427 swap_map = p->swap_map;
2428 p->swap_map = NULL;
Shaohua Li2a8f9442013-09-11 14:20:28 -07002429 cluster_info = p->cluster_info;
2430 p->cluster_info = NULL;
Minchan Kim4f898492013-04-30 15:26:54 -07002431 frontswap_map = frontswap_map_get(p);
Shaohua Liec8acf22013-02-22 16:34:38 -08002432 spin_unlock(&p->lock);
Hugh Dickins5d337b92005-09-03 15:54:41 -07002433 spin_unlock(&swap_lock);
Dan Streetmanadfab832014-06-04 16:09:53 -07002434 frontswap_invalidate_area(p->type);
Krzysztof Kozlowski58e97ba2013-11-12 15:07:47 -08002435 frontswap_map_set(p, NULL);
Ingo Molnarfc0abb12006-01-18 17:42:33 -08002436 mutex_unlock(&swapon_mutex);
Shaohua Liebc2a1a2013-09-11 14:20:32 -07002437 free_percpu(p->percpu_cluster);
2438 p->percpu_cluster = NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002439 vfree(swap_map);
Huang Ying54f180d2017-05-08 15:57:40 -07002440 kvfree(cluster_info);
2441 kvfree(frontswap_map);
Seth Jennings2de1a7e2013-11-12 15:07:46 -08002442 /* Destroy swap account information */
Dan Streetmanadfab832014-06-04 16:09:53 -07002443 swap_cgroup_swapoff(p->type);
Huang, Ying4b3ef9d2017-02-22 15:45:26 -08002444 exit_swap_address_space(p->type);
KAMEZAWA Hiroyuki27a7faa2009-01-07 18:07:58 -08002445
Linus Torvalds1da177e2005-04-16 15:20:36 -07002446 inode = mapping->host;
2447 if (S_ISBLK(inode->i_mode)) {
2448 struct block_device *bdev = I_BDEV(inode);
Krzysztof Kozlowski5b808a22013-10-16 13:47:06 -07002449 set_blocksize(bdev, old_block_size);
Tejun Heoe525fd82010-11-13 11:55:17 +01002450 blkdev_put(bdev, FMODE_READ | FMODE_WRITE | FMODE_EXCL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002451 } else {
Al Viro59551022016-01-22 15:40:57 -05002452 inode_lock(inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002453 inode->i_flags &= ~S_SWAPFILE;
Al Viro59551022016-01-22 15:40:57 -05002454 inode_unlock(inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002455 }
2456 filp_close(swap_file, NULL);
Weijie Yangf893ab42014-02-06 12:04:23 -08002457
2458 /*
2459 * Clear the SWP_USED flag after all resources are freed so that swapon
2460 * can reuse this swap_info in alloc_swap_info() safely. It is ok to
2461 * not hold p->lock after we cleared its SWP_WRITEOK.
2462 */
2463 spin_lock(&swap_lock);
2464 p->flags = 0;
2465 spin_unlock(&swap_lock);
2466
Linus Torvalds1da177e2005-04-16 15:20:36 -07002467 err = 0;
Kay Sievers66d7dd52010-10-26 14:22:06 -07002468 atomic_inc(&proc_poll_event);
2469 wake_up_interruptible(&proc_poll_wait);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002470
2471out_dput:
2472 filp_close(victim, NULL);
2473out:
Xiaotian Fengf58b59c2012-11-16 14:14:55 -08002474 putname(pathname);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002475 return err;
2476}
2477
2478#ifdef CONFIG_PROC_FS
Kay Sievers66d7dd52010-10-26 14:22:06 -07002479static unsigned swaps_poll(struct file *file, poll_table *wait)
2480{
Kay Sieversf1514632011-07-12 20:48:39 +02002481 struct seq_file *seq = file->private_data;
Kay Sievers66d7dd52010-10-26 14:22:06 -07002482
2483 poll_wait(file, &proc_poll_wait, wait);
2484
Kay Sieversf1514632011-07-12 20:48:39 +02002485 if (seq->poll_event != atomic_read(&proc_poll_event)) {
2486 seq->poll_event = atomic_read(&proc_poll_event);
Kay Sievers66d7dd52010-10-26 14:22:06 -07002487 return POLLIN | POLLRDNORM | POLLERR | POLLPRI;
2488 }
2489
2490 return POLLIN | POLLRDNORM;
2491}
2492
Linus Torvalds1da177e2005-04-16 15:20:36 -07002493/* iterator */
2494static void *swap_start(struct seq_file *swap, loff_t *pos)
2495{
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002496 struct swap_info_struct *si;
2497 int type;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002498 loff_t l = *pos;
2499
Ingo Molnarfc0abb12006-01-18 17:42:33 -08002500 mutex_lock(&swapon_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002501
Suleiman Souhlal881e4aa2006-12-06 20:32:28 -08002502 if (!l)
2503 return SEQ_START_TOKEN;
2504
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002505 for (type = 0; type < nr_swapfiles; type++) {
2506 smp_rmb(); /* read nr_swapfiles before swap_info[type] */
2507 si = swap_info[type];
2508 if (!(si->flags & SWP_USED) || !si->swap_map)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002509 continue;
Suleiman Souhlal881e4aa2006-12-06 20:32:28 -08002510 if (!--l)
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002511 return si;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002512 }
2513
2514 return NULL;
2515}
2516
2517static void *swap_next(struct seq_file *swap, void *v, loff_t *pos)
2518{
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002519 struct swap_info_struct *si = v;
2520 int type;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002521
Suleiman Souhlal881e4aa2006-12-06 20:32:28 -08002522 if (v == SEQ_START_TOKEN)
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002523 type = 0;
2524 else
2525 type = si->type + 1;
Suleiman Souhlal881e4aa2006-12-06 20:32:28 -08002526
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002527 for (; type < nr_swapfiles; type++) {
2528 smp_rmb(); /* read nr_swapfiles before swap_info[type] */
2529 si = swap_info[type];
2530 if (!(si->flags & SWP_USED) || !si->swap_map)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002531 continue;
2532 ++*pos;
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002533 return si;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002534 }
2535
2536 return NULL;
2537}
2538
2539static void swap_stop(struct seq_file *swap, void *v)
2540{
Ingo Molnarfc0abb12006-01-18 17:42:33 -08002541 mutex_unlock(&swapon_mutex);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002542}
2543
2544static int swap_show(struct seq_file *swap, void *v)
2545{
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002546 struct swap_info_struct *si = v;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002547 struct file *file;
2548 int len;
2549
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002550 if (si == SEQ_START_TOKEN) {
Suleiman Souhlal881e4aa2006-12-06 20:32:28 -08002551 seq_puts(swap,"Filename\t\t\t\tType\t\tSize\tUsed\tPriority\n");
2552 return 0;
2553 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07002554
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002555 file = si->swap_file;
Miklos Szeredi2726d562015-06-19 10:30:28 +02002556 len = seq_file_path(swap, file, " \t\n\\");
Hugh Dickins6eb396d2005-09-03 15:54:35 -07002557 seq_printf(swap, "%*s%s\t%u\t%u\t%d\n",
Hugh Dickins886bb7e2009-01-06 14:39:48 -08002558 len < 40 ? 40 - len : 1, " ",
Al Viro496ad9a2013-01-23 17:07:38 -05002559 S_ISBLK(file_inode(file)->i_mode) ?
Linus Torvalds1da177e2005-04-16 15:20:36 -07002560 "partition" : "file\t",
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002561 si->pages << (PAGE_SHIFT - 10),
2562 si->inuse_pages << (PAGE_SHIFT - 10),
2563 si->prio);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002564 return 0;
2565}
2566
Helge Deller15ad7cd2006-12-06 20:40:36 -08002567static const struct seq_operations swaps_op = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002568 .start = swap_start,
2569 .next = swap_next,
2570 .stop = swap_stop,
2571 .show = swap_show
2572};
2573
2574static int swaps_open(struct inode *inode, struct file *file)
2575{
Kay Sieversf1514632011-07-12 20:48:39 +02002576 struct seq_file *seq;
Kay Sievers66d7dd52010-10-26 14:22:06 -07002577 int ret;
2578
Kay Sievers66d7dd52010-10-26 14:22:06 -07002579 ret = seq_open(file, &swaps_op);
Kay Sieversf1514632011-07-12 20:48:39 +02002580 if (ret)
Kay Sievers66d7dd52010-10-26 14:22:06 -07002581 return ret;
Kay Sievers66d7dd52010-10-26 14:22:06 -07002582
Kay Sieversf1514632011-07-12 20:48:39 +02002583 seq = file->private_data;
2584 seq->poll_event = atomic_read(&proc_poll_event);
2585 return 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002586}
2587
Helge Deller15ad7cd2006-12-06 20:40:36 -08002588static const struct file_operations proc_swaps_operations = {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002589 .open = swaps_open,
2590 .read = seq_read,
2591 .llseek = seq_lseek,
2592 .release = seq_release,
Kay Sievers66d7dd52010-10-26 14:22:06 -07002593 .poll = swaps_poll,
Linus Torvalds1da177e2005-04-16 15:20:36 -07002594};
2595
2596static int __init procswaps_init(void)
2597{
Denis V. Lunev3d71f862008-04-29 01:02:13 -07002598 proc_create("swaps", 0, NULL, &proc_swaps_operations);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002599 return 0;
2600}
2601__initcall(procswaps_init);
2602#endif /* CONFIG_PROC_FS */
2603
Jan Beulich17963162008-12-16 11:35:24 +00002604#ifdef MAX_SWAPFILES_CHECK
2605static int __init max_swapfiles_check(void)
2606{
2607 MAX_SWAPFILES_CHECK();
2608 return 0;
2609}
2610late_initcall(max_swapfiles_check);
2611#endif
2612
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002613static struct swap_info_struct *alloc_swap_info(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -07002614{
Hugh Dickins73c34b62009-12-14 17:58:43 -08002615 struct swap_info_struct *p;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002616 unsigned int type;
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002617
2618 p = kzalloc(sizeof(*p), GFP_KERNEL);
2619 if (!p)
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002620 return ERR_PTR(-ENOMEM);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002621
Hugh Dickins5d337b92005-09-03 15:54:41 -07002622 spin_lock(&swap_lock);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002623 for (type = 0; type < nr_swapfiles; type++) {
2624 if (!(swap_info[type]->flags & SWP_USED))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002625 break;
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002626 }
Christoph Lameter06972122006-06-23 02:03:35 -07002627 if (type >= MAX_SWAPFILES) {
Hugh Dickins5d337b92005-09-03 15:54:41 -07002628 spin_unlock(&swap_lock);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002629 kfree(p);
Cesar Eduardo Barros730c0582011-03-22 16:33:19 -07002630 return ERR_PTR(-EPERM);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002631 }
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002632 if (type >= nr_swapfiles) {
2633 p->type = type;
2634 swap_info[type] = p;
2635 /*
2636 * Write swap_info[type] before nr_swapfiles, in case a
2637 * racing procfs swap_start() or swap_next() is reading them.
2638 * (We never shrink nr_swapfiles, we never free this entry.)
2639 */
2640 smp_wmb();
2641 nr_swapfiles++;
2642 } else {
2643 kfree(p);
2644 p = swap_info[type];
2645 /*
2646 * Do not memset this entry: a racing procfs swap_next()
2647 * would be relying on p->type to remain valid.
2648 */
2649 }
Hugh Dickins9625a5f2009-12-14 17:58:42 -08002650 INIT_LIST_HEAD(&p->first_swap_extent.list);
Dan Streetman18ab4d42014-06-04 16:09:59 -07002651 plist_node_init(&p->list, 0);
2652 plist_node_init(&p->avail_list, 0);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002653 p->flags = SWP_USED;
Hugh Dickins5d337b92005-09-03 15:54:41 -07002654 spin_unlock(&swap_lock);
Shaohua Liec8acf22013-02-22 16:34:38 -08002655 spin_lock_init(&p->lock);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08002656
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002657 return p;
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002658}
2659
Cesar Eduardo Barros4d0e1e12011-03-22 16:33:26 -07002660static int claim_swapfile(struct swap_info_struct *p, struct inode *inode)
2661{
2662 int error;
2663
2664 if (S_ISBLK(inode->i_mode)) {
2665 p->bdev = bdgrab(I_BDEV(inode));
2666 error = blkdev_get(p->bdev,
Hugh Dickins6f179af2015-08-17 17:34:27 -07002667 FMODE_READ | FMODE_WRITE | FMODE_EXCL, p);
Cesar Eduardo Barros4d0e1e12011-03-22 16:33:26 -07002668 if (error < 0) {
2669 p->bdev = NULL;
Hugh Dickins6f179af2015-08-17 17:34:27 -07002670 return error;
Cesar Eduardo Barros4d0e1e12011-03-22 16:33:26 -07002671 }
2672 p->old_block_size = block_size(p->bdev);
2673 error = set_blocksize(p->bdev, PAGE_SIZE);
2674 if (error < 0)
Cesar Eduardo Barros87ade722011-03-22 16:33:27 -07002675 return error;
Cesar Eduardo Barros4d0e1e12011-03-22 16:33:26 -07002676 p->flags |= SWP_BLKDEV;
2677 } else if (S_ISREG(inode->i_mode)) {
2678 p->bdev = inode->i_sb->s_bdev;
Al Viro59551022016-01-22 15:40:57 -05002679 inode_lock(inode);
Cesar Eduardo Barros87ade722011-03-22 16:33:27 -07002680 if (IS_SWAPFILE(inode))
2681 return -EBUSY;
2682 } else
2683 return -EINVAL;
Cesar Eduardo Barros4d0e1e12011-03-22 16:33:26 -07002684
2685 return 0;
Cesar Eduardo Barros4d0e1e12011-03-22 16:33:26 -07002686}
2687
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002688static unsigned long read_swap_header(struct swap_info_struct *p,
2689 union swap_header *swap_header,
2690 struct inode *inode)
2691{
2692 int i;
2693 unsigned long maxpages;
2694 unsigned long swapfilepages;
Raymond Jenningsd6bbbd22013-09-11 14:20:16 -07002695 unsigned long last_page;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002696
2697 if (memcmp("SWAPSPACE2", swap_header->magic.magic, 10)) {
Andrew Morton465c47f2013-09-11 14:20:17 -07002698 pr_err("Unable to find swap-space signature\n");
Cesar Eduardo Barros38719022011-03-22 16:33:30 -07002699 return 0;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002700 }
2701
2702 /* swap partition endianess hack... */
2703 if (swab32(swap_header->info.version) == 1) {
2704 swab32s(&swap_header->info.version);
2705 swab32s(&swap_header->info.last_page);
2706 swab32s(&swap_header->info.nr_badpages);
Jann Horndd111be2016-11-10 10:46:19 -08002707 if (swap_header->info.nr_badpages > MAX_SWAP_BADPAGES)
2708 return 0;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002709 for (i = 0; i < swap_header->info.nr_badpages; i++)
2710 swab32s(&swap_header->info.badpages[i]);
2711 }
2712 /* Check the swap header's sub-version */
2713 if (swap_header->info.version != 1) {
Andrew Morton465c47f2013-09-11 14:20:17 -07002714 pr_warn("Unable to handle swap header version %d\n",
2715 swap_header->info.version);
Cesar Eduardo Barros38719022011-03-22 16:33:30 -07002716 return 0;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002717 }
2718
2719 p->lowest_bit = 1;
2720 p->cluster_next = 1;
2721 p->cluster_nr = 0;
2722
2723 /*
2724 * Find out how many pages are allowed for a single swap
Hugh Dickins9b15b812012-06-15 17:55:50 -07002725 * device. There are two limiting factors: 1) the number
Hugh Dickinsa2c16d62011-08-03 16:21:19 -07002726 * of bits for the swap offset in the swp_entry_t type, and
2727 * 2) the number of bits in the swap pte as defined by the
Hugh Dickins9b15b812012-06-15 17:55:50 -07002728 * different architectures. In order to find the
Hugh Dickinsa2c16d62011-08-03 16:21:19 -07002729 * largest possible bit mask, a swap entry with swap type 0
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002730 * and swap offset ~0UL is created, encoded to a swap pte,
Hugh Dickinsa2c16d62011-08-03 16:21:19 -07002731 * decoded to a swp_entry_t again, and finally the swap
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002732 * offset is extracted. This will mask all the bits from
2733 * the initial ~0UL mask that can't be encoded in either
2734 * the swp_entry_t or the architecture definition of a
Hugh Dickins9b15b812012-06-15 17:55:50 -07002735 * swap pte.
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002736 */
2737 maxpages = swp_offset(pte_to_swp_entry(
Hugh Dickins9b15b812012-06-15 17:55:50 -07002738 swp_entry_to_pte(swp_entry(0, ~0UL)))) + 1;
Raymond Jenningsd6bbbd22013-09-11 14:20:16 -07002739 last_page = swap_header->info.last_page;
2740 if (last_page > maxpages) {
Andrew Morton465c47f2013-09-11 14:20:17 -07002741 pr_warn("Truncating oversized swap area, only using %luk out of %luk\n",
Raymond Jenningsd6bbbd22013-09-11 14:20:16 -07002742 maxpages << (PAGE_SHIFT - 10),
2743 last_page << (PAGE_SHIFT - 10));
2744 }
2745 if (maxpages > last_page) {
2746 maxpages = last_page + 1;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002747 /* p->max is an unsigned int: don't overflow it */
2748 if ((unsigned int)maxpages == 0)
2749 maxpages = UINT_MAX;
2750 }
2751 p->highest_bit = maxpages - 1;
2752
2753 if (!maxpages)
Cesar Eduardo Barros38719022011-03-22 16:33:30 -07002754 return 0;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002755 swapfilepages = i_size_read(inode) >> PAGE_SHIFT;
2756 if (swapfilepages && maxpages > swapfilepages) {
Andrew Morton465c47f2013-09-11 14:20:17 -07002757 pr_warn("Swap area shorter than signature indicates\n");
Cesar Eduardo Barros38719022011-03-22 16:33:30 -07002758 return 0;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002759 }
2760 if (swap_header->info.nr_badpages && S_ISREG(inode->i_mode))
Cesar Eduardo Barros38719022011-03-22 16:33:30 -07002761 return 0;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002762 if (swap_header->info.nr_badpages > MAX_SWAP_BADPAGES)
Cesar Eduardo Barros38719022011-03-22 16:33:30 -07002763 return 0;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002764
2765 return maxpages;
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002766}
2767
Huang, Ying4b3ef9d2017-02-22 15:45:26 -08002768#define SWAP_CLUSTER_INFO_COLS \
Huang, Ying235b6212017-02-22 15:45:22 -08002769 DIV_ROUND_UP(L1_CACHE_BYTES, sizeof(struct swap_cluster_info))
Huang, Ying4b3ef9d2017-02-22 15:45:26 -08002770#define SWAP_CLUSTER_SPACE_COLS \
2771 DIV_ROUND_UP(SWAP_ADDRESS_SPACE_PAGES, SWAPFILE_CLUSTER)
2772#define SWAP_CLUSTER_COLS \
2773 max_t(unsigned int, SWAP_CLUSTER_INFO_COLS, SWAP_CLUSTER_SPACE_COLS)
Huang, Ying235b6212017-02-22 15:45:22 -08002774
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002775static int setup_swap_map_and_extents(struct swap_info_struct *p,
2776 union swap_header *swap_header,
2777 unsigned char *swap_map,
Shaohua Li2a8f9442013-09-11 14:20:28 -07002778 struct swap_cluster_info *cluster_info,
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002779 unsigned long maxpages,
2780 sector_t *span)
2781{
Huang, Ying235b6212017-02-22 15:45:22 -08002782 unsigned int j, k;
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002783 unsigned int nr_good_pages;
2784 int nr_extents;
Shaohua Li2a8f9442013-09-11 14:20:28 -07002785 unsigned long nr_clusters = DIV_ROUND_UP(maxpages, SWAPFILE_CLUSTER);
Huang, Ying235b6212017-02-22 15:45:22 -08002786 unsigned long col = p->cluster_next / SWAPFILE_CLUSTER % SWAP_CLUSTER_COLS;
2787 unsigned long i, idx;
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002788
2789 nr_good_pages = maxpages - 1; /* omit header page */
2790
Huang Ying6b534912016-10-07 16:58:42 -07002791 cluster_list_init(&p->free_clusters);
2792 cluster_list_init(&p->discard_clusters);
Shaohua Li2a8f9442013-09-11 14:20:28 -07002793
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002794 for (i = 0; i < swap_header->info.nr_badpages; i++) {
2795 unsigned int page_nr = swap_header->info.badpages[i];
Cesar Eduardo Barrosbdb8e3f2011-03-22 16:33:33 -07002796 if (page_nr == 0 || page_nr > swap_header->info.last_page)
2797 return -EINVAL;
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002798 if (page_nr < maxpages) {
2799 swap_map[page_nr] = SWAP_MAP_BAD;
2800 nr_good_pages--;
Shaohua Li2a8f9442013-09-11 14:20:28 -07002801 /*
2802 * Haven't marked the cluster free yet, no list
2803 * operation involved
2804 */
2805 inc_cluster_info_page(p, cluster_info, page_nr);
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002806 }
2807 }
2808
Shaohua Li2a8f9442013-09-11 14:20:28 -07002809 /* Haven't marked the cluster free yet, no list operation involved */
2810 for (i = maxpages; i < round_up(maxpages, SWAPFILE_CLUSTER); i++)
2811 inc_cluster_info_page(p, cluster_info, i);
2812
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002813 if (nr_good_pages) {
2814 swap_map[0] = SWAP_MAP_BAD;
Shaohua Li2a8f9442013-09-11 14:20:28 -07002815 /*
2816 * Not mark the cluster free yet, no list
2817 * operation involved
2818 */
2819 inc_cluster_info_page(p, cluster_info, 0);
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002820 p->max = maxpages;
2821 p->pages = nr_good_pages;
2822 nr_extents = setup_swap_extents(p, span);
Cesar Eduardo Barrosbdb8e3f2011-03-22 16:33:33 -07002823 if (nr_extents < 0)
2824 return nr_extents;
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002825 nr_good_pages = p->pages;
2826 }
2827 if (!nr_good_pages) {
Andrew Morton465c47f2013-09-11 14:20:17 -07002828 pr_warn("Empty swap-file\n");
Cesar Eduardo Barrosbdb8e3f2011-03-22 16:33:33 -07002829 return -EINVAL;
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002830 }
2831
Shaohua Li2a8f9442013-09-11 14:20:28 -07002832 if (!cluster_info)
2833 return nr_extents;
2834
Huang, Ying235b6212017-02-22 15:45:22 -08002835
Huang, Ying4b3ef9d2017-02-22 15:45:26 -08002836 /*
2837 * Reduce false cache line sharing between cluster_info and
2838 * sharing same address space.
2839 */
Huang, Ying235b6212017-02-22 15:45:22 -08002840 for (k = 0; k < SWAP_CLUSTER_COLS; k++) {
2841 j = (k + col) % SWAP_CLUSTER_COLS;
2842 for (i = 0; i < DIV_ROUND_UP(nr_clusters, SWAP_CLUSTER_COLS); i++) {
2843 idx = i * SWAP_CLUSTER_COLS + j;
2844 if (idx >= nr_clusters)
2845 continue;
2846 if (cluster_count(&cluster_info[idx]))
2847 continue;
Shaohua Li2a8f9442013-09-11 14:20:28 -07002848 cluster_set_flag(&cluster_info[idx], CLUSTER_FLAG_FREE);
Huang Ying6b534912016-10-07 16:58:42 -07002849 cluster_list_add_tail(&p->free_clusters, cluster_info,
2850 idx);
Shaohua Li2a8f9442013-09-11 14:20:28 -07002851 }
Shaohua Li2a8f9442013-09-11 14:20:28 -07002852 }
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002853 return nr_extents;
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002854}
2855
Rafael Aquinidcf6b7d2013-07-03 15:02:46 -07002856/*
2857 * Helper to sys_swapon determining if a given swap
2858 * backing device queue supports DISCARD operations.
2859 */
2860static bool swap_discardable(struct swap_info_struct *si)
2861{
2862 struct request_queue *q = bdev_get_queue(si->bdev);
2863
2864 if (!q || !blk_queue_discard(q))
2865 return false;
2866
2867 return true;
2868}
2869
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002870SYSCALL_DEFINE2(swapon, const char __user *, specialfile, int, swap_flags)
2871{
2872 struct swap_info_struct *p;
Jeff Layton91a27b22012-10-10 15:25:28 -04002873 struct filename *name;
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002874 struct file *swap_file = NULL;
2875 struct address_space *mapping;
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07002876 int prio;
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002877 int error;
2878 union swap_header *swap_header;
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002879 int nr_extents;
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002880 sector_t span;
2881 unsigned long maxpages;
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002882 unsigned char *swap_map = NULL;
Shaohua Li2a8f9442013-09-11 14:20:28 -07002883 struct swap_cluster_info *cluster_info = NULL;
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06002884 unsigned long *frontswap_map = NULL;
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002885 struct page *page = NULL;
2886 struct inode *inode = NULL;
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002887
Hugh Dickinsd15cab92012-03-28 14:42:42 -07002888 if (swap_flags & ~SWAP_FLAGS_VALID)
2889 return -EINVAL;
2890
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002891 if (!capable(CAP_SYS_ADMIN))
2892 return -EPERM;
2893
2894 p = alloc_swap_info();
Cesar Eduardo Barros2542e5132011-03-22 16:33:18 -07002895 if (IS_ERR(p))
2896 return PTR_ERR(p);
Cesar Eduardo Barros53cbb242011-03-22 16:33:17 -07002897
Shaohua Li815c2c52013-09-11 14:20:30 -07002898 INIT_WORK(&p->discard_work, swap_discard_work);
2899
Linus Torvalds1da177e2005-04-16 15:20:36 -07002900 name = getname(specialfile);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002901 if (IS_ERR(name)) {
Cesar Eduardo Barros7de7fb62011-03-22 16:33:22 -07002902 error = PTR_ERR(name);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002903 name = NULL;
Cesar Eduardo Barrosbd690102011-03-22 16:33:25 -07002904 goto bad_swap;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002905 }
Jeff Layton669abf42012-10-10 16:43:10 -04002906 swap_file = file_open_name(name, O_RDWR|O_LARGEFILE, 0);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002907 if (IS_ERR(swap_file)) {
Cesar Eduardo Barros7de7fb62011-03-22 16:33:22 -07002908 error = PTR_ERR(swap_file);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002909 swap_file = NULL;
Cesar Eduardo Barrosbd690102011-03-22 16:33:25 -07002910 goto bad_swap;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002911 }
2912
2913 p->swap_file = swap_file;
2914 mapping = swap_file->f_mapping;
Cesar Eduardo Barros21307812011-03-22 23:03:13 -03002915 inode = mapping->host;
Hugh Dickins6f179af2015-08-17 17:34:27 -07002916
Al Viro59551022016-01-22 15:40:57 -05002917 /* If S_ISREG(inode->i_mode) will do inode_lock(inode); */
Cesar Eduardo Barros4d0e1e12011-03-22 16:33:26 -07002918 error = claim_swapfile(p, inode);
2919 if (unlikely(error))
Linus Torvalds1da177e2005-04-16 15:20:36 -07002920 goto bad_swap;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002921
Linus Torvalds1da177e2005-04-16 15:20:36 -07002922 /*
2923 * Read the swap header.
2924 */
2925 if (!mapping->a_ops->readpage) {
2926 error = -EINVAL;
2927 goto bad_swap;
2928 }
Pekka Enberg090d2b12006-06-23 02:05:08 -07002929 page = read_mapping_page(mapping, 0, swap_file);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002930 if (IS_ERR(page)) {
2931 error = PTR_ERR(page);
2932 goto bad_swap;
2933 }
Hugh Dickins81e33972009-01-06 14:39:49 -08002934 swap_header = kmap(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -07002935
Cesar Eduardo Barrosca8bd382011-03-22 16:33:29 -07002936 maxpages = read_swap_header(p, swap_header, inode);
2937 if (unlikely(!maxpages)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -07002938 error = -EINVAL;
2939 goto bad_swap;
2940 }
Hugh Dickins886bb7e2009-01-06 14:39:48 -08002941
Hugh Dickins81e33972009-01-06 14:39:49 -08002942 /* OK, set up the swap map and apply the bad block list */
Cesar Eduardo Barros803d0c832011-03-22 16:33:14 -07002943 swap_map = vzalloc(maxpages);
Hugh Dickins81e33972009-01-06 14:39:49 -08002944 if (!swap_map) {
2945 error = -ENOMEM;
2946 goto bad_swap;
2947 }
Minchan Kimf0571422017-01-10 16:58:15 -08002948
2949 if (bdi_cap_stable_pages_required(inode_to_bdi(inode)))
2950 p->flags |= SWP_STABLE_WRITES;
2951
Shaohua Li2a8f9442013-09-11 14:20:28 -07002952 if (p->bdev && blk_queue_nonrot(bdev_get_queue(p->bdev))) {
Hugh Dickins6f179af2015-08-17 17:34:27 -07002953 int cpu;
Huang, Ying235b6212017-02-22 15:45:22 -08002954 unsigned long ci, nr_cluster;
Hugh Dickins6f179af2015-08-17 17:34:27 -07002955
Shaohua Li2a8f9442013-09-11 14:20:28 -07002956 p->flags |= SWP_SOLIDSTATE;
2957 /*
2958 * select a random position to start with to help wear leveling
2959 * SSD
2960 */
2961 p->cluster_next = 1 + (prandom_u32() % p->highest_bit);
Huang, Ying235b6212017-02-22 15:45:22 -08002962 nr_cluster = DIV_ROUND_UP(maxpages, SWAPFILE_CLUSTER);
Shaohua Li2a8f9442013-09-11 14:20:28 -07002963
Huang Ying54f180d2017-05-08 15:57:40 -07002964 cluster_info = kvzalloc(nr_cluster * sizeof(*cluster_info),
2965 GFP_KERNEL);
Shaohua Li2a8f9442013-09-11 14:20:28 -07002966 if (!cluster_info) {
2967 error = -ENOMEM;
2968 goto bad_swap;
2969 }
Huang, Ying235b6212017-02-22 15:45:22 -08002970
2971 for (ci = 0; ci < nr_cluster; ci++)
2972 spin_lock_init(&((cluster_info + ci)->lock));
2973
Shaohua Liebc2a1a2013-09-11 14:20:32 -07002974 p->percpu_cluster = alloc_percpu(struct percpu_cluster);
2975 if (!p->percpu_cluster) {
2976 error = -ENOMEM;
2977 goto bad_swap;
2978 }
Hugh Dickins6f179af2015-08-17 17:34:27 -07002979 for_each_possible_cpu(cpu) {
Shaohua Liebc2a1a2013-09-11 14:20:32 -07002980 struct percpu_cluster *cluster;
Hugh Dickins6f179af2015-08-17 17:34:27 -07002981 cluster = per_cpu_ptr(p->percpu_cluster, cpu);
Shaohua Liebc2a1a2013-09-11 14:20:32 -07002982 cluster_set_null(&cluster->index);
2983 }
Shaohua Li2a8f9442013-09-11 14:20:28 -07002984 }
Hugh Dickins81e33972009-01-06 14:39:49 -08002985
Cesar Eduardo Barros1421ef32011-03-22 16:33:31 -07002986 error = swap_cgroup_swapon(p->type, maxpages);
2987 if (error)
2988 goto bad_swap;
2989
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002990 nr_extents = setup_swap_map_and_extents(p, swap_header, swap_map,
Shaohua Li2a8f9442013-09-11 14:20:28 -07002991 cluster_info, maxpages, &span);
Cesar Eduardo Barros915d4d72011-03-22 16:33:32 -07002992 if (unlikely(nr_extents < 0)) {
2993 error = nr_extents;
Linus Torvalds1da177e2005-04-16 15:20:36 -07002994 goto bad_swap;
2995 }
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06002996 /* frontswap enabled? set up bit-per-page map for frontswap */
Vlastimil Babka8ea1d2a2016-07-26 15:24:42 -07002997 if (IS_ENABLED(CONFIG_FRONTSWAP))
Huang Ying54f180d2017-05-08 15:57:40 -07002998 frontswap_map = kvzalloc(BITS_TO_LONGS(maxpages) * sizeof(long),
2999 GFP_KERNEL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003000
Shaohua Li2a8f9442013-09-11 14:20:28 -07003001 if (p->bdev &&(swap_flags & SWAP_FLAG_DISCARD) && swap_discardable(p)) {
3002 /*
3003 * When discard is enabled for swap with no particular
3004 * policy flagged, we set all swap discard flags here in
3005 * order to sustain backward compatibility with older
3006 * swapon(8) releases.
3007 */
3008 p->flags |= (SWP_DISCARDABLE | SWP_AREA_DISCARD |
3009 SWP_PAGE_DISCARD);
Rafael Aquinidcf6b7d2013-07-03 15:02:46 -07003010
Shaohua Li2a8f9442013-09-11 14:20:28 -07003011 /*
3012 * By flagging sys_swapon, a sysadmin can tell us to
3013 * either do single-time area discards only, or to just
3014 * perform discards for released swap page-clusters.
3015 * Now it's time to adjust the p->flags accordingly.
3016 */
3017 if (swap_flags & SWAP_FLAG_DISCARD_ONCE)
3018 p->flags &= ~SWP_PAGE_DISCARD;
3019 else if (swap_flags & SWAP_FLAG_DISCARD_PAGES)
3020 p->flags &= ~SWP_AREA_DISCARD;
Rafael Aquinidcf6b7d2013-07-03 15:02:46 -07003021
Shaohua Li2a8f9442013-09-11 14:20:28 -07003022 /* issue a swapon-time discard if it's still required */
3023 if (p->flags & SWP_AREA_DISCARD) {
3024 int err = discard_swap(p);
3025 if (unlikely(err))
3026 pr_err("swapon: discard_swap(%p): %d\n",
3027 p, err);
Rafael Aquinidcf6b7d2013-07-03 15:02:46 -07003028 }
Hugh Dickins20137a42009-01-06 14:39:54 -08003029 }
Hugh Dickins6a6ba832009-01-06 14:39:51 -08003030
Huang, Ying4b3ef9d2017-02-22 15:45:26 -08003031 error = init_swap_address_space(p->type, maxpages);
3032 if (error)
3033 goto bad_swap;
3034
Ingo Molnarfc0abb12006-01-18 17:42:33 -08003035 mutex_lock(&swapon_mutex);
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07003036 prio = -1;
Hugh Dickins78ecba02008-07-23 21:28:23 -07003037 if (swap_flags & SWAP_FLAG_PREFER)
Cesar Eduardo Barros40531542011-03-22 16:33:37 -07003038 prio =
Hugh Dickins78ecba02008-07-23 21:28:23 -07003039 (swap_flags & SWAP_FLAG_PRIO_MASK) >> SWAP_FLAG_PRIO_SHIFT;
Shaohua Li2a8f9442013-09-11 14:20:28 -07003040 enable_swap_info(p, prio, swap_map, cluster_info, frontswap_map);
Cesar Eduardo Barrosc69dbfb2011-03-22 16:33:35 -07003041
Joe Perches756a0252016-03-17 14:19:47 -07003042 pr_info("Adding %uk swap on %s. Priority:%d extents:%d across:%lluk %s%s%s%s%s\n",
Jeff Layton91a27b22012-10-10 15:25:28 -04003043 p->pages<<(PAGE_SHIFT-10), name->name, p->prio,
Cesar Eduardo Barrosc69dbfb2011-03-22 16:33:35 -07003044 nr_extents, (unsigned long long)span<<(PAGE_SHIFT-10),
3045 (p->flags & SWP_SOLIDSTATE) ? "SS" : "",
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06003046 (p->flags & SWP_DISCARDABLE) ? "D" : "",
Rafael Aquinidcf6b7d2013-07-03 15:02:46 -07003047 (p->flags & SWP_AREA_DISCARD) ? "s" : "",
3048 (p->flags & SWP_PAGE_DISCARD) ? "c" : "",
Dan Magenheimer38b5faf2012-04-09 17:08:06 -06003049 (frontswap_map) ? "FS" : "");
Cesar Eduardo Barrosc69dbfb2011-03-22 16:33:35 -07003050
Ingo Molnarfc0abb12006-01-18 17:42:33 -08003051 mutex_unlock(&swapon_mutex);
Kay Sievers66d7dd52010-10-26 14:22:06 -07003052 atomic_inc(&proc_poll_event);
3053 wake_up_interruptible(&proc_poll_wait);
3054
Cesar Eduardo Barros9b01c352011-03-22 16:33:24 -07003055 if (S_ISREG(inode->i_mode))
3056 inode->i_flags |= S_SWAPFILE;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003057 error = 0;
3058 goto out;
3059bad_swap:
Shaohua Liebc2a1a2013-09-11 14:20:32 -07003060 free_percpu(p->percpu_cluster);
3061 p->percpu_cluster = NULL;
Cesar Eduardo Barrosbd690102011-03-22 16:33:25 -07003062 if (inode && S_ISBLK(inode->i_mode) && p->bdev) {
Cesar Eduardo Barrosf2090d22011-03-22 16:33:23 -07003063 set_blocksize(p->bdev, p->old_block_size);
3064 blkdev_put(p->bdev, FMODE_READ | FMODE_WRITE | FMODE_EXCL);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003065 }
Hugh Dickins4cd3bb12005-09-03 15:54:33 -07003066 destroy_swap_extents(p);
Cesar Eduardo Barrose8e6c2e2011-03-22 16:33:16 -07003067 swap_cgroup_swapoff(p->type);
Hugh Dickins5d337b92005-09-03 15:54:41 -07003068 spin_lock(&swap_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003069 p->swap_file = NULL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003070 p->flags = 0;
Hugh Dickins5d337b92005-09-03 15:54:41 -07003071 spin_unlock(&swap_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003072 vfree(swap_map);
Shaohua Li2a8f9442013-09-11 14:20:28 -07003073 vfree(cluster_info);
Mel Gorman52c50562011-03-22 16:30:08 -07003074 if (swap_file) {
Cesar Eduardo Barros21307812011-03-22 23:03:13 -03003075 if (inode && S_ISREG(inode->i_mode)) {
Al Viro59551022016-01-22 15:40:57 -05003076 inode_unlock(inode);
Cesar Eduardo Barros21307812011-03-22 23:03:13 -03003077 inode = NULL;
3078 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07003079 filp_close(swap_file, NULL);
Mel Gorman52c50562011-03-22 16:30:08 -07003080 }
Linus Torvalds1da177e2005-04-16 15:20:36 -07003081out:
3082 if (page && !IS_ERR(page)) {
3083 kunmap(page);
Kirill A. Shutemov09cbfea2016-04-01 15:29:47 +03003084 put_page(page);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003085 }
3086 if (name)
3087 putname(name);
Cesar Eduardo Barros9b01c352011-03-22 16:33:24 -07003088 if (inode && S_ISREG(inode->i_mode))
Al Viro59551022016-01-22 15:40:57 -05003089 inode_unlock(inode);
Tim Chen039939a2017-02-22 15:45:43 -08003090 if (!error)
3091 enable_swap_slots_cache();
Linus Torvalds1da177e2005-04-16 15:20:36 -07003092 return error;
3093}
3094
3095void si_swapinfo(struct sysinfo *val)
3096{
Hugh Dickinsefa90a92009-12-14 17:58:41 -08003097 unsigned int type;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003098 unsigned long nr_to_be_unused = 0;
3099
Hugh Dickins5d337b92005-09-03 15:54:41 -07003100 spin_lock(&swap_lock);
Hugh Dickinsefa90a92009-12-14 17:58:41 -08003101 for (type = 0; type < nr_swapfiles; type++) {
3102 struct swap_info_struct *si = swap_info[type];
3103
3104 if ((si->flags & SWP_USED) && !(si->flags & SWP_WRITEOK))
3105 nr_to_be_unused += si->inuse_pages;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003106 }
Shaohua Liec8acf22013-02-22 16:34:38 -08003107 val->freeswap = atomic_long_read(&nr_swap_pages) + nr_to_be_unused;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003108 val->totalswap = total_swap_pages + nr_to_be_unused;
Hugh Dickins5d337b92005-09-03 15:54:41 -07003109 spin_unlock(&swap_lock);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003110}
3111
3112/*
3113 * Verify that a swap entry is valid and increment its swap map count.
3114 *
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003115 * Returns error code in following case.
3116 * - success -> 0
3117 * - swp_entry is invalid -> EINVAL
3118 * - swp_entry is migration entry -> EINVAL
3119 * - swap-cache reference is requested but there is already one. -> EEXIST
3120 * - swap-cache reference is requested but the entry is not used. -> ENOENT
Hugh Dickins570a335b2009-12-14 17:58:46 -08003121 * - swap-mapped reference requested but needs continued swap count. -> ENOMEM
Linus Torvalds1da177e2005-04-16 15:20:36 -07003122 */
Hugh Dickins8d69aae2009-12-14 17:58:45 -08003123static int __swap_duplicate(swp_entry_t entry, unsigned char usage)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003124{
Hugh Dickins73c34b62009-12-14 17:58:43 -08003125 struct swap_info_struct *p;
Huang, Ying235b6212017-02-22 15:45:22 -08003126 struct swap_cluster_info *ci;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003127 unsigned long offset, type;
Hugh Dickins8d69aae2009-12-14 17:58:45 -08003128 unsigned char count;
3129 unsigned char has_cache;
Hugh Dickins253d5532009-12-14 17:58:44 -08003130 int err = -EINVAL;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003131
Andi Kleena7420aa2009-09-16 11:50:05 +02003132 if (non_swap_entry(entry))
Hugh Dickins253d5532009-12-14 17:58:44 -08003133 goto out;
Christoph Lameter06972122006-06-23 02:03:35 -07003134
Linus Torvalds1da177e2005-04-16 15:20:36 -07003135 type = swp_type(entry);
3136 if (type >= nr_swapfiles)
3137 goto bad_file;
Hugh Dickinsefa90a92009-12-14 17:58:41 -08003138 p = swap_info[type];
Linus Torvalds1da177e2005-04-16 15:20:36 -07003139 offset = swp_offset(entry);
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003140 if (unlikely(offset >= p->max))
Huang, Ying235b6212017-02-22 15:45:22 -08003141 goto out;
3142
3143 ci = lock_cluster_or_swap_info(p, offset);
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003144
Hugh Dickins253d5532009-12-14 17:58:44 -08003145 count = p->swap_map[offset];
Shaohua Liedfe23d2013-09-11 14:20:31 -07003146
3147 /*
3148 * swapin_readahead() doesn't check if a swap entry is valid, so the
3149 * swap entry could be SWAP_MAP_BAD. Check here with lock held.
3150 */
3151 if (unlikely(swap_count(count) == SWAP_MAP_BAD)) {
3152 err = -ENOENT;
3153 goto unlock_out;
3154 }
3155
Hugh Dickins253d5532009-12-14 17:58:44 -08003156 has_cache = count & SWAP_HAS_CACHE;
3157 count &= ~SWAP_HAS_CACHE;
3158 err = 0;
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003159
Hugh Dickins253d5532009-12-14 17:58:44 -08003160 if (usage == SWAP_HAS_CACHE) {
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003161
3162 /* set SWAP_HAS_CACHE if there is no cache and entry is used */
Hugh Dickins253d5532009-12-14 17:58:44 -08003163 if (!has_cache && count)
3164 has_cache = SWAP_HAS_CACHE;
3165 else if (has_cache) /* someone else added cache */
3166 err = -EEXIST;
3167 else /* no users remaining */
3168 err = -ENOENT;
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003169
3170 } else if (count || has_cache) {
Hugh Dickins253d5532009-12-14 17:58:44 -08003171
Hugh Dickins570a335b2009-12-14 17:58:46 -08003172 if ((count & ~COUNT_CONTINUED) < SWAP_MAP_MAX)
3173 count += usage;
3174 else if ((count & ~COUNT_CONTINUED) > SWAP_MAP_MAX)
Hugh Dickins253d5532009-12-14 17:58:44 -08003175 err = -EINVAL;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003176 else if (swap_count_continued(p, offset, count))
3177 count = COUNT_CONTINUED;
3178 else
3179 err = -ENOMEM;
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003180 } else
Hugh Dickins253d5532009-12-14 17:58:44 -08003181 err = -ENOENT; /* unused swap entry */
3182
3183 p->swap_map[offset] = count | has_cache;
3184
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003185unlock_out:
Huang, Ying235b6212017-02-22 15:45:22 -08003186 unlock_cluster_or_swap_info(p, ci);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003187out:
Hugh Dickins253d5532009-12-14 17:58:44 -08003188 return err;
Linus Torvalds1da177e2005-04-16 15:20:36 -07003189
3190bad_file:
Andrew Morton465c47f2013-09-11 14:20:17 -07003191 pr_err("swap_dup: %s%08lx\n", Bad_file, entry.val);
Linus Torvalds1da177e2005-04-16 15:20:36 -07003192 goto out;
3193}
Hugh Dickins253d5532009-12-14 17:58:44 -08003194
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003195/*
Hugh Dickinsaaa46862009-12-14 17:58:47 -08003196 * Help swapoff by noting that swap entry belongs to shmem/tmpfs
3197 * (in which case its reference count is never incremented).
3198 */
3199void swap_shmem_alloc(swp_entry_t entry)
3200{
3201 __swap_duplicate(entry, SWAP_MAP_SHMEM);
3202}
3203
3204/*
Hugh Dickins08259d52010-03-05 13:42:25 -08003205 * Increase reference count of swap entry by 1.
3206 * Returns 0 for success, or -ENOMEM if a swap_count_continuation is required
3207 * but could not be atomically allocated. Returns 0, just as if it succeeded,
3208 * if __swap_duplicate() fails for another reason (-EINVAL or -ENOENT), which
3209 * might occur if a page table entry has got corrupted.
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003210 */
Hugh Dickins570a335b2009-12-14 17:58:46 -08003211int swap_duplicate(swp_entry_t entry)
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003212{
Hugh Dickins570a335b2009-12-14 17:58:46 -08003213 int err = 0;
3214
3215 while (!err && __swap_duplicate(entry, 1) == -ENOMEM)
3216 err = add_swap_count_continuation(entry, GFP_ATOMIC);
3217 return err;
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003218}
Linus Torvalds1da177e2005-04-16 15:20:36 -07003219
KAMEZAWA Hiroyukicb4b86b2009-06-16 15:32:52 -07003220/*
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003221 * @entry: swap entry for which we allocate swap cache.
3222 *
Hugh Dickins73c34b62009-12-14 17:58:43 -08003223 * Called when allocating swap cache for existing swap entry,
KAMEZAWA Hiroyuki355cfa72009-06-16 15:32:53 -07003224 * This can return error codes. Returns 0 at success.
3225 * -EBUSY means there is a swap cache.
3226 * Note: return code is different from swap_duplicate().
KAMEZAWA Hiroyukicb4b86b2009-06-16 15:32:52 -07003227 */
3228int swapcache_prepare(swp_entry_t entry)
3229{
Hugh Dickins253d5532009-12-14 17:58:44 -08003230 return __swap_duplicate(entry, SWAP_HAS_CACHE);
KAMEZAWA Hiroyukicb4b86b2009-06-16 15:32:52 -07003231}
3232
Mel Gormanf981c592012-07-31 16:44:47 -07003233struct swap_info_struct *page_swap_info(struct page *page)
3234{
3235 swp_entry_t swap = { .val = page_private(page) };
Mel Gormanf981c592012-07-31 16:44:47 -07003236 return swap_info[swp_type(swap)];
3237}
3238
3239/*
3240 * out-of-line __page_file_ methods to avoid include hell.
3241 */
3242struct address_space *__page_file_mapping(struct page *page)
3243{
Sasha Levin309381fea2014-01-23 15:52:54 -08003244 VM_BUG_ON_PAGE(!PageSwapCache(page), page);
Mel Gormanf981c592012-07-31 16:44:47 -07003245 return page_swap_info(page)->swap_file->f_mapping;
3246}
3247EXPORT_SYMBOL_GPL(__page_file_mapping);
3248
3249pgoff_t __page_file_index(struct page *page)
3250{
3251 swp_entry_t swap = { .val = page_private(page) };
Sasha Levin309381fea2014-01-23 15:52:54 -08003252 VM_BUG_ON_PAGE(!PageSwapCache(page), page);
Mel Gormanf981c592012-07-31 16:44:47 -07003253 return swp_offset(swap);
3254}
3255EXPORT_SYMBOL_GPL(__page_file_index);
3256
Linus Torvalds1da177e2005-04-16 15:20:36 -07003257/*
Hugh Dickins570a335b2009-12-14 17:58:46 -08003258 * add_swap_count_continuation - called when a swap count is duplicated
3259 * beyond SWAP_MAP_MAX, it allocates a new page and links that to the entry's
3260 * page of the original vmalloc'ed swap_map, to hold the continuation count
3261 * (for that entry and for its neighbouring PAGE_SIZE swap entries). Called
3262 * again when count is duplicated beyond SWAP_MAP_MAX * SWAP_CONT_MAX, etc.
3263 *
3264 * These continuation pages are seldom referenced: the common paths all work
3265 * on the original swap_map, only referring to a continuation page when the
3266 * low "digit" of a count is incremented or decremented through SWAP_MAP_MAX.
3267 *
3268 * add_swap_count_continuation(, GFP_ATOMIC) can be called while holding
3269 * page table locks; if it fails, add_swap_count_continuation(, GFP_KERNEL)
3270 * can be called after dropping locks.
3271 */
3272int add_swap_count_continuation(swp_entry_t entry, gfp_t gfp_mask)
3273{
3274 struct swap_info_struct *si;
Huang, Ying235b6212017-02-22 15:45:22 -08003275 struct swap_cluster_info *ci;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003276 struct page *head;
3277 struct page *page;
3278 struct page *list_page;
3279 pgoff_t offset;
3280 unsigned char count;
3281
3282 /*
3283 * When debugging, it's easier to use __GFP_ZERO here; but it's better
3284 * for latency not to zero a page while GFP_ATOMIC and holding locks.
3285 */
3286 page = alloc_page(gfp_mask | __GFP_HIGHMEM);
3287
3288 si = swap_info_get(entry);
3289 if (!si) {
3290 /*
3291 * An acceptable race has occurred since the failing
3292 * __swap_duplicate(): the swap entry has been freed,
3293 * perhaps even the whole swap_map cleared for swapoff.
3294 */
3295 goto outer;
3296 }
3297
3298 offset = swp_offset(entry);
Huang, Ying235b6212017-02-22 15:45:22 -08003299
3300 ci = lock_cluster(si, offset);
3301
Hugh Dickins570a335b2009-12-14 17:58:46 -08003302 count = si->swap_map[offset] & ~SWAP_HAS_CACHE;
3303
3304 if ((count & ~COUNT_CONTINUED) != SWAP_MAP_MAX) {
3305 /*
3306 * The higher the swap count, the more likely it is that tasks
3307 * will race to add swap count continuation: we need to avoid
3308 * over-provisioning.
3309 */
3310 goto out;
3311 }
3312
3313 if (!page) {
Huang, Ying235b6212017-02-22 15:45:22 -08003314 unlock_cluster(ci);
Shaohua Liec8acf22013-02-22 16:34:38 -08003315 spin_unlock(&si->lock);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003316 return -ENOMEM;
3317 }
3318
3319 /*
3320 * We are fortunate that although vmalloc_to_page uses pte_offset_map,
Seth Jennings2de1a7e2013-11-12 15:07:46 -08003321 * no architecture is using highmem pages for kernel page tables: so it
3322 * will not corrupt the GFP_ATOMIC caller's atomic page table kmaps.
Hugh Dickins570a335b2009-12-14 17:58:46 -08003323 */
3324 head = vmalloc_to_page(si->swap_map + offset);
3325 offset &= ~PAGE_MASK;
3326
3327 /*
3328 * Page allocation does not initialize the page's lru field,
3329 * but it does always reset its private field.
3330 */
3331 if (!page_private(head)) {
3332 BUG_ON(count & COUNT_CONTINUED);
3333 INIT_LIST_HEAD(&head->lru);
3334 set_page_private(head, SWP_CONTINUED);
3335 si->flags |= SWP_CONTINUED;
3336 }
3337
3338 list_for_each_entry(list_page, &head->lru, lru) {
3339 unsigned char *map;
3340
3341 /*
3342 * If the previous map said no continuation, but we've found
3343 * a continuation page, free our allocation and use this one.
3344 */
3345 if (!(count & COUNT_CONTINUED))
3346 goto out;
3347
Cong Wang9b04c5f2011-11-25 23:14:39 +08003348 map = kmap_atomic(list_page) + offset;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003349 count = *map;
Cong Wang9b04c5f2011-11-25 23:14:39 +08003350 kunmap_atomic(map);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003351
3352 /*
3353 * If this continuation count now has some space in it,
3354 * free our allocation and use this one.
3355 */
3356 if ((count & ~COUNT_CONTINUED) != SWAP_CONT_MAX)
3357 goto out;
3358 }
3359
3360 list_add_tail(&page->lru, &head->lru);
3361 page = NULL; /* now it's attached, don't free it */
3362out:
Huang, Ying235b6212017-02-22 15:45:22 -08003363 unlock_cluster(ci);
Shaohua Liec8acf22013-02-22 16:34:38 -08003364 spin_unlock(&si->lock);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003365outer:
3366 if (page)
3367 __free_page(page);
3368 return 0;
3369}
3370
3371/*
3372 * swap_count_continued - when the original swap_map count is incremented
3373 * from SWAP_MAP_MAX, check if there is already a continuation page to carry
3374 * into, carry if so, or else fail until a new continuation page is allocated;
3375 * when the original swap_map count is decremented from 0 with continuation,
3376 * borrow from the continuation and report whether it still holds more.
Huang, Ying235b6212017-02-22 15:45:22 -08003377 * Called while __swap_duplicate() or swap_entry_free() holds swap or cluster
3378 * lock.
Hugh Dickins570a335b2009-12-14 17:58:46 -08003379 */
3380static bool swap_count_continued(struct swap_info_struct *si,
3381 pgoff_t offset, unsigned char count)
3382{
3383 struct page *head;
3384 struct page *page;
3385 unsigned char *map;
3386
3387 head = vmalloc_to_page(si->swap_map + offset);
3388 if (page_private(head) != SWP_CONTINUED) {
3389 BUG_ON(count & COUNT_CONTINUED);
3390 return false; /* need to add count continuation */
3391 }
3392
3393 offset &= ~PAGE_MASK;
3394 page = list_entry(head->lru.next, struct page, lru);
Cong Wang9b04c5f2011-11-25 23:14:39 +08003395 map = kmap_atomic(page) + offset;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003396
3397 if (count == SWAP_MAP_MAX) /* initial increment from swap_map */
3398 goto init_map; /* jump over SWAP_CONT_MAX checks */
3399
3400 if (count == (SWAP_MAP_MAX | COUNT_CONTINUED)) { /* incrementing */
3401 /*
3402 * Think of how you add 1 to 999
3403 */
3404 while (*map == (SWAP_CONT_MAX | COUNT_CONTINUED)) {
Cong Wang9b04c5f2011-11-25 23:14:39 +08003405 kunmap_atomic(map);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003406 page = list_entry(page->lru.next, struct page, lru);
3407 BUG_ON(page == head);
Cong Wang9b04c5f2011-11-25 23:14:39 +08003408 map = kmap_atomic(page) + offset;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003409 }
3410 if (*map == SWAP_CONT_MAX) {
Cong Wang9b04c5f2011-11-25 23:14:39 +08003411 kunmap_atomic(map);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003412 page = list_entry(page->lru.next, struct page, lru);
3413 if (page == head)
3414 return false; /* add count continuation */
Cong Wang9b04c5f2011-11-25 23:14:39 +08003415 map = kmap_atomic(page) + offset;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003416init_map: *map = 0; /* we didn't zero the page */
3417 }
3418 *map += 1;
Cong Wang9b04c5f2011-11-25 23:14:39 +08003419 kunmap_atomic(map);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003420 page = list_entry(page->lru.prev, struct page, lru);
3421 while (page != head) {
Cong Wang9b04c5f2011-11-25 23:14:39 +08003422 map = kmap_atomic(page) + offset;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003423 *map = COUNT_CONTINUED;
Cong Wang9b04c5f2011-11-25 23:14:39 +08003424 kunmap_atomic(map);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003425 page = list_entry(page->lru.prev, struct page, lru);
3426 }
3427 return true; /* incremented */
3428
3429 } else { /* decrementing */
3430 /*
3431 * Think of how you subtract 1 from 1000
3432 */
3433 BUG_ON(count != COUNT_CONTINUED);
3434 while (*map == COUNT_CONTINUED) {
Cong Wang9b04c5f2011-11-25 23:14:39 +08003435 kunmap_atomic(map);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003436 page = list_entry(page->lru.next, struct page, lru);
3437 BUG_ON(page == head);
Cong Wang9b04c5f2011-11-25 23:14:39 +08003438 map = kmap_atomic(page) + offset;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003439 }
3440 BUG_ON(*map == 0);
3441 *map -= 1;
3442 if (*map == 0)
3443 count = 0;
Cong Wang9b04c5f2011-11-25 23:14:39 +08003444 kunmap_atomic(map);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003445 page = list_entry(page->lru.prev, struct page, lru);
3446 while (page != head) {
Cong Wang9b04c5f2011-11-25 23:14:39 +08003447 map = kmap_atomic(page) + offset;
Hugh Dickins570a335b2009-12-14 17:58:46 -08003448 *map = SWAP_CONT_MAX | count;
3449 count = COUNT_CONTINUED;
Cong Wang9b04c5f2011-11-25 23:14:39 +08003450 kunmap_atomic(map);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003451 page = list_entry(page->lru.prev, struct page, lru);
3452 }
3453 return count == COUNT_CONTINUED;
3454 }
3455}
3456
3457/*
3458 * free_swap_count_continuations - swapoff free all the continuation pages
3459 * appended to the swap_map, after swap_map is quiesced, before vfree'ing it.
3460 */
3461static void free_swap_count_continuations(struct swap_info_struct *si)
3462{
3463 pgoff_t offset;
3464
3465 for (offset = 0; offset < si->max; offset += PAGE_SIZE) {
3466 struct page *head;
3467 head = vmalloc_to_page(si->swap_map + offset);
3468 if (page_private(head)) {
Geliang Tang0d576d22016-01-14 15:21:49 -08003469 struct page *page, *next;
3470
3471 list_for_each_entry_safe(page, next, &head->lru, lru) {
3472 list_del(&page->lru);
Hugh Dickins570a335b2009-12-14 17:58:46 -08003473 __free_page(page);
3474 }
3475 }
3476 }
3477}