更换内存容量和挂载bank需要修改的地方——Starting kernel ... Uncompressing Linux...的另外一种可能

  很久没有写一篇比较完整的技术文章,今天刚好遇到一个问题,解决了感触比较大:这个问题明明是我以前遇到过的,但是我却记不得,我还一筹莫展,没意识到问题所在,只怪我当时没有写当时的解决办法,一年后在写出来亡羊补牢也不迟。

         问题是这样的:我们自己做的电路板,在wince 下没有任何问题,但是在Android下的时候,偶尔会提示inand 存储错误,当时我认为有两种可能性:

1、自己画的电路板不行,虽然wince 下OK,但是Android对硬件稳定性要求更高,所以只能从硬件上找原因

2、kernel或者Android层的问题,因为uboot运行状态不错,应该是上层驱动的问题



        正好有空,那就先验证 问题2的可能性:我找了一个在开发板上运行良好的kernel和Android包在上面运行试试。结果很不爽,居然内核还没起来系统就死了,打印最后的信息是:


Starting kernel ...



Uncompressing Linux...


              后来百度原因,无非是:

1> U-boot中的参数(console)没有传到内核。
2> U-boot的时钟设置与Kernel的不一致。
3> U-boot中的Machine ID设置的与Kernel不一致。


           仔细检查者三项,都不存在问题,到底是怎么回事呢?因为我只是换成我的uboot而已,那么我就和比较开发板的uboot 比较一下,比较吓一跳,突然记起来我板子的内存挂载的bank和开发板的有点区别,通道是不一样的..............很让人伤心的就是我以前1GB修改的512MB的时候就改过这个部分,我居然忘记这点要素,于是修改如下:

1.uboot中修改  board\samsung\smdkc110\lowlevel_init.S




  • .set __base,0x200    ==>> .set __base,0x400  
  •    
  • // 256MB for SDRAM with cacheable  
  •    
  • .rept 0xD00 - 0xC00  
  •    
  • FL_SECTION_ENTRY __base,3,0,1,1  
  •    
  • .set __base,__base+1  
  •    
  • .endr  




2 .uboot中 board/samsung/smdkc110/smdkc110.c       的 ulong virt_to_phy_smdkc110(ulong addr)函数根据自己内存实际挂载地址来修改

3.uboot中 3 include\configs\smdkv210single.h 内存控制器以及内存bank 大小等参数设置也根据实际情况来修改

4.内核中的修改


arch/arm/mach-s5pv210/include/mach/map.h


  • #define S5P_PA_SDRAM           S5PV210_PA_SDRAM  
  •    
  • #define S5PV210_PA_SDRAM        (0x40000000)  

arch/arm/mach-s5pv210/include/mach/memory.h

  • #define PHYS_OFFSET         UL(0x40000000)  

arch/arm/mach-s5pv210/Makefile.boot


  • zreladdr-y  := 0x40008000   
  • params_phys-y  := 0x40000100  
          大概情况就是这样,上面的数值,可以根据硬件的接法来修改,改完后重新编译出的zImage就可以顺利启动了,到了Android也没任何异常,顺利完工。 在这了做一个总结:
Starting kernel ...
Uncompressing Linux...
            原因,除了:

1> U-boot中的参数(console)没有传到内核。
2> U-boot的时钟设置与Kernel的不一致。
3> U-boot中的Machine ID设置的与Kernel不一致。



还应该增加一种可能性:

4> 内核中的内存设置和u-boot不一致导致无法启动内核

你可能感兴趣的:(kernel,...,starting)