We have dealt with this in our release of U-Boot since we only support
64-bit Linux. We use the n32 ABI with U-Boot and set it up to use a TLB
entry to map U-Boot into a 32-bit addressable area.
We have some special memcpy type routines that can handle the 64-bit
addressing.

All of our I/O registers require 64-bit addressing so we use assembly
wrappers to do the actual read/writes to those addresses.

-Aaron Williams

On 06/21/2011 07:07 PM, hacklu wrote:
>   I have a 64bit cnMips borad.In the mail list archives,it says  "uboot is 
> 32bit,even in the 64bit cpu."
> but how to understand that?
> I have a guess,is the 64bit cpu support a 32bit-mode,then when does it switch 
> to 64bit-mode to load 64-bit linux?
>
> btw,I have an other question,according to  <see mips run linux>,linux run in 
> the _xkseg_ segment. so the first two bit virtual address in kernel space 
> must be 11,
> like 11xx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx xxxx 
> xxxx xxxx (64bit).
> but when I printf a variable' address in a foo driver,is say 
> 0xa80000041c2ea180. not start of _11_.
> the memory mapping mode has feazed me for _long_ _long_time.
>
> Dear Wolfgang(or someone else who can anwser me),thanks 
>                               
> --------------
> hacklu
> 2011-06-22
>

_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot

Reply via email to