Re: question on symbol exports

From: Chris Friesen
Date: Tue Feb 01 2005 - 12:03:19 EST


Arjan van de Ven wrote:
On Tue, 2005-02-01 at 09:37 -0600, Chris Friesen wrote:

I've got a module that I'm porting forward from 2.4. The basic idea is that we want to be able to track pages dirtied by an application. The system has no swap, so we use the dirty bit to get this information. On demand we walk the page tables belonging to the process, store the addresses of any dirty ones, flush the tlb, and mark them clean.


afaik one doesn't need to do a tlb flush in code that clears the dirty
bit, as long as you use the proper vm functions to do so. (if those need a tlb flush, those are supposed to do that for you
afaik).

I've been in contact with one of the developers of the code. The reason we flush the tlb is so that on the next write the cpu has to fault it in and set the dirty bit. Does that make sense? I should try experimenting.....

Also note that your code isn't dealing with 4 level pagetables....

2.6.9 doesn't have 4 level pagetables. We'll have to port it forward when we eventually upgrade.

> And
pagetable walking in drivers is basically almost always a mistake and a
sign that something is wrong.

I'd rather not be doing it, but there's no nice generic va_to_pte() function. There have been patches, and ppc has one, but as a whole I don't know of any nice way to do this.

Chris

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