All of lore.kernel.org
 help / color / mirror / Atom feed
From: Gerlando Falauto <gerlando.falauto@keymile.com>
To: Sergei Trofimovich <slyich@gmail.com>
Cc: Ian Campbell <ijc@hellion.org.uk>,
	Russell King <rmk+kernel@arm.linux.org.uk>,
	linux-kernel@vger.kernel.org, Will Deacon <will.deacon@arm.com>,
	Nicolas Pitre <nicolas.pitre@linaro.org>,
	Tony Lindgren <tony@atomide.com>
Subject: Re: arm: CONFIG_ARM_PATCH_PHYS_VIRT=y is broken on kirkwood
Date: Fri, 07 Dec 2012 17:01:42 +0100	[thread overview]
Message-ID: <50C212E6.9010200@keymile.com> (raw)
In-Reply-To: <20120410211210.310b65ea@sf.home>

Hi everyone,

On 04/10/2012 08:12 PM, Sergei Trofimovich wrote:
> On Mon, 09 Apr 2012 22:28:28 +0100
> Ian Campbell<ijc@hellion.org.uk>  wrote:
>
>> On Sun, 2012-04-08 at 11:59 +0300, Sergei Trofimovich wrote:
>>> In order to make the box boot I had to set:
>>>      CONFIG_EMBEDDED=y
>>>      # CONFIG_ARM_PATCH_PHYS_VIRT is not set
>>>     CONFIG_PHYS_OFFSET=0x0
>>>
>>> Do you have an idea why it does not boot anymore by default?
>>
>> There is a u-boot commit which fixes this issue:
>>
>> commit 679530278d5a79d34e356ad2d452f4400953bfc2
>> Author: Michael Walle<[michael@walle.cc]>
>> Date:   Mon Feb 6 22:42:10 2012 +0530
>>
>>      arm, arm-kirkwood: disable l2c before linux boot
>>
>>      The decompressor expects the L2 cache to be disabled. This fixes booting
>>      some kernels, which have CONFIG_ARM_PATCH_PHYS_VIRT enabled.
>>
>>      Signed-off-by: Michael Walle<michael@walle.cc>
>>      Acked-by: Prafulla Wadaskar<prafulla@marvell.com>
>>      Cc: Albert ARIBAUD<albert.u.boot@aribaud.net>
>>      Cc: Prafulla Wadaskar<prafulla@marvell.com>
>>      Cc: Wolfgang Denk<wd@denx.de>
>
> Thank you, Ian. Updating u-boot helped!
>
> Sorry for the noise.

I guess if updating u-boot is not an option, there's no other way around 
it than disabling CONFIG_ARM_PATCH_PHYS_VIRT altogether.

Could someone (Russell?) simply state what the consequences are of 
disabling such option? (Or, conversely, what its advantages are?)
Only reference I found is the original commit, but I couldn't really 
understand what it does (or to what purpose), see at the bottom.

Thank you very much!
Gerlando

commit dc21af99fadcfa0ae65b52fd0895f85824f0c288
Author: Russell King <rmk+kernel@arm.linux.org.uk>
Date:   Tue Jan 4 19:09:43 2011 +0000

     ARM: P2V: introduce phys_to_virt/virt_to_phys runtime patching

     This idea came from Nicolas, Eric Miao produced an initial version,
     which was then rewritten into this.

     Patch the physical to virtual translations at runtime.  As we modify
     the code, this makes it incompatible with XIP kernels, but allows us
     to achieve this with minimal loss of performance.

     As many translations are of the form:

         physical = virtual + (PHYS_OFFSET - PAGE_OFFSET)
         virtual = physical - (PHYS_OFFSET - PAGE_OFFSET)

     we generate an 'add' instruction for __virt_to_phys(), and a 'sub'
     instruction for __phys_to_virt().  We calculate at run time 
(PHYS_OFFSET
     - PAGE_OFFSET) by comparing the address prior to MMU initialization 
with
     where it should be once the MMU has been initialized, and place this
     constant into the above add/sub instructions.

     Once we have (PHYS_OFFSET - PAGE_OFFSET), we can calculate the real
     PHYS_OFFSET as PAGE_OFFSET is a build-time constant, and save this for
     the C-mode PHYS_OFFSET variable definition to use.

     At present, we are unable to support Realview with Sparsemem enabled
     as this uses a complex mapping function, and MSM as this requires a
     constant which will not fit in our math instruction.

     Add a module version magic string for this feature to prevent
     incompatible modules being loaded.

     Tested-by: Tony Lindgren <tony@atomide.com>
     Reviewed-by: Nicolas Pitre <nicolas.pitre@linaro.org>
     Tested-by: Nicolas Pitre <nicolas.pitre@linaro.org>
     Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>



  reply	other threads:[~2012-12-07 16:14 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-04-08  8:59 arm: CONFIG_ARM_PATCH_PHYS_VIRT=y is broken on kirkwood Sergei Trofimovich
2012-04-09 21:28 ` Ian Campbell
2012-04-10 18:12   ` Sergei Trofimovich
2012-12-07 16:01     ` Gerlando Falauto [this message]
2012-12-07 18:54       ` Nicolas Pitre

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=50C212E6.9010200@keymile.com \
    --to=gerlando.falauto@keymile.com \
    --cc=ijc@hellion.org.uk \
    --cc=linux-kernel@vger.kernel.org \
    --cc=nicolas.pitre@linaro.org \
    --cc=rmk+kernel@arm.linux.org.uk \
    --cc=slyich@gmail.com \
    --cc=tony@atomide.com \
    --cc=will.deacon@arm.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.