Linux 3.11 compat: Replace num_physpages with totalram_pages

num_physpages was removed by
torvalds/linux@cfa11e08ed, so lets replace
it with totalram_pages.

This is a bug fix as much as it is a compatibility fix because
num_physpages did not reflect the number of pages actually available to
the kernel:

http://lkml.indiana.edu/hypermail/linux/kernel/0908.2/01001.html

Also, there are known issues with memory calculations when ZFS is in a
Xen dom0. There is a chance that using totalram_pages could resolve
them. This conjecture is untested at the time of writing.

Signed-off-by: Richard Yao <ryao@gentoo.org>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #273
This commit is contained in:
Richard Yao 2013-08-07 04:50:04 -04:00 committed by Brian Behlendorf
parent 0b15402db3
commit ba06298072
2 changed files with 4 additions and 3 deletions

View File

@ -41,7 +41,7 @@
*/ */
#define membar_producer() smp_wmb() #define membar_producer() smp_wmb()
#define physmem num_physpages #define physmem totalram_pages
#define freemem nr_free_pages() #define freemem nr_free_pages()
#define availrmem spl_kmem_availrmem() #define availrmem spl_kmem_availrmem()

View File

@ -36,6 +36,7 @@
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/proc_compat.h> #include <linux/proc_compat.h>
#include <linux/file_compat.h> #include <linux/file_compat.h>
#include <linux/swap.h>
#include <sys/sysmacros.h> #include <sys/sysmacros.h>
#include <spl-debug.h> #include <spl-debug.h>
#include <spl-trace.h> #include <spl-trace.h>
@ -548,7 +549,7 @@ trace_print_to_console(struct spl_debug_header *hdr, int mask, const char *buf,
static int static int
trace_max_debug_mb(void) trace_max_debug_mb(void)
{ {
return MAX(512, ((num_physpages >> (20 - PAGE_SHIFT)) * 80) / 100); return MAX(512, ((totalram_pages >> (20 - PAGE_SHIFT)) * 80) / 100);
} }
static struct trace_page * static struct trace_page *
@ -1188,7 +1189,7 @@ spl_debug_init(void)
/* If spl_debug_mb is set to an invalid value or uninitialized /* If spl_debug_mb is set to an invalid value or uninitialized
* then just make the total buffers smp_num_cpus TCD_MAX_PAGES */ * then just make the total buffers smp_num_cpus TCD_MAX_PAGES */
if (max > (num_physpages >> (20 - 2 - PAGE_SHIFT)) / 5 || if (max > (totalram_pages >> (20 - 2 - PAGE_SHIFT)) / 5 ||
max >= 512 || max < 0) { max >= 512 || max < 0) {
max = TCD_MAX_PAGES; max = TCD_MAX_PAGES;
} else { } else {