[PATCH v3 RESEND 05/17] ARM: LPAE: support 64-bit virt_to_phys patching

Nicolas Pitre nicolas.pitre at linaro.org
Mon Sep 24 18:55:25 EDT 2012


On Mon, 24 Sep 2012, Russell King - ARM Linux wrote:

> On Mon, Sep 24, 2012 at 06:32:22PM -0400, Nicolas Pitre wrote:
> > We don't want to limit lowmem.  The lowmem is very precious memory and 
> > we want to maximize its size.  In that case it is probably best to 
> > implement a real patchable 64-bit addition rather than artificially 
> > restricting the lowmem size.
> 
> You don't need to.  You can solve the V->P translation like this:
> 
>         movw    %hi, #0xVWXY            @ fixup
>         adds    %lo, %lo, #offset       @ fixup
>         adc     %hi, %hi, #0

That's exactly what I mean when I say a real 64-bit addition.  Despite 
one of the arguments being a 32 bit value, the overflow needs to be 
carried to the high part.

> which is probably the simplest way to do the fixup - keep the existing
> fixup code, and add support for that movw instruction.  And that will
> work across any 4GB boundary just fine (we won't have more than 4GB of
> virtual address space on a 32-bit CPU anyway, so we only have to worry
> about one carry.)

Exactly.

> And the P->V translation is truncating anyway, so that is just:
> 
> 	sub	%lo, %lo, #offset
> 
> and nothing more.

Yes, that's what the posted code does already.


Nicolas



More information about the linux-arm-kernel mailing list