xref: /openbmc/linux/arch/powerpc/kernel/suspend.c (revision 7f8998c7aef3ac9c5f3f2943e083dfa6302e90d0)
149c3df6aSVivek Goyal /*
249c3df6aSVivek Goyal  * Suspend support specific for power.
349c3df6aSVivek Goyal  *
449c3df6aSVivek Goyal  * Distribute under GPLv2
549c3df6aSVivek Goyal  *
6a2531293SPavel Machek  * Copyright (c) 2002 Pavel Machek <pavel@ucw.cz>
749c3df6aSVivek Goyal  * Copyright (c) 2001 Patrick Mochel <mochel@osdl.org>
849c3df6aSVivek Goyal  */
949c3df6aSVivek Goyal 
1027ac792cSAndrea Righi #include <linux/mm.h>
1149c3df6aSVivek Goyal #include <asm/page.h>
12*7f8998c7SGeert Uytterhoeven #include <asm/sections.h>
1349c3df6aSVivek Goyal 
1449c3df6aSVivek Goyal /*
1549c3df6aSVivek Goyal  *	pfn_is_nosave - check if given pfn is in the 'nosave' section
1649c3df6aSVivek Goyal  */
1749c3df6aSVivek Goyal 
1849c3df6aSVivek Goyal int pfn_is_nosave(unsigned long pfn)
1949c3df6aSVivek Goyal {
2049c3df6aSVivek Goyal 	unsigned long nosave_begin_pfn = __pa(&__nosave_begin) >> PAGE_SHIFT;
2149c3df6aSVivek Goyal 	unsigned long nosave_end_pfn = PAGE_ALIGN(__pa(&__nosave_end)) >> PAGE_SHIFT;
2249c3df6aSVivek Goyal 	return (pfn >= nosave_begin_pfn) && (pfn < nosave_end_pfn);
2349c3df6aSVivek Goyal }
24