blob: d1767dfb0d95d76dff1b91bb5c2b40f18fee8f6f [file] [log] [blame]
Daniel De Graaf803eb042011-03-14 11:29:37 -04001/******************************************************************************
2 * Xen balloon functionality
3 */
4
5#define RETRY_UNLIMITED 0
6
7struct balloon_stats {
8 /* We aim for 'current allocation' == 'target allocation'. */
9 unsigned long current_pages;
10 unsigned long target_pages;
David Vrabel1cf6a6c2015-06-25 16:29:18 +010011 unsigned long target_unpopulated;
Daniel De Graaf803eb042011-03-14 11:29:37 -040012 /* Number of pages in high- and low-memory balloons. */
13 unsigned long balloon_low;
14 unsigned long balloon_high;
David Vrabelde5a77d2015-06-25 12:08:20 +010015 unsigned long total_pages;
Daniel De Graaf803eb042011-03-14 11:29:37 -040016 unsigned long schedule_delay;
17 unsigned long max_schedule_delay;
18 unsigned long retry_count;
19 unsigned long max_retry_count;
20};
21
22extern struct balloon_stats balloon_stats;
23
24void balloon_set_new_target(unsigned long target);
Konrad Rzeszutek Wilkb6f30672011-03-15 10:23:57 -040025
David Vrabel81b286e2015-06-25 13:12:46 +010026int alloc_xenballooned_pages(int nr_pages, struct page **pages);
Stefano Stabellini693394b2011-09-29 11:57:55 +010027void free_xenballooned_pages(int nr_pages, struct page **pages);
Dan Magenheimera50777c2011-07-08 12:26:21 -060028
Kay Sievers07068022011-12-14 15:32:50 -080029struct device;
Dan Magenheimera50777c2011-07-08 12:26:21 -060030#ifdef CONFIG_XEN_SELFBALLOONING
Kay Sievers07068022011-12-14 15:32:50 -080031extern int register_xen_selfballooning(struct device *dev);
Dan Magenheimera50777c2011-07-08 12:26:21 -060032#else
Kay Sievers07068022011-12-14 15:32:50 -080033static inline int register_xen_selfballooning(struct device *dev)
Dan Magenheimera50777c2011-07-08 12:26:21 -060034{
35 return -ENOSYS;
36}
37#endif