[原创] 更换内存容量和挂载bank需要修改的地方

Wince.Android   2015-5-15 16:47 楼主
很久没有写一篇比较完整的技术文章,今天刚好遇到一个问题,解决了感触比较大:这个问题明明是我以前遇到过的,但是我却记不得,我还一筹莫展,没意识到问题所在,只怪我当时没有写当时的解决办法,一年后在写出来亡羊补牢也不迟。 问题是这样的:我们自己做的电路板,在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.culong 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不一致导致无法启动内核 本帖最后由 Wince.Android 于 2015-5-15 16:49 编辑
如果对linux,Android,wince 等嵌入式底层有兴趣的,请加这个QQ群吧,群号:27100460

回复评论

暂无评论,赶紧抢沙发吧
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复