[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4BFA1F92.2080802@redhat.com>
Date: Mon, 24 May 2010 09:41:22 +0300
From: Avi Kivity <avi@...hat.com>
To: Cesar Eduardo Barros <cesarb@...arb.net>
CC: linux-mm@...ck.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH 3/3] mm: Swap checksum
On 05/23/2010 09:58 PM, Cesar Eduardo Barros wrote:
> Em 23-05-2010 12:19, Avi Kivity escreveu:
>> On 64-bit, we may be able to store the checksum in the pte, if the swap
>> device is small enough.
>
> Which pte?
All of them.
> Correct me if I am wrong, but I do not think all pages written to the
> swap have exactly one pte pointing to them. And I have not looked at
> the shmem.c code yet, but does it even use ptes?
Well, the ptes need the swap address written into them, so they are
already found and updated somehow. All that's needed is to update the
value written to also include the checksum.
> It might be possible (find all ptes and write the 32-bit checksum to
> them, do something else for shmem, have two different code paths for
> small/large swapfiles), but I do not know if the memory savings are
> worth the extra complexity (especially the need for two separate code
> paths).
Certainly not at first, but later it may be worthwhile.
>
>> If we take the trouble to touch the page, we may as well compare it
>> against zero, and if so drop it instead of swapping it out.
>
> The problem with this is that the page is touched deep inside the
> crc32c code, which might even be using hardware instructions
> (crc32c-intel). So we would need to read it two times to compare
> against zero.
The second read is very cheap since the page is already in cache. Also,
we fail early when any word is nonzero, so usually the compare exits
quickly.
>
> One possibility could be to compare the full page against zero only if
> its crc is a specific value (the crc32c of a page full of zeros). This
> would not be too slow (we would be wasting time only when we have a
> very high probability of saving much more time), and not need to touch
> the crc32c code at all. I would only have to look at how this messes
> up the state tracking (i.e. how to make it track the fact that,
> instead of getting written out, this is now a zeroed page).
Instead of returning a swap pte to be written to the page tables, return
a zeroed pte.
> Other than that, it seems a good idea.
>
--
Do not meddle in the internals of kernels, for they are subtle and quick to panic.
--
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