From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:46877) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1S4A0d-0005S7-6K for qemu-devel@nongnu.org; Sun, 04 Mar 2012 06:53:52 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1S4A0b-0007fH-D1 for qemu-devel@nongnu.org; Sun, 04 Mar 2012 06:53:50 -0500 Received: from gate.crashing.org ([63.228.1.57]:34530) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1S4A0b-0007ZS-3m for qemu-devel@nongnu.org; Sun, 04 Mar 2012 06:53:49 -0500 Message-ID: <1330861999.11728.79.camel@pasglop> From: Benjamin Herrenschmidt Date: Sun, 04 Mar 2012 22:53:19 +1100 In-Reply-To: <4F5348CE.8070909@redhat.com> References: <1330043012-30556-1-git-send-email-david@gibson.dropbear.id.au> <1330043012-30556-7-git-send-email-david@gibson.dropbear.id.au> <4F4CC96B.6040003@redhat.com> <1330465707.11728.29.camel@pasglop> <4F5348CE.8070909@redhat.com> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit Mime-Version: 1.0 Subject: Re: [Qemu-devel] [PATCH 6/6] kvm: Fix dirty tracking with large kernel page size List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Avi Kivity Cc: Marcelo Tosatti , qemu-devel@nongnu.org, anthony@codemonkey.ws, David Gibson On Sun, 2012-03-04 at 12:49 +0200, Avi Kivity wrote: > On 02/28/2012 11:48 PM, Benjamin Herrenschmidt wrote: > > On Tue, 2012-02-28 at 14:32 +0200, Avi Kivity wrote: > > > > > What if TARGET_PAGE_SIZE > getpagesize()? Or is that impossible? > > > > We have yet to encounter such a case. It's not currently possible on > > power (some old embedded chips could do 1K and 2K page sizes in the TLB > > iirc but we never supported that in Linux and it's being phased out in > > HW). > > > > I suggest that gets dealt with when/if it needs to, which means probably > > never :-) > > Doesn't ppc support both 4k and 64k pages? Suppose you run a 4k guest > on a 64k host? > > Maybe I'm misremembering or misunderstanding something. TARGET_PAGE_SIZE in qemu is always 4k for powerpc, it's a compile time #define. The host kernel exposes the dirty bit map with a bit per -host- kernel PAGE_SIZE (which is what getpagesize() gets you in qemu). My patch makes thus makes things work when the host uses 64K page sizes. In all cases, the guest page size is irrelevant, this is purely a problem between the host kernel and qemu. Cheers, Ben.