lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20070204153321.GC10477@curandero.marconia.cz>
Date:	Sun, 4 Feb 2007 16:33:21 +0100
From:	Michal Hocko <mstsxfx@...il.com>
To:	Arjan van de Ven <arjan@...radead.org>
Cc:	linux-kernel@...r.kernel.org
Subject: Re: mm: how to check for kernel pages

On Sun, Feb 04, 2007 at 02:57:30PM +0100, Arjan van de Ven wrote:
> On Sun, 2007-02-04 at 12:02 +0100, Michal Hocko wrote:
> > Hi,
> > is there any effective and fast way how to find out whether page
> > given by its page frame number is currenly used by (mapped by) kernel?
> 
> what do you want to use this for? The answer to your question greatly
> depends on that...

Sorry for not being more precise. As a part of my thesis work I need to
migrate pages. I greatly use mm/migrate.c code.  
I assume that not all pages can be migrated - especially those used by
kernel (where direct virtual to physical mapping is used).
So I intended something like following code:

/* Returns 0 if page is suitable to be migration source */
int check_migrate_page(struct page * page)
{
	return PageBuddy(page) || PageCompound(page) || ... 
		kernel_page(page);
}

/* Steals pfn page from its current user(s) and replace it by newly
 * allocated page. pfn page structure is returned if page was migrated
 * to new location (can be reused by caller) or NULL otherwise.
 */
struct page * steal_page(unsigned long pfn)
{
	int ret;
	struct page *page, *target_page;

	page = pfn_to_page(pfn);
	if(!page)
		goto bad_page;

	ret = check_migrate_page(page);
	if(ret)
		goto bad_page;

	target_page = alloc_pages(flags, 0);
	/* uses migrate_pages function internally */
	ret = do_migration(page, target_page);
	if(ret)
		goto bad_page;

	/* TODO clear page frame data. */
	return page;
bad_page:
	return NULL;
}

Please add me to Cc, because I am not the list member.
Best regards
-- 
Michal Hocko

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ